Skip to content

Commit

Permalink
mei: fix up uuid matching
Browse files Browse the repository at this point in the history
A previous commit, c93b76b ("mei: bus: report also uuid in module
alias") caused a build error as I missed applying a needed patch to add
some macros to uapi/linux/uuid.h.  Instead of those additional macros,
change the mei code to use the existing uuid structure directly.

Fixes: c93b76b
Cc: Tomas Winkler <[email protected]>
Cc: Samuel Ortiz <[email protected]>
Reported-by: Stephen Rothwell <[email protected]>
Signed-off-by: Greg Kroah-Hartman <[email protected]>
  • Loading branch information
gregkh committed May 31, 2015
1 parent 039ae58 commit b144ce2
Show file tree
Hide file tree
Showing 4 changed files with 9 additions and 11 deletions.
9 changes: 2 additions & 7 deletions drivers/misc/mei/bus.c
Original file line number Diff line number Diff line change
Expand Up @@ -30,11 +30,6 @@
#define to_mei_cl_driver(d) container_of(d, struct mei_cl_driver, driver)
#define to_mei_cl_device(d) container_of(d, struct mei_cl_device, dev)

static inline uuid_le uuid_le_cast(const __u8 uuid[16])
{
return *(uuid_le *)uuid;
}

static int mei_cl_device_match(struct device *dev, struct device_driver *drv)
{
struct mei_cl_device *device = to_mei_cl_device(dev);
Expand All @@ -54,9 +49,9 @@ static int mei_cl_device_match(struct device *dev, struct device_driver *drv)

id = driver->id_table;

while (uuid_le_cmp(NULL_UUID_LE, uuid_le_cast(id->uuid))) {
while (uuid_le_cmp(NULL_UUID_LE, id->uuid)) {

if (!uuid_le_cmp(*uuid, uuid_le_cast(id->uuid))) {
if (!uuid_le_cmp(*uuid, id->uuid)) {
if (id->name[0]) {
if (!strncmp(name, id->name, sizeof(id->name)))
return 1;
Expand Down
2 changes: 1 addition & 1 deletion drivers/nfc/mei_phy.h
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
#include <net/nfc/hci.h>
#include <linux/uuid.h>

#define MEI_NFC_UUID __UUID_LE(0x0bb17a78, 0x2a8e, 0x4c50, \
#define MEI_NFC_UUID UUID_LE(0x0bb17a78, 0x2a8e, 0x4c50, \
0x94, 0xd4, 0x50, 0x26, 0x67, 0x23, 0x77, 0x5c)
#define MEI_NFC_HEADER_SIZE 10
#define MEI_NFC_MAX_HCI_PAYLOAD 300
Expand Down
2 changes: 1 addition & 1 deletion include/linux/mod_devicetable.h
Original file line number Diff line number Diff line change
Expand Up @@ -614,7 +614,7 @@ struct ipack_device_id {
*/
struct mei_cl_device_id {
char name[MEI_CL_NAME_SIZE];
__u8 uuid[16];
uuid_le uuid;
kernel_ulong_t driver_info;
};

Expand Down
7 changes: 5 additions & 2 deletions scripts/mod/file2alias.c
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,9 @@ typedef Elf64_Addr kernel_ulong_t;
typedef uint32_t __u32;
typedef uint16_t __u16;
typedef unsigned char __u8;
typedef struct {
__u8 b[16];
} uuid_le;

/* Big exception to the "don't include kernel headers into userspace, which
* even potentially has different endianness and word sizes, since
Expand Down Expand Up @@ -131,13 +134,13 @@ static inline void add_wildcard(char *str)
strcat(str + len, "*");
}

static inline void add_uuid(char *str, __u8 uuid[16])
static inline void add_uuid(char *str, uuid_le uuid)
{
int len = strlen(str);
int i;

for (i = 0; i < 16; i++)
sprintf(str + len + (i << 1), "%02x", uuid[i]);
sprintf(str + len + (i << 1), "%02x", uuid.b[i]);
}

/**
Expand Down

0 comments on commit b144ce2

Please sign in to comment.