symbian-qemu-0.9.1-12/qemu-symbian-svp/hw/isa_mmio.c
changeset 1 2fb8b9db1c86
equal deleted inserted replaced
0:ffa851df0825 1:2fb8b9db1c86
       
     1 /*
       
     2  * Memory mapped access to ISA IO space.
       
     3  *
       
     4  * Copyright (c) 2006 Fabrice Bellard
       
     5  *
       
     6  * Permission is hereby granted, free of charge, to any person obtaining a copy
       
     7  * of this software and associated documentation files (the "Software"), to deal
       
     8  * in the Software without restriction, including without limitation the rights
       
     9  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
       
    10  * copies of the Software, and to permit persons to whom the Software is
       
    11  * furnished to do so, subject to the following conditions:
       
    12  *
       
    13  * The above copyright notice and this permission notice shall be included in
       
    14  * all copies or substantial portions of the Software.
       
    15  *
       
    16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
       
    17  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
       
    18  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
       
    19  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
       
    20  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
       
    21  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
       
    22  * THE SOFTWARE.
       
    23  */
       
    24 
       
    25 #include "hw.h"
       
    26 #include "isa.h"
       
    27 
       
    28 static void isa_mmio_writeb (void *opaque, target_phys_addr_t addr,
       
    29                                   uint32_t val)
       
    30 {
       
    31     cpu_outb(NULL, addr & 0xffff, val);
       
    32 }
       
    33 
       
    34 static void isa_mmio_writew (void *opaque, target_phys_addr_t addr,
       
    35                                   uint32_t val)
       
    36 {
       
    37 #ifdef TARGET_WORDS_BIGENDIAN
       
    38     val = bswap16(val);
       
    39 #endif
       
    40     cpu_outw(NULL, addr & 0xffff, val);
       
    41 }
       
    42 
       
    43 static void isa_mmio_writel (void *opaque, target_phys_addr_t addr,
       
    44                                 uint32_t val)
       
    45 {
       
    46 #ifdef TARGET_WORDS_BIGENDIAN
       
    47     val = bswap32(val);
       
    48 #endif
       
    49     cpu_outl(NULL, addr & 0xffff, val);
       
    50 }
       
    51 
       
    52 static uint32_t isa_mmio_readb (void *opaque, target_phys_addr_t addr)
       
    53 {
       
    54     uint32_t val;
       
    55 
       
    56     val = cpu_inb(NULL, addr & 0xffff);
       
    57     return val;
       
    58 }
       
    59 
       
    60 static uint32_t isa_mmio_readw (void *opaque, target_phys_addr_t addr)
       
    61 {
       
    62     uint32_t val;
       
    63 
       
    64     val = cpu_inw(NULL, addr & 0xffff);
       
    65 #ifdef TARGET_WORDS_BIGENDIAN
       
    66     val = bswap16(val);
       
    67 #endif
       
    68     return val;
       
    69 }
       
    70 
       
    71 static uint32_t isa_mmio_readl (void *opaque, target_phys_addr_t addr)
       
    72 {
       
    73     uint32_t val;
       
    74 
       
    75     val = cpu_inl(NULL, addr & 0xffff);
       
    76 #ifdef TARGET_WORDS_BIGENDIAN
       
    77     val = bswap32(val);
       
    78 #endif
       
    79     return val;
       
    80 }
       
    81 
       
    82 static CPUWriteMemoryFunc *isa_mmio_write[] = {
       
    83     &isa_mmio_writeb,
       
    84     &isa_mmio_writew,
       
    85     &isa_mmio_writel,
       
    86 };
       
    87 
       
    88 static CPUReadMemoryFunc *isa_mmio_read[] = {
       
    89     &isa_mmio_readb,
       
    90     &isa_mmio_readw,
       
    91     &isa_mmio_readl,
       
    92 };
       
    93 
       
    94 static int isa_mmio_iomemtype = 0;
       
    95 
       
    96 void isa_mmio_init(target_phys_addr_t base, target_phys_addr_t size)
       
    97 {
       
    98     if (!isa_mmio_iomemtype) {
       
    99         isa_mmio_iomemtype = cpu_register_io_memory(0, isa_mmio_read,
       
   100                                                     isa_mmio_write, NULL);
       
   101     }
       
   102     cpu_register_physical_memory(base, size, isa_mmio_iomemtype);
       
   103 }