]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
parisc: Show machine product number during boot
authorHelge Deller <deller@gmx.de>
Fri, 8 Feb 2019 17:28:13 +0000 (18:28 +0100)
committerHelge Deller <deller@gmx.de>
Thu, 21 Feb 2019 19:37:13 +0000 (20:37 +0100)
Ask PDC firmware during boot for the original and current product
number as well as the serial number and show it (if available).

Signed-off-by: Helge Deller <deller@gmx.de>
arch/parisc/include/asm/pdc.h
arch/parisc/kernel/firmware.c
arch/parisc/kernel/processor.c

index 5b187d40d6043068f9de5bb356b4c51b99859a3a..19bb2e46cd36cb942e275cc660f63d34fc1f0e09 100644 (file)
@@ -44,6 +44,7 @@ int pdc_model_sysmodel(char *name);
 int pdc_model_cpuid(unsigned long *cpu_id);
 int pdc_model_versions(unsigned long *versions, int id);
 int pdc_model_capabilities(unsigned long *capabilities);
+int pdc_model_platform_info(char *orig_prod_num, char *current_prod_num, char *serial_no);
 int pdc_cache_info(struct pdc_cache_info *cache);
 int pdc_spaceid_bits(unsigned long *space_bits);
 #ifndef CONFIG_PA20
index e6f3b49f2fd7000b48ff20a692981d34993ef55a..7a17551ea31e3f887dd79462c72cd46dea8ef539 100644 (file)
@@ -568,6 +568,30 @@ int pdc_model_capabilities(unsigned long *capabilities)
         return retval;
 }
 
+/**
+ * pdc_model_platform_info - Returns machine product and serial number.
+ * @orig_prod_num: Return buffer for original product number.
+ * @current_prod_num: Return buffer for current product number.
+ * @serial_no: Return buffer for serial number.
+ *
+ * Returns strings containing the original and current product numbers and the
+ * serial number of the system.
+ */
+int pdc_model_platform_info(char *orig_prod_num, char *current_prod_num,
+               char *serial_no)
+{
+       int retval;
+       unsigned long flags;
+
+       spin_lock_irqsave(&pdc_lock, flags);
+       retval = mem_pdc_call(PDC_MODEL, PDC_MODEL_GET_PLATFORM_INFO,
+               __pa(orig_prod_num), __pa(current_prod_num), __pa(serial_no));
+       convert_to_wide(pdc_result);
+       spin_unlock_irqrestore(&pdc_lock, flags);
+
+       return retval;
+}
+
 /**
  * pdc_cache_info - Return cache and TLB information.
  * @cache_info: The return buffer.
index 82bd0d0927ce30338cc0c5b9adf3e85c5d28795c..7f4d042856b5da8ede1104b4aa932d55bdc053fd 100644 (file)
@@ -242,6 +242,7 @@ static int __init processor_probe(struct parisc_device *dev)
 void __init collect_boot_cpu_data(void)
 {
        unsigned long cr16_seed;
+       char orig_prod_num[64], current_prod_num[64], serial_no[64];
 
        memset(&boot_cpu_data, 0, sizeof(boot_cpu_data));
 
@@ -301,6 +302,14 @@ void __init collect_boot_cpu_data(void)
        _parisc_requires_coherency = (boot_cpu_data.cpu_type == mako) ||
                                (boot_cpu_data.cpu_type == mako2);
 #endif
+
+       if (pdc_model_platform_info(orig_prod_num, current_prod_num, serial_no) == PDC_OK) {
+               printk(KERN_INFO "product %s, original product %s, S/N: %s\n",
+                       current_prod_num, orig_prod_num, serial_no);
+               add_device_randomness(orig_prod_num, strlen(orig_prod_num));
+               add_device_randomness(current_prod_num, strlen(current_prod_num));
+               add_device_randomness(serial_no, strlen(serial_no));
+       }
 }