Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 860e546c authored by Atsushi Nemoto's avatar Atsushi Nemoto Committed by Ralf Baechle
Browse files

MIPS: TXx9: Early command-line preprocessing



* Select board by command-line option or firmware environment variable.
* Handle "masterclk=" option.
* Add boards.h to centerize board_vec declaration.

Signed-off-by: default avatarAtsushi Nemoto <anemo@mba.ocn.ne.jp>
Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>

 create mode 100644 include/asm-mips/txx9/boards.h
parent 265b89db
Loading
Loading
Loading
Loading
+68 −6
Original line number Original line Diff line number Diff line
@@ -119,14 +119,31 @@ int irq_to_gpio(unsigned irq)
EXPORT_SYMBOL(irq_to_gpio);
EXPORT_SYMBOL(irq_to_gpio);
#endif
#endif


extern struct txx9_board_vec jmr3927_vec;
#define BOARD_VEC(board)	extern struct txx9_board_vec board;
extern struct txx9_board_vec rbtx4927_vec;
#include <asm/txx9/boards.h>
extern struct txx9_board_vec rbtx4937_vec;
#undef BOARD_VEC
extern struct txx9_board_vec rbtx4938_vec;


struct txx9_board_vec *txx9_board_vec __initdata;
struct txx9_board_vec *txx9_board_vec __initdata;
static char txx9_system_type[32];
static char txx9_system_type[32];


static struct txx9_board_vec *board_vecs[] __initdata = {
#define BOARD_VEC(board)	&board,
#include <asm/txx9/boards.h>
#undef BOARD_VEC
};

static struct txx9_board_vec *__init find_board_byname(const char *name)
{
	int i;

	/* search board_vecs table */
	for (i = 0; i < ARRAY_SIZE(board_vecs); i++) {
		if (strstr(board_vecs[i]->system, name))
			return board_vecs[i];
	}
	return NULL;
}

static void __init prom_init_cmdline(void)
static void __init prom_init_cmdline(void)
{
{
	int argc = (int)fw_arg0;
	int argc = (int)fw_arg0;
@@ -169,9 +186,47 @@ static void __init prom_init_cmdline(void)
	}
	}
}
}


void __init prom_init(void)
static void __init preprocess_cmdline(void)
{
{
	prom_init_cmdline();
	char cmdline[CL_SIZE];
	char *s;

	strcpy(cmdline, arcs_cmdline);
	s = cmdline;
	arcs_cmdline[0] = '\0';
	while (s && *s) {
		char *str = strsep(&s, " ");
		if (strncmp(str, "board=", 6) == 0) {
			txx9_board_vec = find_board_byname(str + 6);
			continue;
		} else if (strncmp(str, "masterclk=", 10) == 0) {
			unsigned long val;
			if (strict_strtoul(str + 10, 10, &val) == 0)
				txx9_master_clock = val;
			continue;
		}
		if (arcs_cmdline[0])
			strcat(arcs_cmdline, " ");
		strcat(arcs_cmdline, str);
	}
}

static void __init select_board(void)
{
	const char *envstr;

	/* first, determine by "board=" argument in preprocess_cmdline() */
	if (txx9_board_vec)
		return;
	/* next, determine by "board" envvar */
	envstr = prom_getenv("board");
	if (envstr) {
		txx9_board_vec = find_board_byname(envstr);
		if (txx9_board_vec)
			return;
	}

	/* select "default" board */
#ifdef CONFIG_CPU_TX39XX
#ifdef CONFIG_CPU_TX39XX
	txx9_board_vec = &jmr3927_vec;
	txx9_board_vec = &jmr3927_vec;
#endif
#endif
@@ -192,6 +247,13 @@ void __init prom_init(void)
#endif
#endif
	}
	}
#endif
#endif
}

void __init prom_init(void)
{
	prom_init_cmdline();
	preprocess_cmdline();
	select_board();


	strcpy(txx9_system_type, txx9_board_vec->system);
	strcpy(txx9_system_type, txx9_board_vec->system);


+10 −0
Original line number Original line Diff line number Diff line
#ifdef CONFIG_TOSHIBA_JMR3927
BOARD_VEC(jmr3927_vec)
#endif
#ifdef CONFIG_TOSHIBA_RBTX4927
BOARD_VEC(rbtx4927_vec)
BOARD_VEC(rbtx4937_vec)
#endif
#ifdef CONFIG_TOSHIBA_RBTX4938
BOARD_VEC(rbtx4938_vec)
#endif