qemu-arm
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH 4/5] target/arm: Support more GM blocksizes


From: Richard Henderson
Subject: Re: [PATCH 4/5] target/arm: Support more GM blocksizes
Date: Thu, 10 Aug 2023 12:10:57 -0700
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0

On 8/10/23 07:23, Peter Maydell wrote:
+    case 4:
+        /* 64 bytes -> 4 tags -> 16 result bits */
+        ret = cpu_to_le16(*(uint16_t *)tag_mem);

Does this really make a difference compared to ldw_le_p() ?

ldw_le_p uses memcpy, though only mips and sparc hosts do not have unaligned reads, so perhaps it doesn't make much difference.

I had originally been thinking about atomicity, but then noticed that the pseudocode uses a loop and so the instruction is therefore non-atomic.


Is it worth having an assert in CPU realize for an invalid
blocksize, so that we can catch duff ID register values
without having to rely on there being a test run that
uses ldgm/stgm ?

Yes, that's a good idea.


r~



reply via email to

[Prev in Thread] Current Thread [Next in Thread]