[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH for-4.14 1/3] xen/arm: atomic: Allow read_atomic() to be used in more cases
On Thu, 7 May 2020, Julien Grall wrote: > Hi, > > On 07/05/2020 21:29, Stefano Stabellini wrote: > > > #define read_atomic(p) ({ > > > \ > > > - typeof(*p) __x; \ > > > - switch ( sizeof(*p) ) { \ > > > - case 1: __x = (typeof(*p))read_u8_atomic((uint8_t *)p); break; \ > > > - case 2: __x = (typeof(*p))read_u16_atomic((uint16_t *)p); break; \ > > > - case 4: __x = (typeof(*p))read_u32_atomic((uint32_t *)p); break; \ > > > - case 8: __x = (typeof(*p))read_u64_atomic((uint64_t *)p); break; \ > > > - default: __x = 0; __bad_atomic_size(); break; \ > > > - } \ > > > - __x; \ > > > + union { typeof(*p) val; char c[0]; } x_; \ > > > + read_atomic_size(p, x_.c, sizeof(*p)); \ > > > > Wouldn't it be better to pass x_ as follows: > > > > read_atomic_size(p, &x_, sizeof(*p)); > > I am not sure to understand this. Are you suggesting to pass a pointer to the > union? Yes. Would it cause a problem that I couldn't spot?
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |