diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-14 16:39:34 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-14 16:39:34 -0400 |
| commit | d25282d1c9b9bc4cda7f9d3c0205108e99aa7a9d (patch) | |
| tree | f414482d768b015a609924293b779b4ad0b8f764 /include/linux/moduleloader.h | |
| parent | b6eea87fc6850d3531a64a27d2323a4498cd4e43 (diff) | |
| parent | dbadc17683e6c673a69b236c0f041b931cc55c42 (diff) | |
Merge branch 'modules-next' of git://git.kernel.org/pub/scm/linux/kernel/git/rusty/linux
Pull module signing support from Rusty Russell:
"module signing is the highlight, but it's an all-over David Howells frenzy..."
Hmm "Magrathea: Glacier signing key". Somebody has been reading too much HHGTTG.
* 'modules-next' of git://git.kernel.org/pub/scm/linux/kernel/git/rusty/linux: (37 commits)
X.509: Fix indefinite length element skip error handling
X.509: Convert some printk calls to pr_devel
asymmetric keys: fix printk format warning
MODSIGN: Fix 32-bit overflow in X.509 certificate validity date checking
MODSIGN: Make mrproper should remove generated files.
MODSIGN: Use utf8 strings in signer's name in autogenerated X.509 certs
MODSIGN: Use the same digest for the autogen key sig as for the module sig
MODSIGN: Sign modules during the build process
MODSIGN: Provide a script for generating a key ID from an X.509 cert
MODSIGN: Implement module signature checking
MODSIGN: Provide module signing public keys to the kernel
MODSIGN: Automatically generate module signing keys if missing
MODSIGN: Provide Kconfig options
MODSIGN: Provide gitignore and make clean rules for extra files
MODSIGN: Add FIPS policy
module: signature checking hook
X.509: Add a crypto key parser for binary (DER) X.509 certificates
MPILIB: Provide a function to read raw data into an MPI
X.509: Add an ASN.1 decoder
X.509: Add simple ASN.1 grammar compiler
...
Diffstat (limited to 'include/linux/moduleloader.h')
| -rw-r--r-- | include/linux/moduleloader.h | 36 |
1 files changed, 32 insertions, 4 deletions
diff --git a/include/linux/moduleloader.h b/include/linux/moduleloader.h index b2be02ebf453..560ca53a75fa 100644 --- a/include/linux/moduleloader.h +++ b/include/linux/moduleloader.h | |||
| @@ -28,21 +28,49 @@ void *module_alloc(unsigned long size); | |||
| 28 | /* Free memory returned from module_alloc. */ | 28 | /* Free memory returned from module_alloc. */ |
| 29 | void module_free(struct module *mod, void *module_region); | 29 | void module_free(struct module *mod, void *module_region); |
| 30 | 30 | ||
| 31 | /* Apply the given relocation to the (simplified) ELF. Return -error | 31 | /* |
| 32 | or 0. */ | 32 | * Apply the given relocation to the (simplified) ELF. Return -error |
| 33 | * or 0. | ||
| 34 | */ | ||
| 35 | #ifdef CONFIG_MODULES_USE_ELF_REL | ||
| 33 | int apply_relocate(Elf_Shdr *sechdrs, | 36 | int apply_relocate(Elf_Shdr *sechdrs, |
| 34 | const char *strtab, | 37 | const char *strtab, |
| 35 | unsigned int symindex, | 38 | unsigned int symindex, |
| 36 | unsigned int relsec, | 39 | unsigned int relsec, |
| 37 | struct module *mod); | 40 | struct module *mod); |
| 41 | #else | ||
| 42 | static inline int apply_relocate(Elf_Shdr *sechdrs, | ||
| 43 | const char *strtab, | ||
| 44 | unsigned int symindex, | ||
| 45 | unsigned int relsec, | ||
| 46 | struct module *me) | ||
| 47 | { | ||
| 48 | printk(KERN_ERR "module %s: REL relocation unsupported\n", me->name); | ||
| 49 | return -ENOEXEC; | ||
| 50 | } | ||
| 51 | #endif | ||
| 38 | 52 | ||
| 39 | /* Apply the given add relocation to the (simplified) ELF. Return | 53 | /* |
| 40 | -error or 0 */ | 54 | * Apply the given add relocation to the (simplified) ELF. Return |
| 55 | * -error or 0 | ||
| 56 | */ | ||
| 57 | #ifdef CONFIG_MODULES_USE_ELF_RELA | ||
| 41 | int apply_relocate_add(Elf_Shdr *sechdrs, | 58 | int apply_relocate_add(Elf_Shdr *sechdrs, |
| 42 | const char *strtab, | 59 | const char *strtab, |
| 43 | unsigned int symindex, | 60 | unsigned int symindex, |
| 44 | unsigned int relsec, | 61 | unsigned int relsec, |
| 45 | struct module *mod); | 62 | struct module *mod); |
| 63 | #else | ||
| 64 | static inline int apply_relocate_add(Elf_Shdr *sechdrs, | ||
| 65 | const char *strtab, | ||
| 66 | unsigned int symindex, | ||
| 67 | unsigned int relsec, | ||
| 68 | struct module *me) | ||
| 69 | { | ||
| 70 | printk(KERN_ERR "module %s: REL relocation unsupported\n", me->name); | ||
| 71 | return -ENOEXEC; | ||
| 72 | } | ||
| 73 | #endif | ||
| 46 | 74 | ||
| 47 | /* Any final processing of module before access. Return -error or 0. */ | 75 | /* Any final processing of module before access. Return -error or 0. */ |
| 48 | int module_finalize(const Elf_Ehdr *hdr, | 76 | int module_finalize(const Elf_Ehdr *hdr, |
