Disallow unaligned access to I/O ports.

This commit is contained in:
Philip Homburg 2007-04-23 13:31:16 +00:00
parent 7541e0753b
commit d2cec7db49

View file

@ -30,6 +30,14 @@ register message *m_ptr; /* pointer to request message */
io_type = m_ptr->DIO_REQUEST & _DIO_TYPEMASK; io_type = m_ptr->DIO_REQUEST & _DIO_TYPEMASK;
io_dir = m_ptr->DIO_REQUEST & _DIO_DIRMASK; io_dir = m_ptr->DIO_REQUEST & _DIO_DIRMASK;
switch (io_type)
{
case _DIO_BYTE: size= 1; break;
case _DIO_WORD: size= 2; break;
case _DIO_LONG: size= 4; break;
default: size= 4; break; /* Be conservative */
}
rp= proc_addr(who_p); rp= proc_addr(who_p);
privp= priv(rp); privp= priv(rp);
if (!privp) if (!privp)
@ -55,14 +63,17 @@ register message *m_ptr; /* pointer to request message */
} }
if (i >= nr_io_range) if (i >= nr_io_range)
{ {
kprintf(
"do_devio: I/O port check failed for proc %d, port 0x%x\n",
m_ptr->m_source, port);
return EPERM; return EPERM;
} }
} }
doit: doit:
if (m_ptr->DIO_PORT & (size-1))
{
kprintf("do_devio: unaligned port 0x%x (size %d)\n",
m_ptr->DIO_PORT, size);
return EPERM;
}
/* Process a single I/O request for byte, word, and long values. */ /* Process a single I/O request for byte, word, and long values. */
if (io_dir == _DIO_INPUT) { if (io_dir == _DIO_INPUT) {