Commit 6f6b9fee authored by Alexander Sverdlin's avatar Alexander Sverdlin Committed by Brian Norris

mtd: phram: Repair multiple instances support

Commit b2a2a84d (mtd: phram: dot not crash when
built-in and passing boot param) claims to be "based on Ville Herva's similar
patch to block2mtd" (c4e7fb31), but it has
missed the crucial point of the original path: all these "if(n)def MODULE".
It has broken the possibility to create several phram instances when phram is
compiled as module. The possibility to add instances via /sys writes to
/sys/module/phram/parameters/phram was also broken with mentioned patch.
Proposed patch takes the idea of original block2mtd patch to its full extent.
Assumption "This function is always called before 'init_phram()'" was also
incorrect, so removed the comment. This patch effectively reverts also
b11ec57f (mtd: phram: fix section mismatch for
phram_setup).
Signed-off-by: default avatarAlexander Sverdlin <alexander.sverdlin@nsn.com>
[Brian: remove static assigment = 0]
Signed-off-by: default avatarBrian Norris <computersforpeace@gmail.com>
parent b4c23305
...@@ -205,6 +205,8 @@ static inline void kill_final_newline(char *str) ...@@ -205,6 +205,8 @@ static inline void kill_final_newline(char *str)
return 1; \ return 1; \
} while (0) } while (0)
#ifndef MODULE
static int phram_init_called;
/* /*
* This shall contain the module parameter if any. It is of the form: * This shall contain the module parameter if any. It is of the form:
* - phram=<device>,<address>,<size> for module case * - phram=<device>,<address>,<size> for module case
...@@ -213,9 +215,10 @@ static inline void kill_final_newline(char *str) ...@@ -213,9 +215,10 @@ static inline void kill_final_newline(char *str)
* size. * size.
* Example: phram.phram=rootfs,0xa0000000,512Mi * Example: phram.phram=rootfs,0xa0000000,512Mi
*/ */
static __initdata char phram_paramline[64 + 20 + 20]; static char phram_paramline[64 + 20 + 20];
#endif
static int __init phram_setup(const char *val) static int phram_setup(const char *val)
{ {
char buf[64 + 20 + 20], *str = buf; char buf[64 + 20 + 20], *str = buf;
char *token[3]; char *token[3];
...@@ -264,17 +267,36 @@ static int __init phram_setup(const char *val) ...@@ -264,17 +267,36 @@ static int __init phram_setup(const char *val)
return ret; return ret;
} }
static int __init phram_param_call(const char *val, struct kernel_param *kp) static int phram_param_call(const char *val, struct kernel_param *kp)
{ {
#ifdef MODULE
return phram_setup(val);
#else
/* /*
* This function is always called before 'init_phram()', whether * If more parameters are later passed in via
* built-in or module. * /sys/module/phram/parameters/phram
* and init_phram() has already been called,
* we can parse the argument now.
*/ */
if (phram_init_called)
return phram_setup(val);
/*
* During early boot stage, we only save the parameters
* here. We must parse them later: if the param passed
* from kernel boot command line, phram_param_call() is
* called so early that it is not possible to resolve
* the device (even kmalloc() fails). Defer that work to
* phram_setup().
*/
if (strlen(val) >= sizeof(phram_paramline)) if (strlen(val) >= sizeof(phram_paramline))
return -ENOSPC; return -ENOSPC;
strcpy(phram_paramline, val); strcpy(phram_paramline, val);
return 0; return 0;
#endif
} }
module_param_call(phram, phram_param_call, NULL, NULL, 000); module_param_call(phram, phram_param_call, NULL, NULL, 000);
...@@ -283,10 +305,15 @@ MODULE_PARM_DESC(phram, "Memory region to map. \"phram=<name>,<start>,<length>\" ...@@ -283,10 +305,15 @@ MODULE_PARM_DESC(phram, "Memory region to map. \"phram=<name>,<start>,<length>\"
static int __init init_phram(void) static int __init init_phram(void)
{ {
int ret = 0;
#ifndef MODULE
if (phram_paramline[0]) if (phram_paramline[0])
return phram_setup(phram_paramline); ret = phram_setup(phram_paramline);
phram_init_called = 1;
#endif
return 0; return ret;
} }
static void __exit cleanup_phram(void) static void __exit cleanup_phram(void)
......
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