1
0
Fork 0
mirror of https://github.com/Ysurac/openmptcprouter.git synced 2025-03-09 15:40:20 +00:00
openmptcprouter/6.12/target/linux/bcm27xx/patches-6.12/950-0135-arch-arm64-Add-Revision-Serial-Model-to-cpuinfo.patch
Ycarus (Yannick Chabanois) bdb9b0046f Add bcm27xx 6.12 test support
2024-12-20 14:17:26 +01:00

57 lines
1.6 KiB
Diff

From 3152340c00fd70b0dcf89a18724fd2fc1698430e Mon Sep 17 00:00:00 2001
From: Phil Elwell <phil@raspberrypi.org>
Date: Tue, 3 Sep 2019 18:17:25 +0100
Subject: [PATCH 135/697] arch/arm64: Add Revision, Serial, Model to cpuinfo
Signed-off-by: Phil Elwell <phil@raspberrypi.org>
---
arch/arm64/kernel/cpuinfo.c | 24 ++++++++++++++++++++++++
1 file changed, 24 insertions(+)
--- a/arch/arm64/kernel/cpuinfo.c
+++ b/arch/arm64/kernel/cpuinfo.c
@@ -17,6 +17,8 @@
#include <linux/elf.h>
#include <linux/init.h>
#include <linux/kernel.h>
+#include <linux/of.h>
+#include <linux/of_platform.h>
#include <linux/personality.h>
#include <linux/preempt.h>
#include <linux/printk.h>
@@ -195,6 +197,10 @@ static int c_show(struct seq_file *m, vo
{
int i, j;
bool compat = personality(current->personality) == PER_LINUX32;
+ struct device_node *np;
+ const char *model;
+ const char *serial;
+ u32 revision;
for_each_online_cpu(i) {
struct cpuinfo_arm64 *cpuinfo = &per_cpu(cpu_data, i);
@@ -255,6 +261,24 @@ static int c_show(struct seq_file *m, vo
seq_printf(m, "CPU revision\t: %d\n\n", MIDR_REVISION(midr));
}
+ np = of_find_node_by_path("/system");
+ if (np) {
+ if (!of_property_read_u32(np, "linux,revision", &revision))
+ seq_printf(m, "Revision\t: %04x\n", revision);
+ of_node_put(np);
+ }
+
+ np = of_find_node_by_path("/");
+ if (np) {
+ if (!of_property_read_string(np, "serial-number",
+ &serial))
+ seq_printf(m, "Serial\t\t: %s\n", serial);
+ if (!of_property_read_string(np, "model",
+ &model))
+ seq_printf(m, "Model\t\t: %s\n", model);
+ of_node_put(np);
+ }
+
return 0;
}