Skip to content

Commit

Permalink
Merge branch 'xtensa-sim-params' into xtensa-fixes
Browse files Browse the repository at this point in the history
  • Loading branch information
Max Filippov committed May 7, 2017
2 parents 062b1c1 + fbe22d2 commit 2a4e669
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 23 deletions.
5 changes: 2 additions & 3 deletions arch/xtensa/kernel/setup.c
Original file line number Diff line number Diff line change
Expand Up @@ -317,8 +317,9 @@ static inline int mem_reserve(unsigned long start, unsigned long end)

void __init setup_arch(char **cmdline_p)
{
strlcpy(boot_command_line, command_line, COMMAND_LINE_SIZE);
*cmdline_p = command_line;
platform_setup(cmdline_p);
strlcpy(boot_command_line, *cmdline_p, COMMAND_LINE_SIZE);

/* Reserve some memory regions */

Expand Down Expand Up @@ -382,8 +383,6 @@ void __init setup_arch(char **cmdline_p)

unflatten_and_copy_device_tree();

platform_setup(cmdline_p);

#ifdef CONFIG_SMP
smp_init_cpus();
#endif
Expand Down
20 changes: 20 additions & 0 deletions arch/xtensa/platforms/iss/include/platform/simcall.h
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
* for more details.
*
* Copyright (C) 2001 Tensilica Inc.
* Copyright (C) 2017 Cadence Design Systems Inc.
*/

#ifndef _XTENSA_PLATFORM_ISS_SIMCALL_H
Expand Down Expand Up @@ -49,6 +50,10 @@
#define SYS_bind 30
#define SYS_ioctl 31

#define SYS_iss_argc 1000 /* returns value of argc */
#define SYS_iss_argv_size 1001 /* bytes needed for argv & arg strings */
#define SYS_iss_set_argv 1002 /* saves argv & arg strings at given addr */

/*
* SYS_select_one specifiers
*/
Expand Down Expand Up @@ -118,5 +123,20 @@ static inline int simc_lseek(int fd, uint32_t off, int whence)
return __simc(SYS_lseek, fd, off, whence);
}

static inline int simc_argc(void)
{
return __simc(SYS_iss_argc, 0, 0, 0);
}

static inline int simc_argv_size(void)
{
return __simc(SYS_iss_argv_size, 0, 0, 0);
}

static inline void simc_argv(void *buf)
{
__simc(SYS_iss_set_argv, (int)buf, 0, 0);
}

#endif /* _XTENSA_PLATFORM_ISS_SIMCALL_H */

43 changes: 23 additions & 20 deletions arch/xtensa/platforms/iss/setup.c
Original file line number Diff line number Diff line change
Expand Up @@ -8,13 +8,15 @@
* Joe Taylor <joe@tensilica.com>
*
* Copyright 2001 - 2005 Tensilica Inc.
* Copyright 2017 Cadence Design Systems Inc.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2 of the License, or (at your
* option) any later version.
*
*/
#include <linux/bootmem.h>
#include <linux/stddef.h>
#include <linux/kernel.h>
#include <linux/init.h>
Expand All @@ -31,13 +33,13 @@

#include <asm/platform.h>
#include <asm/bootparam.h>
#include <asm/setup.h>

#include <platform/simcall.h>


void __init platform_init(bp_tag_t* bootparam)
{

}

void platform_halt(void)
Expand All @@ -59,26 +61,10 @@ void platform_restart(void)
/* control never gets here */
}

extern void iss_net_poll(void);

const char twirl[]="|/-\\|/-\\";

void platform_heartbeat(void)
{
#if 0
static int i = 0, j = 0;

if (--i < 0) {
i = 99;
printk("\r%c\r", twirl[j++]);
if (j == 8)
j = 0;
}
#endif
}



static int
iss_panic_event(struct notifier_block *this, unsigned long event, void *ptr)
{
Expand All @@ -87,12 +73,29 @@ iss_panic_event(struct notifier_block *this, unsigned long event, void *ptr)
}

static struct notifier_block iss_panic_block = {
iss_panic_event,
NULL,
0
.notifier_call = iss_panic_event,
};

void __init platform_setup(char **p_cmdline)
{
int argc = simc_argc();
int argv_size = simc_argv_size();

if (argc > 1) {
void **argv = alloc_bootmem(argv_size);
char *cmdline = alloc_bootmem(argv_size);
int i;

cmdline[0] = 0;
simc_argv((void *)argv);

for (i = 1; i < argc; ++i) {
if (i > 1)
strcat(cmdline, " ");
strcat(cmdline, argv[i]);
}
*p_cmdline = cmdline;
}

atomic_notifier_chain_register(&panic_notifier_list, &iss_panic_block);
}

0 comments on commit 2a4e669

Please sign in to comment.