david/ipxe
david
/
ipxe
Archived
1
0
Fork 0

[cmdline] Rewrite "sync" command to use monojob_wait()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
This commit is contained in:
Michael Brown 2013-11-01 01:56:33 +00:00
parent dc7a023715
commit 92c56e129b
5 changed files with 103 additions and 25 deletions

View File

@ -31,7 +31,7 @@ FILE_LICENCE ( GPL2_OR_LATER );
*/
/** Total count of pending operations */
static int pending_total;
int pending_total;
/**
* Mark an operation as pending
@ -60,21 +60,3 @@ void pending_put ( struct pending_operation *pending ) {
pending, pending->count, pending_total );
}
}
/**
* Wait for pending operations to complete
*
* @v timeout Timeout period, in ticks (0=indefinite)
* @ret rc Return status code
*/
int pending_wait ( unsigned long timeout ) {
unsigned long start = currticks();
do {
if ( pending_total == 0 )
return 0;
step();
} while ( ( timeout == 0 ) || ( ( currticks() - start ) < timeout ) );
return -ETIMEDOUT;
}

View File

@ -24,7 +24,7 @@ FILE_LICENCE ( GPL2_OR_LATER );
#include <getopt.h>
#include <ipxe/command.h>
#include <ipxe/parseopt.h>
#include <ipxe/pending.h>
#include <usr/sync.h>
/** @file
*
@ -65,7 +65,7 @@ static int sync_exec ( int argc, char **argv ) {
return rc;
/* Wait for pending operations to complete */
if ( ( rc = pending_wait ( opts.timeout ) ) != 0 ) {
if ( ( rc = sync ( opts.timeout ) ) != 0 ) {
printf ( "Operations did not complete: %s\n", strerror ( rc ) );
return rc;
}

View File

@ -9,8 +9,6 @@
FILE_LICENCE ( GPL2_OR_LATER );
#include <ipxe/list.h>
/** A pending operation */
struct pending_operation {
/** Pending count */
@ -21,14 +19,24 @@ struct pending_operation {
* Check if an operation is pending
*
* @v pending Pending operation
* @v is_pending Operation is pending
* @ret is_pending Operation is pending
*/
static inline int is_pending ( struct pending_operation *pending ) {
return ( pending->count != 0 );
}
extern int pending_total;
/**
* Check if any operations are pending
*
* @ret have_pending Some operations are pending
*/
static inline int have_pending ( void ) {
return ( pending_total != 0 );
}
extern void pending_get ( struct pending_operation *pending );
extern void pending_put ( struct pending_operation *pending );
extern int pending_wait ( unsigned long timeout );
#endif /* _IPXE_PENDING_H */

14
src/include/usr/sync.h Normal file
View File

@ -0,0 +1,14 @@
#ifndef _USR_SYNC_H
#define _USR_SYNC_H
/** @file
*
* Wait for pending operations to complete
*
*/
FILE_LICENCE ( GPL2_OR_LATER );
extern int sync ( unsigned long timeout );
#endif /* _USR_SYNC_H */

74
src/usr/sync.c Normal file
View File

@ -0,0 +1,74 @@
/*
* Copyright (C) 2012 Michael Brown <mbrown@fensystems.co.uk>.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301, USA.
*/
FILE_LICENCE ( GPL2_OR_LATER );
#include <stddef.h>
#include <ipxe/job.h>
#include <ipxe/monojob.h>
#include <ipxe/pending.h>
#include <usr/sync.h>
/** @file
*
* Wait for pending operations to complete
*
*/
/**
* Report progress
*
* @v intf Interface
* @v progress Progress report to fill in
* @ret ongoing_rc Ongoing job status code (if known)
*/
static int sync_progress ( struct interface *intf,
struct job_progress *progress __unused ) {
/* Terminate successfully if no pending operations remain */
if ( ! have_pending() )
intf_close ( intf, 0 );
return 0;
}
/** Synchroniser interface operations */
static struct interface_operation sync_intf_op[] = {
INTF_OP ( job_progress, struct interface *, sync_progress ),
};
/** Synchroniser interface descriptor */
static struct interface_descriptor sync_intf_desc =
INTF_DESC_PURE ( sync_intf_op );
/** Synchroniser */
static struct interface sync_intf = INTF_INIT ( sync_intf_desc );
/**
* Wait for pending operations to complete
*
* @v timeout Timeout period, in ticks (0=indefinite)
* @ret rc Return status code
*/
int sync ( unsigned long timeout ) {
/* Attach synchroniser and wait for completion */
intf_plug_plug ( &monojob, &sync_intf );
return monojob_wait ( NULL, timeout );
}