1 // SPDX-License-Identifier: GPL-2.0-or-later
4 * arch/xtensa/platform-iss/setup.c
6 * Platform specific initialization.
8 * Authors: Chris Zankel <chris@zankel.net>
9 * Joe Taylor <joe@tensilica.com>
11 * Copyright 2001 - 2005 Tensilica Inc.
12 * Copyright 2017 Cadence Design Systems Inc.
14 #include <linux/init.h>
15 #include <linux/kernel.h>
16 #include <linux/notifier.h>
17 #include <linux/printk.h>
18 #include <linux/string.h>
20 #include <asm/platform.h>
21 #include <asm/setup.h>
23 #include <platform/simcall.h>
26 void platform_halt(void)
28 pr_info(" ** Called platform_halt() **\n");
32 void platform_power_off(void)
34 pr_info(" ** Called platform_power_off() **\n");
38 void platform_restart(void)
40 /* Flush and reset the mmu, simulate a processor reset, and
41 * jump to the reset vector. */
43 /* control never gets here */
47 iss_panic_event(struct notifier_block
*this, unsigned long event
, void *ptr
)
53 static struct notifier_block iss_panic_block
= {
54 .notifier_call
= iss_panic_event
,
57 void __init
platform_setup(char **p_cmdline
)
59 static void *argv
[COMMAND_LINE_SIZE
/ sizeof(void *)] __initdata
;
60 static char cmdline
[COMMAND_LINE_SIZE
] __initdata
;
61 int argc
= simc_argc();
62 int argv_size
= simc_argv_size();
65 if (argv_size
> sizeof(argv
)) {
66 pr_err("%s: command line too long: argv_size = %d\n",
72 simc_argv((void *)argv
);
74 for (i
= 1; i
< argc
; ++i
) {
77 strcat(cmdline
, argv
[i
]);
83 atomic_notifier_chain_register(&panic_notifier_list
, &iss_panic_block
);