Changeset ee06f2a in mainline for kernel/arch/ia32


Ignore:
Timestamp:
2009-02-15T15:28:00Z (17 years ago)
Author:
Jakub Jermar <jakub@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
2d96f4d
Parents:
e7f2ad68
Message:

Introduce a more platform-neutral name for programmed I/O.

The new API looks like pio_read_n() or pio_write_n(), where n is 8, 16 or 32.
The old API (i.e. inb(), inw(), inl(), outb() outw(), outl()) may have made
some people think that the interface is only to be used with the separate I/O
space. That's not the case. This API is to be implemented on all platforms
so that we can finally have really generic kernel device drivers.

Location:
kernel/arch/ia32
Files:
5 edited

Legend:

Unmodified
Added
Removed
  • kernel/arch/ia32/include/asm.h

    re7f2ad68 ree06f2a  
    106106 * @param val Value to write
    107107 */
    108 static inline void outb(uint16_t port, uint8_t val)
     108static inline void pio_write_8(uint16_t port, uint8_t val)
    109109{
    110110        asm volatile ("outb %b0, %w1\n" : : "a" (val), "d" (port) );
     
    118118 * @param val Value to write
    119119 */
    120 static inline void outw(uint16_t port, uint16_t val)
     120static inline void pio_write_16(uint16_t port, uint16_t val)
    121121{
    122122        asm volatile ("outw %w0, %w1\n" : : "a" (val), "d" (port) );
     
    130130 * @param val Value to write
    131131 */
    132 static inline void outl(uint16_t port, uint32_t val)
     132static inline void pio_write_32(uint16_t port, uint32_t val)
    133133{
    134134        asm volatile ("outl %l0, %w1\n" : : "a" (val), "d" (port) );
     
    142142 * @return Value read
    143143 */
    144 static inline uint8_t inb(uint16_t port)
     144static inline uint8_t pio_read_8(uint16_t port)
    145145{
    146146        uint8_t val;
     
    157157 * @return Value read
    158158 */
    159 static inline uint16_t inw(uint16_t port)
     159static inline uint16_t pio_read_16(uint16_t port)
    160160{
    161161        uint16_t val;
     
    172172 * @return Value read
    173173 */
    174 static inline uint32_t inl(uint16_t port)
     174static inline uint32_t pio_read_32(uint16_t port)
    175175{
    176176        uint32_t val;
  • kernel/arch/ia32/include/drivers/i8042.h

    re7f2ad68 ree06f2a  
    4848static inline void i8042_data_write(uint8_t data)
    4949{
    50         outb(i8042_DATA, data);
     50        pio_write_8(i8042_DATA, data);
    5151}
    5252
    5353static inline uint8_t i8042_data_read(void)
    5454{
    55         return inb(i8042_DATA);
     55        return pio_read_8(i8042_DATA);
    5656}
    5757
    5858static inline uint8_t i8042_status_read(void)
    5959{
    60         return inb(i8042_STATUS);
     60        return pio_read_8(i8042_STATUS);
    6161}
    6262
    6363static inline void i8042_command_write(uint8_t command)
    6464{
    65         outb(i8042_STATUS, command);
     65        pio_write_8(i8042_STATUS, command);
    6666}
    6767
  • kernel/arch/ia32/src/drivers/i8254.c

    re7f2ad68 ree06f2a  
    9595void i8254_normal_operation(void)
    9696{
    97         outb(CLK_PORT4, 0x36);
     97        pio_write_8(CLK_PORT4, 0x36);
    9898        pic_disable_irqs(1 << IRQ_CLK);
    99         outb(CLK_PORT1, (CLK_CONST / HZ) & 0xf);
    100         outb(CLK_PORT1, (CLK_CONST / HZ) >> 8);
     99        pio_write_8(CLK_PORT1, (CLK_CONST / HZ) & 0xf);
     100        pio_write_8(CLK_PORT1, (CLK_CONST / HZ) >> 8);
    101101        pic_enable_irqs(1 << IRQ_CLK);
    102102}
     
    115115         * MAGIC_NUMBER is the magic value for 1ms.
    116116         */
    117         outb(CLK_PORT4, 0x30);
    118         outb(CLK_PORT1, 0xff);
    119         outb(CLK_PORT1, 0xff);
     117        pio_write_8(CLK_PORT4, 0x30);
     118        pio_write_8(CLK_PORT1, 0xff);
     119        pio_write_8(CLK_PORT1, 0xff);
    120120
    121121        do {
    122122                /* will read both status and count */
    123                 outb(CLK_PORT4, 0xc2);
    124                 not_ok = (uint8_t) ((inb(CLK_PORT1) >> 6) & 1);
    125                 t1 = inb(CLK_PORT1);
    126                 t1 |= inb(CLK_PORT1) << 8;
     123                pio_write_8(CLK_PORT4, 0xc2);
     124                not_ok = (uint8_t) ((pio_read_8(CLK_PORT1) >> 6) & 1);
     125                t1 = pio_read_8(CLK_PORT1);
     126                t1 |= pio_read_8(CLK_PORT1) << 8;
    127127        } while (not_ok);
    128128
    129129        asm_delay_loop(LOOPS);
    130130
    131         outb(CLK_PORT4, 0xd2);
    132         t2 = inb(CLK_PORT1);
    133         t2 |= inb(CLK_PORT1) << 8;
     131        pio_write_8(CLK_PORT4, 0xd2);
     132        t2 = pio_read_8(CLK_PORT1);
     133        t2 |= pio_read_8(CLK_PORT1) << 8;
    134134
    135135        /*
    136136         * We want to determine the overhead of the calibrating mechanism.
    137137         */
    138         outb(CLK_PORT4, 0xd2);
    139         o1 = inb(CLK_PORT1);
    140         o1 |= inb(CLK_PORT1) << 8;
     138        pio_write_8(CLK_PORT4, 0xd2);
     139        o1 = pio_read_8(CLK_PORT1);
     140        o1 |= pio_read_8(CLK_PORT1) << 8;
    141141
    142142        asm_fake_loop(LOOPS);
    143143
    144         outb(CLK_PORT4, 0xd2);
    145         o2 = inb(CLK_PORT1);
    146         o2 |= inb(CLK_PORT1) << 8;
     144        pio_write_8(CLK_PORT4, 0xd2);
     145        o2 = pio_read_8(CLK_PORT1);
     146        o2 |= pio_read_8(CLK_PORT1) << 8;
    147147
    148148        CPU->delay_loop_const =
  • kernel/arch/ia32/src/drivers/i8259.c

    re7f2ad68 ree06f2a  
    5050{
    5151        /* ICW1: this is ICW1, ICW4 to follow */
    52         outb(PIC_PIC0PORT1, PIC_ICW1 | PIC_NEEDICW4);
     52        pio_write_8(PIC_PIC0PORT1, PIC_ICW1 | PIC_NEEDICW4);
    5353
    5454        /* ICW2: IRQ 0 maps to INT IRQBASE */
    55         outb(PIC_PIC0PORT2, IVT_IRQBASE);
     55        pio_write_8(PIC_PIC0PORT2, IVT_IRQBASE);
    5656
    5757        /* ICW3: pic1 using IRQ IRQ_PIC1 */
    58         outb(PIC_PIC0PORT2, 1 << IRQ_PIC1);
     58        pio_write_8(PIC_PIC0PORT2, 1 << IRQ_PIC1);
    5959
    6060        /* ICW4: i8086 mode */
    61         outb(PIC_PIC0PORT2, 1);
     61        pio_write_8(PIC_PIC0PORT2, 1);
    6262
    6363        /* ICW1: ICW1, ICW4 to follow */
    64         outb(PIC_PIC1PORT1, PIC_ICW1 | PIC_NEEDICW4);
     64        pio_write_8(PIC_PIC1PORT1, PIC_ICW1 | PIC_NEEDICW4);
    6565
    6666        /* ICW2: IRQ 8 maps to INT (IVT_IRQBASE + 8) */
    67         outb(PIC_PIC1PORT2, IVT_IRQBASE + 8);
     67        pio_write_8(PIC_PIC1PORT2, IVT_IRQBASE + 8);
    6868
    6969        /* ICW3: pic1 is known as IRQ_PIC1 */
    70         outb(PIC_PIC1PORT2, IRQ_PIC1);
     70        pio_write_8(PIC_PIC1PORT2, IRQ_PIC1);
    7171
    7272        /* ICW4: i8086 mode */
    73         outb(PIC_PIC1PORT2, 1);
     73        pio_write_8(PIC_PIC1PORT2, 1);
    7474
    7575        /*
     
    9595
    9696        if (irqmask & 0xff) {
    97                 x = inb(PIC_PIC0PORT2);
    98                 outb(PIC_PIC0PORT2, (uint8_t) (x & (~(irqmask & 0xff))));
     97                x = pio_read_8(PIC_PIC0PORT2);
     98                pio_write_8(PIC_PIC0PORT2, (uint8_t) (x & (~(irqmask & 0xff))));
    9999        }
    100100        if (irqmask >> 8) {
    101                 x = inb(PIC_PIC1PORT2);
    102                 outb(PIC_PIC1PORT2, (uint8_t) (x & (~(irqmask >> 8))));
     101                x = pio_read_8(PIC_PIC1PORT2);
     102                pio_write_8(PIC_PIC1PORT2, (uint8_t) (x & (~(irqmask >> 8))));
    103103        }
    104104}
     
    109109
    110110        if (irqmask & 0xff) {
    111                 x = inb(PIC_PIC0PORT2);
    112                 outb(PIC_PIC0PORT2, (uint8_t) (x | (irqmask & 0xff)));
     111                x = pio_read_8(PIC_PIC0PORT2);
     112                pio_write_8(PIC_PIC0PORT2, (uint8_t) (x | (irqmask & 0xff)));
    113113        }
    114114        if (irqmask >> 8) {
    115                 x = inb(PIC_PIC1PORT2);
    116                 outb(PIC_PIC1PORT2, (uint8_t) (x | (irqmask >> 8)));
     115                x = pio_read_8(PIC_PIC1PORT2);
     116                pio_write_8(PIC_PIC1PORT2, (uint8_t) (x | (irqmask >> 8)));
    117117        }
    118118}
     
    120120void pic_eoi(void)
    121121{
    122         outb(0x20, 0x20);
    123         outb(0xa0, 0x20);
     122        pio_write_8(0x20, 0x20);
     123        pio_write_8(0xa0, 0x20);
    124124}
    125125
  • kernel/arch/ia32/src/smp/smp.c

    re7f2ad68 ree06f2a  
    123123         * BIOS will not do the POST after the INIT signal.
    124124         */
    125         outb(0x70, 0xf);
    126         outb(0x71, 0xa);
     125        pio_write_8(0x70, 0xf);
     126        pio_write_8(0x71, 0xa);
    127127
    128128        pic_disable_irqs(0xffff);
Note: See TracChangeset for help on using the changeset viewer.