Skip to content

Commit 9607871

Browse files
dhowellsdjbw
authored andcommitted
UAPI: ndctl: Fix g++-unsupported initialisation in headers
The following code in the linux/ndctl header file: static inline const char *nvdimm_bus_cmd_name(unsigned cmd) { static const char * const names[] = { [ND_CMD_ARS_CAP] = "ars_cap", [ND_CMD_ARS_START] = "ars_start", [ND_CMD_ARS_STATUS] = "ars_status", [ND_CMD_CLEAR_ERROR] = "clear_error", [ND_CMD_CALL] = "cmd_call", }; if (cmd < ARRAY_SIZE(names) && names[cmd]) return names[cmd]; return "unknown"; } is broken in a number of ways: (1) ARRAY_SIZE() is not generally defined. (2) g++ does not support "non-trivial" array initialisers fully yet. (3) Every file that calls this function will acquire a copy of names[]. The same goes for nvdimm_cmd_name(). Fix all three by converting to a switch statement where each case returns a string. That way if cmd is a constant, the compiler can trivially reduce it and, if not, the compiler can use a shared lookup table if it thinks that is more efficient. A better way would be to remove these functions and their arrays from the header entirely. Signed-off-by: David Howells <[email protected]> Signed-off-by: Dan Williams <[email protected]>
1 parent f110176 commit 9607871

File tree

1 file changed

+21
-27
lines changed

1 file changed

+21
-27
lines changed

include/uapi/linux/ndctl.h

Lines changed: 21 additions & 27 deletions
Original file line numberDiff line numberDiff line change
@@ -128,37 +128,31 @@ enum {
128128

129129
static inline const char *nvdimm_bus_cmd_name(unsigned cmd)
130130
{
131-
static const char * const names[] = {
132-
[ND_CMD_ARS_CAP] = "ars_cap",
133-
[ND_CMD_ARS_START] = "ars_start",
134-
[ND_CMD_ARS_STATUS] = "ars_status",
135-
[ND_CMD_CLEAR_ERROR] = "clear_error",
136-
[ND_CMD_CALL] = "cmd_call",
137-
};
138-
139-
if (cmd < ARRAY_SIZE(names) && names[cmd])
140-
return names[cmd];
141-
return "unknown";
131+
switch (cmd) {
132+
case ND_CMD_ARS_CAP: return "ars_cap";
133+
case ND_CMD_ARS_START: return "ars_start";
134+
case ND_CMD_ARS_STATUS: return "ars_status";
135+
case ND_CMD_CLEAR_ERROR: return "clear_error";
136+
case ND_CMD_CALL: return "cmd_call";
137+
default: return "unknown";
138+
}
142139
}
143140

144141
static inline const char *nvdimm_cmd_name(unsigned cmd)
145142
{
146-
static const char * const names[] = {
147-
[ND_CMD_SMART] = "smart",
148-
[ND_CMD_SMART_THRESHOLD] = "smart_thresh",
149-
[ND_CMD_DIMM_FLAGS] = "flags",
150-
[ND_CMD_GET_CONFIG_SIZE] = "get_size",
151-
[ND_CMD_GET_CONFIG_DATA] = "get_data",
152-
[ND_CMD_SET_CONFIG_DATA] = "set_data",
153-
[ND_CMD_VENDOR_EFFECT_LOG_SIZE] = "effect_size",
154-
[ND_CMD_VENDOR_EFFECT_LOG] = "effect_log",
155-
[ND_CMD_VENDOR] = "vendor",
156-
[ND_CMD_CALL] = "cmd_call",
157-
};
158-
159-
if (cmd < ARRAY_SIZE(names) && names[cmd])
160-
return names[cmd];
161-
return "unknown";
143+
switch (cmd) {
144+
case ND_CMD_SMART: return "smart";
145+
case ND_CMD_SMART_THRESHOLD: return "smart_thresh";
146+
case ND_CMD_DIMM_FLAGS: return "flags";
147+
case ND_CMD_GET_CONFIG_SIZE: return "get_size";
148+
case ND_CMD_GET_CONFIG_DATA: return "get_data";
149+
case ND_CMD_SET_CONFIG_DATA: return "set_data";
150+
case ND_CMD_VENDOR_EFFECT_LOG_SIZE: return "effect_size";
151+
case ND_CMD_VENDOR_EFFECT_LOG: return "effect_log";
152+
case ND_CMD_VENDOR: return "vendor";
153+
case ND_CMD_CALL: return "cmd_call";
154+
default: return "unknown";
155+
}
162156
}
163157

164158
#define ND_IOCTL 'N'

0 commit comments

Comments
 (0)