diff options
author | malc <malc@c046a42c-6fe2-441c-8c8c-71466251a162> | 2008-08-20 22:39:26 +0000 |
---|---|---|
committer | malc <malc@c046a42c-6fe2-441c-8c8c-71466251a162> | 2008-08-20 22:39:26 +0000 |
commit | d538e8f50d89a66ae14a2cf351d2e0e5365d463b (patch) | |
tree | 45714a5cdac1bde22994015f2e8c2ea2eba16b3f | |
parent | dc28c732ac3aa36f6001ef7c7a64df79e1ebb043 (diff) |
Fix tswap size
p in this case is uint32_t *
e1/e2 are unsigned ints initialized from arithmetics performed on
unsigned longs
The mistake was, probably, never noticed due to the absence of any
big endian linux-user host. The types e1/e2 and p begs the quesiton
why this function takes longs at all.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@5036 c046a42c-6fe2-441c-8c8c-71466251a162
-rw-r--r-- | linux-user/main.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/linux-user/main.c b/linux-user/main.c index 11e9be84b2..bc8c1e6fe1 100644 --- a/linux-user/main.c +++ b/linux-user/main.c @@ -278,8 +278,8 @@ static void write_dt(void *ptr, unsigned long addr, unsigned long limit, e2 = ((addr >> 16) & 0xff) | (addr & 0xff000000) | (limit & 0x000f0000); e2 |= flags; p = ptr; - p[0] = tswapl(e1); - p[1] = tswapl(e2); + p[0] = tswap32(e1); + p[1] = tswap32(e2); } #if TARGET_X86_64 |