Re: [PATCH 1/2] afs: Move UUID struct to linux/uuid.h
From: David Howells
Date: Thu Jan 12 2017 - 09:20:10 EST
Arnd Bergmann <arnd@xxxxxxxx> wrote:
> Looks good to me, but I wonder if this part:
>
> r = call->request;
> - r->time_low = ntohl(b[0]);
> - r->time_mid = ntohl(b[1]);
> - r->time_hi_and_version = ntohl(b[2]);
> + r->time_low = b[0];
> + r->time_mid = htons(ntohl(b[1]));
> + r->time_hi_and_version = htons(ntohl(b[2]));
> r->clock_seq_hi_and_reserved = ntohl(b[3]);
> r->clock_seq_low = ntohl(b[4]);
>
> should be considered a bugfix and split out into a
> separate patch.
I changed the definitions in the struct from u16/u32 to __be16/__be32 so it's
not a bugfix.
For some reason, rather than specifying UUIDs as just a 16-octet field, the
AFS protocol breaks the UUID down into pieces and converts them into 32-bit
fields (apparently signed in some places:-/).
> From what I understand about the mess in UUID formats, the time fields can
> either be big-endian (as defined) or little-endian (for all things
> Microsoft),
RFC 4122 specified that the multi-octet fields are stored MSB-first.
> and you are changing the representation from CPU-specific to big-endian,
> which makes it different for x86 and most ARM at least.
In-kernel, not in the protocol.
The problem is that you can't do what you put in your suggested patch and just
copy the UUID produced by the generate_random_uuid() over the afs_uuid struct
since that puts the version in the wrong place.
David