Commit f658b4db792285d0ddc044d7532451b8ec3c4a08
1 parent
0c4ad8dc
isa bridge endianness fixes
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@761 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
12 additions
and
4 deletions
hw/ppc_prep.c
| @@ -137,7 +137,6 @@ static uint32_t PPC_io_readb (target_phys_addr_t addr) | @@ -137,7 +137,6 @@ static uint32_t PPC_io_readb (target_phys_addr_t addr) | ||
| 137 | { | 137 | { |
| 138 | PPC_IO_DPRINTF("0x%08x <= 0x%02x\n", addr - PPC_IO_BASE, ret); | 138 | PPC_IO_DPRINTF("0x%08x <= 0x%02x\n", addr - PPC_IO_BASE, ret); |
| 139 | } | 139 | } |
| 140 | - | ||
| 141 | return ret; | 140 | return ret; |
| 142 | } | 141 | } |
| 143 | 142 | ||
| @@ -147,24 +146,31 @@ static void PPC_io_writew (target_phys_addr_t addr, uint32_t value) | @@ -147,24 +146,31 @@ static void PPC_io_writew (target_phys_addr_t addr, uint32_t value) | ||
| 147 | (addr < 0x80000170 || addr > 0x80000177)) { | 146 | (addr < 0x80000170 || addr > 0x80000177)) { |
| 148 | PPC_IO_DPRINTF("0x%08x => 0x%04x\n", addr - PPC_IO_BASE, value); | 147 | PPC_IO_DPRINTF("0x%08x => 0x%04x\n", addr - PPC_IO_BASE, value); |
| 149 | } | 148 | } |
| 149 | +#ifdef TARGET_WORDS_BIGENDIAN | ||
| 150 | + value = bswap16(value); | ||
| 151 | +#endif | ||
| 150 | cpu_outw(NULL, addr - PPC_IO_BASE, value); | 152 | cpu_outw(NULL, addr - PPC_IO_BASE, value); |
| 151 | } | 153 | } |
| 152 | 154 | ||
| 153 | static uint32_t PPC_io_readw (target_phys_addr_t addr) | 155 | static uint32_t PPC_io_readw (target_phys_addr_t addr) |
| 154 | { | 156 | { |
| 155 | uint32_t ret = cpu_inw(NULL, addr - PPC_IO_BASE); | 157 | uint32_t ret = cpu_inw(NULL, addr - PPC_IO_BASE); |
| 156 | - | 158 | +#ifdef TARGET_WORDS_BIGENDIAN |
| 159 | + ret = bswap16(ret); | ||
| 160 | +#endif | ||
| 157 | if ((addr < 0x800001f0 || addr > 0x800001f7) && | 161 | if ((addr < 0x800001f0 || addr > 0x800001f7) && |
| 158 | (addr < 0x80000170 || addr > 0x80000177)) { | 162 | (addr < 0x80000170 || addr > 0x80000177)) { |
| 159 | PPC_IO_DPRINTF("0x%08x <= 0x%04x\n", addr - PPC_IO_BASE, ret); | 163 | PPC_IO_DPRINTF("0x%08x <= 0x%04x\n", addr - PPC_IO_BASE, ret); |
| 160 | } | 164 | } |
| 161 | - | ||
| 162 | return ret; | 165 | return ret; |
| 163 | } | 166 | } |
| 164 | 167 | ||
| 165 | static void PPC_io_writel (target_phys_addr_t addr, uint32_t value) | 168 | static void PPC_io_writel (target_phys_addr_t addr, uint32_t value) |
| 166 | { | 169 | { |
| 167 | PPC_IO_DPRINTF("0x%08x => 0x%08x\n", addr - PPC_IO_BASE, value); | 170 | PPC_IO_DPRINTF("0x%08x => 0x%08x\n", addr - PPC_IO_BASE, value); |
| 171 | +#ifdef TARGET_WORDS_BIGENDIAN | ||
| 172 | + value = bswap32(value); | ||
| 173 | +#endif | ||
| 168 | cpu_outl(NULL, addr - PPC_IO_BASE, value); | 174 | cpu_outl(NULL, addr - PPC_IO_BASE, value); |
| 169 | } | 175 | } |
| 170 | 176 | ||
| @@ -172,8 +178,10 @@ static uint32_t PPC_io_readl (target_phys_addr_t addr) | @@ -172,8 +178,10 @@ static uint32_t PPC_io_readl (target_phys_addr_t addr) | ||
| 172 | { | 178 | { |
| 173 | uint32_t ret = cpu_inl(NULL, addr - PPC_IO_BASE); | 179 | uint32_t ret = cpu_inl(NULL, addr - PPC_IO_BASE); |
| 174 | 180 | ||
| 181 | +#ifdef TARGET_WORDS_BIGENDIAN | ||
| 182 | + ret = bswap32(ret); | ||
| 183 | +#endif | ||
| 175 | PPC_IO_DPRINTF("0x%08x <= 0x%08x\n", addr - PPC_IO_BASE, ret); | 184 | PPC_IO_DPRINTF("0x%08x <= 0x%08x\n", addr - PPC_IO_BASE, ret); |
| 176 | - | ||
| 177 | return ret; | 185 | return ret; |
| 178 | } | 186 | } |
| 179 | 187 |