X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fdevices%2Fide.h;h=b778f1efa334ebabf4bf431308f943684d9a139f;hb=5e74982843fd03ffa22b1f9818557087dbd045ce;hp=8a68222a47d2e0ae88628230a8d7efd70a2ef9a1;hpb=d0886c953a9e5969ee0f54f11bb146bfe888bfe3;p=palacios.releases.git diff --git a/palacios/include/devices/ide.h b/palacios/include/devices/ide.h index 8a68222..b778f1e 100644 --- a/palacios/include/devices/ide.h +++ b/palacios/include/devices/ide.h @@ -21,27 +21,12 @@ #define __DEVICES_IDE_H__ #ifdef __V3VEE__ -#include +#include -#define ATAPI_BLOCK_SIZE 2048 -#define IDE_SECTOR_SIZE 512 - -typedef enum {IDE_NONE, IDE_DISK, IDE_CDROM} v3_ide_dev_type_t; - -struct v3_ide_cd_ops { - uint32_t (*get_capacity)(void * private_data); - // Reads always operate on 2048 byte blocks - int (*read)(uint8_t * buf, int block_count, uint64_t lba, void * private_data); - -}; - - -struct v3_ide_hd_ops { - uint64_t (*get_capacity)(void * private_data); - // Reads always operate on 2048 byte blocks - int (*read)(uint8_t * buf, int sector_count, uint64_t lba, void * private_data); - +struct ide_cfg { + char pci[32]; + char southbridge[32]; }; @@ -49,20 +34,18 @@ int v3_ide_register_cdrom(struct vm_device * ide, uint_t bus_num, uint_t drive_num, char * drive_name, - struct v3_ide_cd_ops * ops, + struct v3_cd_ops * ops, void * private_data); int v3_ide_register_harddisk(struct vm_device * ide, uint_t bus_num, uint_t drive_num, char * drive_name, - struct v3_ide_hd_ops * ops, + struct v3_hd_ops * ops, void * private_data); -struct vm_device * v3_create_ide(); - int v3_ide_get_geometry(struct vm_device * ide_dev, int channel_num, int drive_num,