diff options
author | Stephen Rothwell <sfr@canb.auug.org.au> | 2010-08-05 11:28:16 +1000 |
---|---|---|
committer | Stephen Rothwell <sfr@canb.auug.org.au> | 2010-08-05 11:28:23 +1000 |
commit | 2dd3971a277830f03a0231fee7a3e83a8975fc6d (patch) | |
tree | 10ee62fcbf9ae9c4c4824bdd6774f3cccb94f3c7 /scripts | |
parent | 3cdb27cd09c97991c4c675512f940a9e66c3dd27 (diff) | |
parent | df736f6915a24373481fde09ede0b573348cddbf (diff) |
Merge branch 'quilt/rr'
Conflicts:
arch/um/drivers/hostaudio_kern.c
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/mod/modpost.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/scripts/mod/modpost.c b/scripts/mod/modpost.c index c827309c29cf..55401535c223 100644 --- a/scripts/mod/modpost.c +++ b/scripts/mod/modpost.c @@ -1033,6 +1033,13 @@ static const struct sectioncheck *section_mismatch( * fromsec = .data* * atsym =__param* * + * Pattern 1a: + * module_param_call() ops can refer to __init set function if permissions=0 + * The pattern is identified by: + * tosec = .init.text + * fromsec = .data* + * atsym = __param_ops_* + * * Pattern 2: * Many drivers utilise a *driver container with references to * add, remove, probe functions etc. @@ -1067,6 +1074,12 @@ static int secref_whitelist(const struct sectioncheck *mismatch, (strncmp(fromsym, "__param", strlen("__param")) == 0)) return 0; + /* Check for pattern 1a */ + if (strcmp(tosec, ".init.text") == 0 && + match(fromsec, data_sections) && + (strncmp(fromsym, "__param_ops_", strlen("__param_ops_")) == 0)) + return 0; + /* Check for pattern 2 */ if (match(tosec, init_exit_sections) && match(fromsec, data_sections) && |