2010-05-18 14:35:18 +08:00
|
|
|
/*
|
|
|
|
* UUID/GUID definition
|
|
|
|
*
|
2016-05-20 17:01:07 -07:00
|
|
|
* Copyright (C) 2010, 2016 Intel Corp.
|
2010-05-18 14:35:18 +08:00
|
|
|
* Huang Ying <ying.huang@intel.com>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License version
|
|
|
|
* 2 as published by the Free Software Foundation;
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*/
|
|
|
|
#ifndef _LINUX_UUID_H_
|
|
|
|
#define _LINUX_UUID_H_
|
|
|
|
|
2012-10-13 10:46:48 +01:00
|
|
|
#include <uapi/linux/uuid.h>
|
2018-02-06 15:37:48 -08:00
|
|
|
#include <linux/string.h>
|
2010-05-18 14:35:18 +08:00
|
|
|
|
2017-06-21 12:17:12 -06:00
|
|
|
#define UUID_SIZE 16
|
|
|
|
|
2017-05-17 09:56:45 +02:00
|
|
|
typedef struct {
|
2017-06-21 12:17:12 -06:00
|
|
|
__u8 b[UUID_SIZE];
|
2017-05-17 10:02:48 +02:00
|
|
|
} uuid_t;
|
2017-05-17 09:56:45 +02:00
|
|
|
|
2017-05-17 10:02:48 +02:00
|
|
|
#define UUID_INIT(a, b, c, d0, d1, d2, d3, d4, d5, d6, d7) \
|
|
|
|
((uuid_t) \
|
2017-05-17 09:56:45 +02:00
|
|
|
{{ ((a) >> 24) & 0xff, ((a) >> 16) & 0xff, ((a) >> 8) & 0xff, (a) & 0xff, \
|
|
|
|
((b) >> 8) & 0xff, (b) & 0xff, \
|
|
|
|
((c) >> 8) & 0xff, (c) & 0xff, \
|
|
|
|
(d0), (d1), (d2), (d3), (d4), (d5), (d6), (d7) }})
|
|
|
|
|
2016-05-20 17:01:04 -07:00
|
|
|
/*
|
|
|
|
* The length of a UUID string ("aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee")
|
|
|
|
* not including trailing NUL.
|
|
|
|
*/
|
|
|
|
#define UUID_STRING_LEN 36
|
2012-05-09 16:38:58 +03:00
|
|
|
|
2017-05-11 09:01:42 +02:00
|
|
|
extern const guid_t guid_null;
|
|
|
|
extern const uuid_t uuid_null;
|
|
|
|
|
2017-05-11 14:00:57 +02:00
|
|
|
static inline bool guid_equal(const guid_t *u1, const guid_t *u2)
|
|
|
|
{
|
|
|
|
return memcmp(u1, u2, sizeof(guid_t)) == 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void guid_copy(guid_t *dst, const guid_t *src)
|
|
|
|
{
|
|
|
|
memcpy(dst, src, sizeof(guid_t));
|
|
|
|
}
|
|
|
|
|
2017-06-16 21:13:38 +03:00
|
|
|
static inline bool guid_is_null(const guid_t *guid)
|
2017-05-11 09:01:42 +02:00
|
|
|
{
|
|
|
|
return guid_equal(guid, &guid_null);
|
|
|
|
}
|
|
|
|
|
2017-05-11 14:00:57 +02:00
|
|
|
static inline bool uuid_equal(const uuid_t *u1, const uuid_t *u2)
|
|
|
|
{
|
|
|
|
return memcmp(u1, u2, sizeof(uuid_t)) == 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void uuid_copy(uuid_t *dst, const uuid_t *src)
|
|
|
|
{
|
|
|
|
memcpy(dst, src, sizeof(uuid_t));
|
|
|
|
}
|
|
|
|
|
2017-06-16 21:13:38 +03:00
|
|
|
static inline bool uuid_is_null(const uuid_t *uuid)
|
2017-05-11 09:01:42 +02:00
|
|
|
{
|
|
|
|
return uuid_equal(uuid, &uuid_null);
|
|
|
|
}
|
|
|
|
|
2016-05-20 17:01:00 -07:00
|
|
|
void generate_random_uuid(unsigned char uuid[16]);
|
|
|
|
|
2017-05-17 10:02:48 +02:00
|
|
|
extern void guid_gen(guid_t *u);
|
|
|
|
extern void uuid_gen(uuid_t *u);
|
2010-05-18 14:35:18 +08:00
|
|
|
|
2016-05-20 17:01:04 -07:00
|
|
|
bool __must_check uuid_is_valid(const char *uuid);
|
|
|
|
|
2017-05-17 10:02:48 +02:00
|
|
|
extern const u8 guid_index[16];
|
|
|
|
extern const u8 uuid_index[16];
|
|
|
|
|
|
|
|
int guid_parse(const char *uuid, guid_t *u);
|
|
|
|
int uuid_parse(const char *uuid, uuid_t *u);
|
2016-05-20 17:01:04 -07:00
|
|
|
|
2017-05-17 10:02:48 +02:00
|
|
|
/* backwards compatibility, don't use in new code */
|
|
|
|
#define uuid_le_gen(u) guid_gen(u)
|
|
|
|
#define uuid_le_to_bin(guid, u) guid_parse(guid, u)
|
|
|
|
|
|
|
|
static inline int uuid_le_cmp(const guid_t u1, const guid_t u2)
|
|
|
|
{
|
|
|
|
return memcmp(&u1, &u2, sizeof(guid_t));
|
|
|
|
}
|
|
|
|
|
2010-05-18 14:35:18 +08:00
|
|
|
#endif
|