Annotation of qemu/roms/seabios/src/blockcmd.c, revision 1.1.1.2

1.1       root        1: // Support for several common scsi like command data block requests
                      2: //
                      3: // Copyright (C) 2010  Kevin O'Connor <[email protected]>
                      4: // Copyright (C) 2002  MandrakeSoft S.A.
                      5: //
                      6: // This file may be distributed under the terms of the GNU LGPLv3 license.
                      7: 
                      8: #include "biosvar.h" // GET_GLOBAL
                      9: #include "util.h" // htonl
                     10: #include "disk.h" // struct disk_op_s
                     11: #include "blockcmd.h" // struct cdb_request_sense
                     12: #include "ata.h" // atapi_cmd_data
1.1.1.2 ! root       13: #include "ahci.h" // atapi_cmd_data
1.1       root       14: #include "usb-msc.h" // usb_cmd_data
                     15: 
                     16: // Route command to low-level handler.
                     17: static int
                     18: cdb_cmd_data(struct disk_op_s *op, void *cdbcmd, u16 blocksize)
                     19: {
                     20:     u8 type = GET_GLOBAL(op->drive_g->type);
                     21:     switch (type) {
                     22:     case DTYPE_ATAPI:
                     23:         return atapi_cmd_data(op, cdbcmd, blocksize);
                     24:     case DTYPE_USB:
                     25:         return usb_cmd_data(op, cdbcmd, blocksize);
1.1.1.2 ! root       26:     case DTYPE_AHCI:
        !            27:         return ahci_cmd_data(op, cdbcmd, blocksize);
1.1       root       28:     default:
                     29:         op->count = 0;
                     30:         return DISK_RET_EPARAM;
                     31:     }
                     32: }
                     33: 
                     34: int
                     35: cdb_get_inquiry(struct disk_op_s *op, struct cdbres_inquiry *data)
                     36: {
                     37:     struct cdb_request_sense cmd;
                     38:     memset(&cmd, 0, sizeof(cmd));
                     39:     cmd.command = CDB_CMD_INQUIRY;
                     40:     cmd.length = sizeof(*data);
                     41:     op->count = 1;
                     42:     op->buf_fl = data;
                     43:     return cdb_cmd_data(op, &cmd, sizeof(*data));
                     44: }
                     45: 
                     46: // Request SENSE
                     47: int
                     48: cdb_get_sense(struct disk_op_s *op, struct cdbres_request_sense *data)
                     49: {
                     50:     struct cdb_request_sense cmd;
                     51:     memset(&cmd, 0, sizeof(cmd));
                     52:     cmd.command = CDB_CMD_REQUEST_SENSE;
                     53:     cmd.length = sizeof(*data);
                     54:     op->count = 1;
                     55:     op->buf_fl = data;
                     56:     return cdb_cmd_data(op, &cmd, sizeof(*data));
                     57: }
                     58: 
                     59: // Request capacity
                     60: int
                     61: cdb_read_capacity(struct disk_op_s *op, struct cdbres_read_capacity *data)
                     62: {
                     63:     struct cdb_read_capacity cmd;
                     64:     memset(&cmd, 0, sizeof(cmd));
                     65:     cmd.command = CDB_CMD_READ_CAPACITY;
                     66:     op->count = 1;
                     67:     op->buf_fl = data;
                     68:     return cdb_cmd_data(op, &cmd, sizeof(*data));
                     69: }
                     70: 
                     71: // Read sectors.
                     72: int
                     73: cdb_read(struct disk_op_s *op)
                     74: {
                     75:     struct cdb_rwdata_10 cmd;
                     76:     memset(&cmd, 0, sizeof(cmd));
                     77:     cmd.command = CDB_CMD_READ_10;
                     78:     cmd.lba = htonl(op->lba);
                     79:     cmd.count = htons(op->count);
                     80:     return cdb_cmd_data(op, &cmd, GET_GLOBAL(op->drive_g->blksize));
                     81: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.