mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-11 15:40:50 +00:00
55a7b2125c
- RAS reporting via GHES/APEI (ACPI) - Indirect ftrace trampolines for modules - Improvements to kernel fault reporting - Page poisoning - Sigframe cleanups and preparation for SVE context - Core dump fixes - Sparse fixes (mainly relating to endianness) - xgene SoC PMU v3 driver - Misc cleanups and non-critical fixes -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQEcBAABCgAGBQJZWiuVAAoJELescNyEwWM0g/gIAIRpVEzjE61zfm/KCsVuIu4O p6F/HrvF/ApvlFcth8LDpTDYUholzT1e9wmx/O0Ll37UvFUrReT03R5MMJ02WU8s hRg0N4izdg2BPa9zuaP/XE5i6WmFfRAwFsv6PzX77FjNGk0M4zhW8acNpWHYMBQT DwXT/xCvg6045Sj6CuwfcIqqVHrz6/kpBmvdbW7G3/WpIHpUGIWM9EO3mkuLGMj0 j0VSCxfAVJvWwmKEBdFExLNjqxvSlVAMOIEAw7yBNLjuheiL+afK+Y1BggB00oe8 14+6viOgW6L97VmPpYVn0YDseqeGg5DqlNF3NqjTqdmzWH/ApAvL4WXN7SL2jbU= =RNzb -----END PGP SIGNATURE----- Merge tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux Pull arm64 updates from Will Deacon: - RAS reporting via GHES/APEI (ACPI) - Indirect ftrace trampolines for modules - Improvements to kernel fault reporting - Page poisoning - Sigframe cleanups and preparation for SVE context - Core dump fixes - Sparse fixes (mainly relating to endianness) - xgene SoC PMU v3 driver - Misc cleanups and non-critical fixes * tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux: (75 commits) arm64: fix endianness annotation for 'struct jit_ctx' and friends arm64: cpuinfo: constify attribute_group structures. arm64: ptrace: Fix incorrect get_user() use in compat_vfp_set() arm64: ptrace: Remove redundant overrun check from compat_vfp_set() arm64: ptrace: Avoid setting compat FP[SC]R to garbage if get_user fails arm64: fix endianness annotation for __apply_alternatives()/get_alt_insn() arm64: fix endianness annotation in get_kaslr_seed() arm64: add missing conversion to __wsum in ip_fast_csum() arm64: fix endianness annotation in acpi_parking_protocol.c arm64: use readq() instead of readl() to read 64bit entry_point arm64: fix endianness annotation for reloc_insn_movw() & reloc_insn_imm() arm64: fix endianness annotation for aarch64_insn_write() arm64: fix endianness annotation in aarch64_insn_read() arm64: fix endianness annotation in call_undef_hook() arm64: fix endianness annotation for debug-monitors.c ras: mark stub functions as 'inline' arm64: pass endianness info to sparse arm64: ftrace: fix !CONFIG_ARM64_MODULE_PLTS kernels arm64: signal: Allow expansion of the signal frame acpi: apei: check for pending errors when probing GHES entries ...
110 lines
2.8 KiB
C
110 lines
2.8 KiB
C
/*
|
|
* UUID/GUID definition
|
|
*
|
|
* Copyright (C) 2010, 2016 Intel Corp.
|
|
* 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_
|
|
|
|
#include <uapi/linux/uuid.h>
|
|
|
|
#define UUID_SIZE 16
|
|
|
|
typedef struct {
|
|
__u8 b[UUID_SIZE];
|
|
} uuid_t;
|
|
|
|
#define UUID_INIT(a, b, c, d0, d1, d2, d3, d4, d5, d6, d7) \
|
|
((uuid_t) \
|
|
{{ ((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) }})
|
|
|
|
/*
|
|
* The length of a UUID string ("aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee")
|
|
* not including trailing NUL.
|
|
*/
|
|
#define UUID_STRING_LEN 36
|
|
|
|
extern const guid_t guid_null;
|
|
extern const uuid_t uuid_null;
|
|
|
|
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));
|
|
}
|
|
|
|
static inline bool guid_is_null(const guid_t *guid)
|
|
{
|
|
return guid_equal(guid, &guid_null);
|
|
}
|
|
|
|
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));
|
|
}
|
|
|
|
static inline bool uuid_is_null(const uuid_t *uuid)
|
|
{
|
|
return uuid_equal(uuid, &uuid_null);
|
|
}
|
|
|
|
void generate_random_uuid(unsigned char uuid[16]);
|
|
|
|
extern void guid_gen(guid_t *u);
|
|
extern void uuid_gen(uuid_t *u);
|
|
|
|
bool __must_check uuid_is_valid(const char *uuid);
|
|
|
|
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);
|
|
|
|
/* backwards compatibility, don't use in new code */
|
|
typedef uuid_t uuid_be;
|
|
#define UUID_BE(a, _b, c, d0, d1, d2, d3, d4, d5, d6, d7) \
|
|
UUID_INIT(a, _b, c, d0, d1, d2, d3, d4, d5, d6, d7)
|
|
#define NULL_UUID_BE \
|
|
UUID_BE(0x00000000, 0x0000, 0x0000, 0x00, 0x00, 0x00, 0x00, \
|
|
0x00, 0x00, 0x00, 0x00)
|
|
|
|
#define uuid_le_gen(u) guid_gen(u)
|
|
#define uuid_be_gen(u) uuid_gen(u)
|
|
#define uuid_le_to_bin(guid, u) guid_parse(guid, u)
|
|
#define uuid_be_to_bin(uuid, u) uuid_parse(uuid, u)
|
|
|
|
static inline int uuid_le_cmp(const guid_t u1, const guid_t u2)
|
|
{
|
|
return memcmp(&u1, &u2, sizeof(guid_t));
|
|
}
|
|
|
|
static inline int uuid_be_cmp(const uuid_t u1, const uuid_t u2)
|
|
{
|
|
return memcmp(&u1, &u2, sizeof(uuid_t));
|
|
}
|
|
|
|
#endif
|