Commit a4553907 authored by David Howells's avatar David Howells Committed by Khalid Elmously

UBUNTU: SAUCE: (efi-lockdown) Lock down module params that specify hardware parameters (eg. ioport)

BugLink: https://bugs.launchpad.net/bugs/1884159

Provided an annotation for module parameters that specify hardware
parameters (such as io ports, iomem addresses, irqs, dma channels, fixed
dma buffers and other types).
Suggested-by: default avatarAlan Cox <gnomes@lxorguk.ukuu.org.uk>
Signed-off-by: default avatarDavid Howells <dhowells@redhat.com>
(backported from commit 33a38c67ed53106458e1858a2101cae3026486e4
 git://git.kernel.org/pub/scm/linux/kernel/git/jwboyer/fedora.git)
Signed-off-by: default avatarSeth Forshee <seth.forshee@canonical.com>
Acked-by: default avatarStefan Bader <stefan.bader@canonical.com>
Acked-by: default avatarAndrea Righi <andrea.righi@canonical.com>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
parent 8d522ceb
...@@ -108,13 +108,18 @@ bool parameq(const char *a, const char *b) ...@@ -108,13 +108,18 @@ bool parameq(const char *a, const char *b)
return parameqn(a, b, strlen(a)+1); return parameqn(a, b, strlen(a)+1);
} }
static void param_check_unsafe(const struct kernel_param *kp) static bool param_check_unsafe(const struct kernel_param *kp,
const char *doing)
{ {
if (kp->flags & KERNEL_PARAM_FL_UNSAFE) { if (kp->flags & KERNEL_PARAM_FL_UNSAFE) {
pr_warn("Setting dangerous option %s - tainting kernel\n", pr_warn("Setting dangerous option %s - tainting kernel\n",
kp->name); kp->name);
add_taint(TAINT_USER, LOCKDEP_STILL_OK); add_taint(TAINT_USER, LOCKDEP_STILL_OK);
} }
if (kp->flags & KERNEL_PARAM_FL_HWPARAM && secure_modules())
return false;
return true;
} }
static int parse_one(char *param, static int parse_one(char *param,
...@@ -144,8 +149,10 @@ static int parse_one(char *param, ...@@ -144,8 +149,10 @@ static int parse_one(char *param,
pr_debug("handling %s with %p\n", param, pr_debug("handling %s with %p\n", param,
params[i].ops->set); params[i].ops->set);
kernel_param_lock(params[i].mod); kernel_param_lock(params[i].mod);
param_check_unsafe(&params[i]); if (param_check_unsafe(&params[i], doing))
err = params[i].ops->set(val, &params[i]); err = params[i].ops->set(val, &params[i]);
else
err = -EPERM;
kernel_param_unlock(params[i].mod); kernel_param_unlock(params[i].mod);
return err; return err;
} }
...@@ -608,6 +615,12 @@ static ssize_t param_attr_show(struct module_attribute *mattr, ...@@ -608,6 +615,12 @@ static ssize_t param_attr_show(struct module_attribute *mattr,
return count; return count;
} }
#ifdef CONFIG_MODULES
#define mod_name(mod) (mod)->name
#else
#define mod_name(mod) "unknown"
#endif
/* sysfs always hands a nul-terminated string in buf. We rely on that. */ /* sysfs always hands a nul-terminated string in buf. We rely on that. */
static ssize_t param_attr_store(struct module_attribute *mattr, static ssize_t param_attr_store(struct module_attribute *mattr,
struct module_kobject *mk, struct module_kobject *mk,
...@@ -620,8 +633,10 @@ static ssize_t param_attr_store(struct module_attribute *mattr, ...@@ -620,8 +633,10 @@ static ssize_t param_attr_store(struct module_attribute *mattr,
return -EPERM; return -EPERM;
kernel_param_lock(mk->mod); kernel_param_lock(mk->mod);
param_check_unsafe(attribute->param); if (param_check_unsafe(attribute->param, mod_name(mk->mod)))
err = attribute->param->ops->set(buf, attribute->param); err = attribute->param->ops->set(buf, attribute->param);
else
err = -EPERM;
kernel_param_unlock(mk->mod); kernel_param_unlock(mk->mod);
if (!err) if (!err)
return len; return len;
......
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