2008-08-17 11:49:42 +00:00
|
|
|
--- a/coregrind/m_syswrap/syswrap-amd64-linux.c
|
|
|
|
+++ b/coregrind/m_syswrap/syswrap-amd64-linux.c
|
|
|
|
@@ -1165,7 +1165,7 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
GENXY(__NR_times, sys_times), // 100
|
|
|
|
PLAXY(__NR_ptrace, sys_ptrace), // 101
|
|
|
|
GENX_(__NR_getuid, sys_getuid), // 102
|
|
|
|
- // (__NR_syslog, sys_syslog), // 103
|
|
|
|
+ LINXY(__NR_syslog, sys_syslog), // 103
|
|
|
|
GENX_(__NR_getgid, sys_getgid), // 104
|
|
|
|
|
|
|
|
GENX_(__NR_setuid, sys_setuid), // 105
|
2008-08-17 11:49:42 +00:00
|
|
|
--- a/include/vki/vki-linux.h
|
|
|
|
+++ b/include/vki/vki-linux.h
|
|
|
|
@@ -1582,7 +1582,9 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
|
|
|
|
#define VKI_BLKROSET _VKI_IO(0x12,93) /* set device read-only (0 = read-write) */
|
|
|
|
#define VKI_BLKROGET _VKI_IO(0x12,94) /* get read-only status (0 = read_write) */
|
|
|
|
+#define VKI_BLKRRPART _VKI_IO(0x12,95) /* re-read partition table */
|
|
|
|
#define VKI_BLKGETSIZE _VKI_IO(0x12,96) /* return device size /512 (long *arg) */
|
|
|
|
+#define VKI_BLKFLSBUF _VKI_IO(0x12,97) /* flush buffer cache */
|
|
|
|
#define VKI_BLKRASET _VKI_IO(0x12,98) /* set read ahead for block device */
|
|
|
|
#define VKI_BLKRAGET _VKI_IO(0x12,99) /* get current read ahead setting */
|
|
|
|
#define VKI_BLKFRASET _VKI_IO(0x12,100)/* set filesystem (mm/filemap.c) read-ahead */
|
2008-08-17 11:49:42 +00:00
|
|
|
@@ -1657,6 +1659,54 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
//#define SG_GET_COMMAND_Q 0x2270 /* Yields 0 (queuing off) or 1 (on) */
|
|
|
|
#define VKI_SG_SET_COMMAND_Q 0x2271 /* Change queuing state with 0 or 1 */
|
|
|
|
|
|
|
|
+
|
|
|
|
+typedef struct vki_scsi_idlun
|
|
|
|
+{
|
|
|
|
+ int mux4;
|
|
|
|
+ int host_unique_id;
|
|
|
|
+
|
|
|
|
+} vki_scsi_idlun_t;
|
|
|
|
+#define VKI_SCSI_IOCTL_GET_IDLUN 0x5382 /* Gets a struct vki_scsi_idlun */
|
|
|
|
+#define VKI_SCSI_IOCTL_PROBE_HOST 0x5385 /* Gets an arrary describing the SCSI host */
|
|
|
|
+#define VKI_SCSI_IOCTL_GET_BUS_NUMBER 0x5386 /* Get the bus number for a device */
|
|
|
|
+
|
|
|
|
+//----------------------------------------------------------------------
|
|
|
|
+// From linux-2.6.8.1/include/linux/fd.h
|
|
|
|
+//----------------------------------------------------------------------
|
|
|
|
+#define VKI_FDRESET 0x254 /* Takes an int by value */
|
|
|
|
+#define VKI_FDGETDRVTYP 0x20f /* Returns char floppy_drive_name[16] */
|
|
|
|
+typedef struct vki_floppy_drive_struct {
|
|
|
|
+ unsigned long flags;
|
|
|
|
+ unsigned long spinup_date;
|
|
|
|
+ unsigned long select_date;
|
|
|
|
+ unsigned long first_read_date;
|
|
|
|
+ short probed_format;
|
|
|
|
+ short track;
|
|
|
|
+ short maxblock;
|
|
|
|
+ short maxtrack;
|
|
|
|
+ int generation;
|
|
|
|
+ int keep_data;
|
|
|
|
+ int fd_ref;
|
|
|
|
+ int fd_device;
|
|
|
|
+ unsigned long last_checked;
|
|
|
|
+ char *dmabuf;
|
|
|
|
+ int bufblocks;
|
|
|
|
+} vki_floppy_drive_struct_t;
|
|
|
|
+#define VKI_FDPOLLDRVSTAT 0x213 /* returns a struct floppy_drive_struct */
|
|
|
|
+typedef struct vki_floppy_struct {
|
|
|
|
+ unsigned int size;
|
|
|
|
+ unsigned int sect;
|
|
|
|
+ unsigned int head;
|
|
|
|
+ unsigned int track;
|
|
|
|
+ unsigned int stretch;
|
|
|
|
+ unsigned char gap;
|
|
|
|
+ unsigned char rate;
|
|
|
|
+ unsigned char spec1;
|
|
|
|
+ unsigned char fmt_gap;
|
|
|
|
+ const char * name;
|
|
|
|
+} vki_floppy_struct_t;
|
|
|
|
+#define VKI_FDGETPRM 0x204 /* returns a struct floppy_struct */
|
|
|
|
+
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
// From linux-2.6.8.1/include/linux/cdrom.h
|
|
|
|
//----------------------------------------------------------------------
|
2008-08-17 11:49:42 +00:00
|
|
|
@@ -1666,6 +1716,7 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
(struct cdrom_tochdr) */
|
|
|
|
#define VKI_CDROMREADTOCENTRY 0x5306 /* Read TOC entry
|
|
|
|
(struct cdrom_tocentry) */
|
|
|
|
+#define VKI_CDROMEJECT 0x5309 /* Eject cdrom media */
|
|
|
|
#define VKI_CDROMSUBCHNL 0x530b /* Read subchannel data
|
|
|
|
(struct cdrom_subchnl) */
|
|
|
|
#define VKI_CDROMREADMODE2 0x530c /* Read CDROM mode 2 data (2336 Bytes)
|
2008-08-17 11:49:42 +00:00
|
|
|
--- a/coregrind/m_syswrap/syswrap-generic.c
|
|
|
|
+++ b/coregrind/m_syswrap/syswrap-generic.c
|
|
|
|
@@ -3288,6 +3288,33 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
case VKI_SG_GET_SG_TABLESIZE: /* 0x227f */
|
|
|
|
PRE_MEM_WRITE( "ioctl(SG_GET_SG_TABLESIZE)", ARG3, sizeof(int) );
|
|
|
|
break;
|
|
|
|
+ case VKI_SCSI_IOCTL_GET_IDLUN:
|
|
|
|
+ PRE_MEM_WRITE( "ioctl(SCSI_IOCTL_GET_IDLUN)", ARG3, sizeof(vki_scsi_idlun_t) );
|
|
|
|
+ break;
|
|
|
|
+ case VKI_SCSI_IOCTL_PROBE_HOST:
|
|
|
|
+ {
|
|
|
|
+ int arraylen;
|
|
|
|
+ char *array = (char*)ARG3;
|
|
|
|
+ PRE_MEM_READ("ioctl(SCSI_IOCTL_PROBE_HOST)", ARG3, sizeof(char)*4 );
|
|
|
|
+ arraylen = array[0] + (array[1]<<8) + (array[2]<<16) + (array[3]<<24);
|
|
|
|
+ PRE_MEM_WRITE( "ioctl(SCSI_IOCTL_PROBE_HOST)", ARG3, sizeof(char)*arraylen );
|
|
|
|
+ }
|
|
|
|
+ break;
|
|
|
|
+ case VKI_SCSI_IOCTL_GET_BUS_NUMBER:
|
|
|
|
+ PRE_MEM_WRITE( "ioctl(SCSI_IOCTL_GET_BUS_NUMBER)", ARG3, sizeof(int) );
|
|
|
|
+ break;
|
|
|
|
+
|
|
|
|
+ case VKI_FDRESET:
|
|
|
|
+ break;
|
|
|
|
+ case VKI_FDGETDRVTYP:
|
|
|
|
+ PRE_MEM_WRITE( "ioctl(FDGETDRVTYP)", ARG3, sizeof(char)*16 );
|
|
|
|
+ break;
|
|
|
|
+ case VKI_FDPOLLDRVSTAT:
|
|
|
|
+ PRE_MEM_WRITE( "ioctl(FDPOLLDRVSTAT)", ARG3, sizeof(vki_floppy_drive_struct_t) );
|
|
|
|
+ break;
|
|
|
|
+ case VKI_FDGETPRM:
|
|
|
|
+ PRE_MEM_WRITE( "ioctl(FDGETPRM)", ARG3, sizeof(vki_floppy_struct_t) );
|
|
|
|
+ break;
|
|
|
|
|
|
|
|
case VKI_IIOCGETCPS:
|
|
|
|
PRE_MEM_WRITE( "ioctl(IIOCGETCPS)", ARG3,
|
2008-08-17 11:49:42 +00:00
|
|
|
@@ -3611,6 +3638,8 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
case VKI_BLKROGET:
|
|
|
|
PRE_MEM_WRITE( "ioctl(BLKROGET)", ARG3, sizeof(int));
|
|
|
|
break;
|
|
|
|
+ case VKI_BLKRRPART:
|
|
|
|
+ break;
|
|
|
|
case VKI_BLKGETSIZE:
|
|
|
|
PRE_MEM_WRITE( "ioctl(BLKGETSIZE)", ARG3, sizeof(unsigned long));
|
|
|
|
break;
|
2008-08-17 11:49:42 +00:00
|
|
|
@@ -3619,6 +3648,8 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
case VKI_BLKRAGET:
|
|
|
|
PRE_MEM_WRITE( "ioctl(BLKRAGET)", ARG3, sizeof(long));
|
|
|
|
break;
|
|
|
|
+ case VKI_BLKFLSBUF:
|
|
|
|
+ break;
|
|
|
|
case VKI_BLKFRASET:
|
|
|
|
break;
|
|
|
|
case VKI_BLKFRAGET:
|
2008-08-17 11:49:42 +00:00
|
|
|
@@ -3685,6 +3716,8 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
PRE_MEM_WRITE( "ioctl(CDROMREADTOCENTRY)", ARG3,
|
|
|
|
sizeof(struct vki_cdrom_tocentry));
|
|
|
|
break;
|
|
|
|
+ case VKI_CDROMEJECT:
|
|
|
|
+ break;
|
|
|
|
case VKI_CDROMMULTISESSION: /* 0x5310 */
|
|
|
|
PRE_MEM_WRITE( "ioctl(CDROMMULTISESSION)", ARG3,
|
|
|
|
sizeof(struct vki_cdrom_multisession));
|
2008-08-17 11:49:42 +00:00
|
|
|
@@ -4274,6 +4307,28 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
case VKI_SG_GET_SG_TABLESIZE:
|
|
|
|
POST_MEM_WRITE(ARG3, sizeof(int));
|
|
|
|
break;
|
|
|
|
+ case VKI_SCSI_IOCTL_GET_IDLUN:
|
|
|
|
+ POST_MEM_WRITE(ARG3, sizeof(vki_scsi_idlun_t));
|
|
|
|
+ break;
|
|
|
|
+ case VKI_SCSI_IOCTL_PROBE_HOST:
|
|
|
|
+ if (RES > 0 && ARG3 )
|
|
|
|
+ POST_MEM_WRITE(ARG3, sizeof(char)*RES);
|
|
|
|
+ break;
|
|
|
|
+ case VKI_SCSI_IOCTL_GET_BUS_NUMBER:
|
|
|
|
+ POST_MEM_WRITE(ARG3, sizeof(int));
|
|
|
|
+ break;
|
|
|
|
+
|
|
|
|
+ case VKI_FDRESET:
|
|
|
|
+ break;
|
|
|
|
+ case VKI_FDGETDRVTYP:
|
|
|
|
+ POST_MEM_WRITE( ARG3, sizeof(char)*16 );
|
|
|
|
+ break;
|
|
|
|
+ case VKI_FDPOLLDRVSTAT:
|
|
|
|
+ POST_MEM_WRITE( ARG3, sizeof(vki_floppy_drive_struct_t) );
|
|
|
|
+ break;
|
|
|
|
+ case VKI_FDGETPRM:
|
|
|
|
+ POST_MEM_WRITE( ARG3, sizeof(vki_floppy_struct_t) );
|
|
|
|
+ break;
|
|
|
|
|
|
|
|
case VKI_IIOCGETCPS:
|
|
|
|
POST_MEM_WRITE( ARG3, VKI_ISDN_MAX_CHANNELS * 2 * sizeof(unsigned long) );
|
2008-08-17 11:49:42 +00:00
|
|
|
@@ -4492,6 +4547,8 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
case VKI_BLKROGET:
|
|
|
|
POST_MEM_WRITE(ARG3, sizeof(int));
|
|
|
|
break;
|
|
|
|
+ case VKI_BLKRRPART:
|
|
|
|
+ break;
|
|
|
|
case VKI_BLKGETSIZE:
|
|
|
|
POST_MEM_WRITE(ARG3, sizeof(unsigned long));
|
|
|
|
break;
|
2008-08-17 11:49:42 +00:00
|
|
|
@@ -4500,6 +4557,8 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
case VKI_BLKRAGET:
|
|
|
|
POST_MEM_WRITE(ARG3, sizeof(long));
|
|
|
|
break;
|
|
|
|
+ case VKI_BLKFLSBUF:
|
|
|
|
+ break;
|
|
|
|
case VKI_BLKFRASET:
|
|
|
|
break;
|
|
|
|
case VKI_BLKFRAGET:
|
2008-08-17 11:49:42 +00:00
|
|
|
@@ -4541,6 +4600,8 @@
|
2007-10-25 13:59:16 +00:00
|
|
|
case VKI_CDROMREADTOCENTRY:
|
|
|
|
POST_MEM_WRITE(ARG3, sizeof(struct vki_cdrom_tocentry));
|
|
|
|
break;
|
|
|
|
+ case VKI_CDROMEJECT:
|
|
|
|
+ break;
|
|
|
|
case VKI_CDROMMULTISESSION:
|
|
|
|
POST_MEM_WRITE(ARG3, sizeof(struct vki_cdrom_multisession));
|
|
|
|
break;
|