ieee1275: no-data-command bus specific method
IEEE 1275-1994 Standard for Boot (Initialization Configuration) Firmware: Core Requirements and Practices E.3.2.2 Bus-specific methods for bus nodes A package implementing the scsi-2 device type shall implement the following bus-specific method: no-data-command ( cmd-addr -- error? ) Executes a simple SCSI command, automatically retrying under certain conditions. cmd-addr is the address of a 6-byte command buffer containing an SCSI command that does not have a data transfer phase. Executes the command, retrying indefinitely with the same retry criteria as retry-command. error? is nonzero if an error occurred, zero otherwise. NOTE no-data-command is a convenience function. It provides no capabilities that are not present in retry-command, but for those commands that meet its restrictions, it is easier to use. Signed-off-by: Eric Snowberg <eric.snowberg@oracle.com> Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
This commit is contained in:
parent
f02037afe3
commit
c422bb6019
2 changed files with 54 additions and 0 deletions
|
@ -733,3 +733,54 @@ grub_ieee1275_set_address (grub_ieee1275_ihandle_t ihandle,
|
|||
|
||||
return args.catch_result;
|
||||
}
|
||||
|
||||
int
|
||||
grub_ieee1275_no_data_command (grub_ieee1275_ihandle_t ihandle,
|
||||
const void *cmd_addr, grub_ssize_t *result)
|
||||
{
|
||||
struct set_address
|
||||
{
|
||||
struct grub_ieee1275_common_hdr common;
|
||||
grub_ieee1275_cell_t method;
|
||||
grub_ieee1275_cell_t ihandle;
|
||||
grub_ieee1275_cell_t cmd_addr;
|
||||
grub_ieee1275_cell_t error;
|
||||
grub_ieee1275_cell_t catch_result;
|
||||
}
|
||||
args;
|
||||
|
||||
INIT_IEEE1275_COMMON (&args.common, "call-method", 3, 2);
|
||||
|
||||
/*
|
||||
* IEEE 1275-1994 Standard for Boot (Initialization Configuration)
|
||||
* Firmware: Core Requirements and Practices
|
||||
*
|
||||
* E.3.2.2 Bus-specific methods for bus nodes
|
||||
*
|
||||
* A package implementing the scsi-2 device type shall implement the
|
||||
* following bus-specific method:
|
||||
*
|
||||
* no-data-command ( cmd-addr -- error? )
|
||||
* Executes a simple SCSI command, automatically retrying under
|
||||
* certain conditions. cmd-addr is the address of a 6-byte command buffer
|
||||
* containing an SCSI command that does not have a data transfer phase.
|
||||
* Executes the command, retrying indefinitely with the same retry criteria
|
||||
* as retry-command.
|
||||
*
|
||||
* error? is nonzero if an error occurred, zero otherwise.
|
||||
* NOTE no-data-command is a convenience function. It provides
|
||||
* no capabilities that are not present in retry-command, but for
|
||||
* those commands that meet its restrictions, it is easier to use.
|
||||
*/
|
||||
args.method = (grub_ieee1275_cell_t) "no-data-command";
|
||||
args.ihandle = ihandle;
|
||||
args.cmd_addr = (grub_ieee1275_cell_t) cmd_addr;
|
||||
|
||||
if (IEEE1275_CALL_ENTRY_FN (&args) == -1)
|
||||
return -1;
|
||||
|
||||
if (result)
|
||||
*result = args.error;
|
||||
|
||||
return args.catch_result;
|
||||
}
|
||||
|
|
|
@ -213,6 +213,9 @@ int EXPORT_FUNC(grub_ieee1275_milliseconds) (grub_uint32_t *msecs);
|
|||
int EXPORT_FUNC(grub_ieee1275_set_address) (grub_ieee1275_ihandle_t ihandle,
|
||||
grub_uint32_t target,
|
||||
grub_uint32_t lun);
|
||||
int EXPORT_FUNC(grub_ieee1275_no_data_command) (grub_ieee1275_ihandle_t ihandle,
|
||||
const void *cmd_addr,
|
||||
grub_ssize_t *result);
|
||||
int EXPORT_FUNC(grub_ieee1275_decode_unit4) (grub_ieee1275_ihandle_t ihandle,
|
||||
void *addr, grub_size_t size,
|
||||
grub_uint32_t *phy_lo,
|
||||
|
|
Loading…
Reference in a new issue