]> Zhao Yanbai Git Server - minix.git/commitdiff
Message type for SYS_READBIOS.
authorLionel Sambuc <lionel@minix3.org>
Fri, 25 Jul 2014 13:54:54 +0000 (15:54 +0200)
committerLionel Sambuc <lionel@minix3.org>
Mon, 28 Jul 2014 15:06:25 +0000 (17:06 +0200)
Change-Id: Id19f658f5eb5f350e3e19f9ce3f8ae80aea23c51

include/minix/com.h
include/minix/ipc.h
kernel/arch/i386/do_readbios.c
lib/libsys/arch/i386/sys_readbios.c

index 5e3e795363d3758848bb6edb7a63df586cf1f163..f9cb110ed57cc5eee0ef3f874817487e6bb505ff 100644 (file)
 #define PROF_CTL_PTR   m7_p1    /* location of info struct */
 #define PROF_MEM_PTR   m7_p2    /* location of profiling data */
 
-/* Field names for SYS_READBIOS. */
-#define RDB_SIZE       m2_i1
-#define RDB_ADDR       m2_l1
-#define RDB_BUF                m2_p1
-
 /* Field names for SYS_VMCTL. */
 #define SVMCTL_WHO     m1_i1
 #define SVMCTL_PARAM   m1_i2   /* All SYS_VMCTL requests. */
index a5c2151f739110e9fefc3a78a02356457ffec5e5..4f3e876077ab5feeb76178b46c472ebfab245c3e 100644 (file)
@@ -115,6 +115,15 @@ typedef struct {
 } mess_11;
 _ASSERT_MSG_SIZE(mess_11);
 
+typedef struct {
+       size_t size;
+       phys_bytes addr;
+       vir_bytes buf;
+
+       uint8_t padding[44];
+} mess_lsys_krn_readbios;
+_ASSERT_MSG_SIZE(mess_lsys_krn_readbios);
+
 typedef struct {
        off_t offset;
        void *addr;
@@ -1952,6 +1961,7 @@ typedef struct {
                mess_notify             m_notify;
                mess_sigcalls           m_sigcalls;
 
+               mess_lsys_krn_readbios  m_lsys_krn_readbios;
                mess_input_tty_event    m_input_tty_event;
 
                mess_krn_lsys_schedule  m_krn_lsys_schedule;
index 3f162570fe44ff691dfdfb547720dd84634151f6..b7ad3c524127c29a9faa5796cffe566201cc8df5 100644 (file)
@@ -2,9 +2,9 @@
  *   m_type:   SYS_READBIOS
  *
  * The parameters for this kernel call are:
- *    m2_i1:   RDB_SIZE                number of bytes to copy
- *    m2_l1:   RDB_ADDR                absolute address in BIOS area
- *    m2_p1:   RDB_BUF                 buffer address in requesting process
+ *     m_lsys_krn_readbios.size        number of bytes to copy
+ *     m_lsys_krn_readbios.addr        absolute address in BIOS area
+ *     m_lsys_krn_readbios.buf         buffer address in requesting process
  */
 
 #include "kernel/system.h"
 int do_readbios(struct proc * caller, message * m_ptr)
 {
   struct vir_addr src, dst;
-  vir_bytes len = m_ptr->RDB_SIZE, limit;
+  size_t len = m_ptr->m_lsys_krn_readbios.size;
+  vir_bytes limit;
 
-  src.offset = m_ptr->RDB_ADDR;
-  dst.offset = (vir_bytes) m_ptr->RDB_BUF;
+  src.offset = m_ptr->m_lsys_krn_readbios.addr;
+  dst.offset = m_ptr->m_lsys_krn_readbios.buf;
   src.proc_nr_e = NONE;
   dst.proc_nr_e = m_ptr->m_source;      
 
@@ -33,5 +34,5 @@ int do_readbios(struct proc * caller, message * m_ptr)
      !USERRANGE(BASE_MEM_TOP, UPPER_MEM_END))
        return EPERM;
 
-  return virtual_copy_vmcheck(caller, &src, &dst, m_ptr->RDB_SIZE);
+  return virtual_copy_vmcheck(caller, &src, &dst, m_ptr->m_lsys_krn_readbios.size);
 }
index 3e3f555e87564f524cab0a9f928a25b08c3213a0..497f3c4bf059cb8465516a88a1d9f26af838cfd3 100644 (file)
@@ -8,8 +8,8 @@ size_t size;                    /* Amount of data to read */
 /* Read data from BIOS locations */
   message m;
 
-  m.RDB_SIZE = size;
-  m.RDB_ADDR = address;
-  m.RDB_BUF = buf;
+  m.m_lsys_krn_readbios.size = size;
+  m.m_lsys_krn_readbios.addr = address;
+  m.m_lsys_krn_readbios.buf = buf;
   return(_kernel_call(SYS_READBIOS, &m));
 }