mirror of https://github.com/ipxe/ipxe.git
[cmdline] Rewrite "sync" command to use monojob_wait()
Signed-off-by: Michael Brown <mcb30@ipxe.org>pull/17/head
parent
dc7a023715
commit
92c56e129b
|
@ -31,7 +31,7 @@ FILE_LICENCE ( GPL2_OR_LATER );
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/** Total count of pending operations */
|
/** Total count of pending operations */
|
||||||
static int pending_total;
|
int pending_total;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Mark an operation as pending
|
* Mark an operation as pending
|
||||||
|
@ -60,21 +60,3 @@ void pending_put ( struct pending_operation *pending ) {
|
||||||
pending, pending->count, pending_total );
|
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;
|
|
||||||
}
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ FILE_LICENCE ( GPL2_OR_LATER );
|
||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
#include <ipxe/command.h>
|
#include <ipxe/command.h>
|
||||||
#include <ipxe/parseopt.h>
|
#include <ipxe/parseopt.h>
|
||||||
#include <ipxe/pending.h>
|
#include <usr/sync.h>
|
||||||
|
|
||||||
/** @file
|
/** @file
|
||||||
*
|
*
|
||||||
|
@ -65,7 +65,7 @@ static int sync_exec ( int argc, char **argv ) {
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
/* Wait for pending operations to complete */
|
/* 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 ) );
|
printf ( "Operations did not complete: %s\n", strerror ( rc ) );
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,8 +9,6 @@
|
||||||
|
|
||||||
FILE_LICENCE ( GPL2_OR_LATER );
|
FILE_LICENCE ( GPL2_OR_LATER );
|
||||||
|
|
||||||
#include <ipxe/list.h>
|
|
||||||
|
|
||||||
/** A pending operation */
|
/** A pending operation */
|
||||||
struct pending_operation {
|
struct pending_operation {
|
||||||
/** Pending count */
|
/** Pending count */
|
||||||
|
@ -21,14 +19,24 @@ struct pending_operation {
|
||||||
* Check if an operation is pending
|
* Check if an operation is pending
|
||||||
*
|
*
|
||||||
* @v pending Pending operation
|
* @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 ) {
|
static inline int is_pending ( struct pending_operation *pending ) {
|
||||||
return ( pending->count != 0 );
|
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_get ( struct pending_operation *pending );
|
||||||
extern void pending_put ( struct pending_operation *pending );
|
extern void pending_put ( struct pending_operation *pending );
|
||||||
extern int pending_wait ( unsigned long timeout );
|
|
||||||
|
|
||||||
#endif /* _IPXE_PENDING_H */
|
#endif /* _IPXE_PENDING_H */
|
||||||
|
|
|
@ -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 */
|
|
@ -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 );
|
||||||
|
}
|
Loading…
Reference in New Issue