aboutsummaryrefslogtreecommitdiff
path: root/hw/mips/fw_cfg.c
diff options
context:
space:
mode:
authorHuacai Chen <chenhuacai@kernel.org>2020-09-22 10:49:25 +0800
committerPhilippe Mathieu-Daudé <f4bug@amsat.org>2021-01-04 23:32:27 +0100
commit313d1e910ac0eb12bbfe83f158cab60f600319f1 (patch)
treeabeba77112981d44dd11afe2372db80502d7f63a /hw/mips/fw_cfg.c
parentdea96332327f2651f726244cc5bb41c4f9350f8b (diff)
downloadqemu-313d1e910ac0eb12bbfe83f158cab60f600319f1.zip
qemu-313d1e910ac0eb12bbfe83f158cab60f600319f1.tar.gz
qemu-313d1e910ac0eb12bbfe83f158cab60f600319f1.tar.bz2
hw/mips: Implement fw_cfg_arch_key_name()
Implement fw_cfg_arch_key_name(), which returns the name of a mips-specific key. Co-developed-by: Jiaxun Yang <jiaxun.yang@flygoat.com> Signed-off-by: Huacai Chen <chenhuacai@kernel.org> Signed-off-by: Jiaxun Yang <jiaxun.yang@flygoat.com> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Message-Id: <1600742967-12933-7-git-send-email-chenhc@lemote.com> [PMD: Add FW_CFG_MIPS Kconfig selector] Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Diffstat (limited to 'hw/mips/fw_cfg.c')
-rw-r--r--hw/mips/fw_cfg.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/hw/mips/fw_cfg.c b/hw/mips/fw_cfg.c
new file mode 100644
index 0000000..67c4a74
--- /dev/null
+++ b/hw/mips/fw_cfg.c
@@ -0,0 +1,35 @@
+/*
+ * QEMU fw_cfg helpers (MIPS specific)
+ *
+ * Copyright (c) 2020 Lemote, Inc.
+ *
+ * Author:
+ * Huacai Chen (chenhc@lemote.com)
+ *
+ * SPDX-License-Identifier: GPL-2.0-or-later
+ *
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
+ * See the COPYING file in the top-level directory.
+ */
+
+#include "qemu/osdep.h"
+#include "hw/mips/fw_cfg.h"
+#include "hw/nvram/fw_cfg.h"
+
+const char *fw_cfg_arch_key_name(uint16_t key)
+{
+ static const struct {
+ uint16_t key;
+ const char *name;
+ } fw_cfg_arch_wellknown_keys[] = {
+ {FW_CFG_MACHINE_VERSION, "machine_version"},
+ {FW_CFG_CPU_FREQ, "cpu_frequency"},
+ };
+
+ for (size_t i = 0; i < ARRAY_SIZE(fw_cfg_arch_wellknown_keys); i++) {
+ if (fw_cfg_arch_wellknown_keys[i].key == key) {
+ return fw_cfg_arch_wellknown_keys[i].name;
+ }
+ }
+ return NULL;
+}