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 | 137 | { |
138 | 138 | PPC_IO_DPRINTF("0x%08x <= 0x%02x\n", addr - PPC_IO_BASE, ret); |
139 | 139 | } |
140 | - | |
141 | 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 | 146 | (addr < 0x80000170 || addr > 0x80000177)) { |
148 | 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 | 152 | cpu_outw(NULL, addr - PPC_IO_BASE, value); |
151 | 153 | } |
152 | 154 | |
153 | 155 | static uint32_t PPC_io_readw (target_phys_addr_t addr) |
154 | 156 | { |
155 | 157 | uint32_t ret = cpu_inw(NULL, addr - PPC_IO_BASE); |
156 | - | |
158 | +#ifdef TARGET_WORDS_BIGENDIAN | |
159 | + ret = bswap16(ret); | |
160 | +#endif | |
157 | 161 | if ((addr < 0x800001f0 || addr > 0x800001f7) && |
158 | 162 | (addr < 0x80000170 || addr > 0x80000177)) { |
159 | 163 | PPC_IO_DPRINTF("0x%08x <= 0x%04x\n", addr - PPC_IO_BASE, ret); |
160 | 164 | } |
161 | - | |
162 | 165 | return ret; |
163 | 166 | } |
164 | 167 | |
165 | 168 | static void PPC_io_writel (target_phys_addr_t addr, uint32_t value) |
166 | 169 | { |
167 | 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 | 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 | 178 | { |
173 | 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 | 184 | PPC_IO_DPRINTF("0x%08x <= 0x%08x\n", addr - PPC_IO_BASE, ret); |
176 | - | |
177 | 185 | return ret; |
178 | 186 | } |
179 | 187 | ... | ... |