mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-14 16:36:55 +07:00
297b64c743
The UEFI spec includes non-standard section type support in the Common Platform Error Record. This is defined in section N.2.3 of UEFI version 2.5. Currently if the CPER section's type (UUID) does not match any section type that the kernel knows how to parse, a trace event is not generated. Generate a trace event which contains the raw error data for non-standard section type error records. Signed-off-by: Tyler Baicar <tbaicar@codeaurora.org> CC: Jonathan (Zhixiong) Zhang <zjzhang@codeaurora.org> Tested-by: Shiju Jose <shiju.jose@huawei.com> Signed-off-by: Will Deacon <will.deacon@arm.com>
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(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(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
|