Commit 4934fbfb authored by Helge Deller's avatar Helge Deller

parisc: Show MPE/iX model string at bootup

Some (mostly 64-bit machines) machines allow to run MPE/iX and report the MPE
model string via firmware call. Enhance the pdc_model_sysmodel() function to
report that model string.
Note that some 32-bit machines like the B160L wrongly report success for the
firmware call, so include a check to prevent showing wrong info.
Signed-off-by: default avatarHelge Deller <deller@gmx.de>
parent 9086e601
...@@ -37,7 +37,7 @@ int pdc_system_map_find_mods(struct pdc_system_map_mod_info *pdc_mod_info, ...@@ -37,7 +37,7 @@ int pdc_system_map_find_mods(struct pdc_system_map_mod_info *pdc_mod_info,
int pdc_system_map_find_addrs(struct pdc_system_map_addr_info *pdc_addr_info, int pdc_system_map_find_addrs(struct pdc_system_map_addr_info *pdc_addr_info,
long mod_index, long addr_index); long mod_index, long addr_index);
int pdc_model_info(struct pdc_model *model); int pdc_model_info(struct pdc_model *model);
int pdc_model_sysmodel(char *name); int pdc_model_sysmodel(unsigned int os_id, char *name);
int pdc_model_cpuid(unsigned long *cpu_id); int pdc_model_cpuid(unsigned long *cpu_id);
int pdc_model_versions(unsigned long *versions, int id); int pdc_model_versions(unsigned long *versions, int id);
int pdc_model_capabilities(unsigned long *capabilities); int pdc_model_capabilities(unsigned long *capabilities);
......
...@@ -527,14 +527,14 @@ int pdc_model_info(struct pdc_model *model) ...@@ -527,14 +527,14 @@ int pdc_model_info(struct pdc_model *model)
* Using OS_ID_HPUX will return the equivalent of the 'modelname' command * Using OS_ID_HPUX will return the equivalent of the 'modelname' command
* on HP/UX. * on HP/UX.
*/ */
int pdc_model_sysmodel(char *name) int pdc_model_sysmodel(unsigned int os_id, char *name)
{ {
int retval; int retval;
unsigned long flags; unsigned long flags;
spin_lock_irqsave(&pdc_lock, flags); spin_lock_irqsave(&pdc_lock, flags);
retval = mem_pdc_call(PDC_MODEL, PDC_MODEL_SYSMODEL, __pa(pdc_result), retval = mem_pdc_call(PDC_MODEL, PDC_MODEL_SYSMODEL, __pa(pdc_result),
OS_ID_HPUX, __pa(name)); os_id, __pa(name));
convert_to_wide(pdc_result); convert_to_wide(pdc_result);
if (retval == PDC_OK) { if (retval == PDC_OK) {
......
...@@ -272,10 +272,15 @@ void __init collect_boot_cpu_data(void) ...@@ -272,10 +272,15 @@ void __init collect_boot_cpu_data(void)
printk(KERN_INFO "capabilities 0x%lx\n", printk(KERN_INFO "capabilities 0x%lx\n",
boot_cpu_data.pdc.capabilities); boot_cpu_data.pdc.capabilities);
if (pdc_model_sysmodel(boot_cpu_data.pdc.sys_model_name) == PDC_OK) if (pdc_model_sysmodel(OS_ID_HPUX, boot_cpu_data.pdc.sys_model_name) == PDC_OK)
printk(KERN_INFO "model %s\n", pr_info("HP-UX model name: %s\n",
boot_cpu_data.pdc.sys_model_name); boot_cpu_data.pdc.sys_model_name);
serial_no[0] = 0;
if (pdc_model_sysmodel(OS_ID_MPEXL, serial_no) == PDC_OK &&
serial_no[0])
pr_info("MPE/iX model name: %s\n", serial_no);
dump_stack_set_arch_desc("%s", boot_cpu_data.pdc.sys_model_name); dump_stack_set_arch_desc("%s", boot_cpu_data.pdc.sys_model_name);
boot_cpu_data.hversion = boot_cpu_data.pdc.model.hversion; boot_cpu_data.hversion = boot_cpu_data.pdc.model.hversion;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment