diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-14 13:39:34 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-14 13:39:34 -0700 | 
| commit | d25282d1c9b9bc4cda7f9d3c0205108e99aa7a9d (patch) | |
| tree | f414482d768b015a609924293b779b4ad0b8f764 /include/linux/moduleloader.h | |
| parent | b6eea87fc6850d3531a64a27d2323a4498cd4e43 (diff) | |
| parent | dbadc17683e6c673a69b236c0f041b931cc55c42 (diff) | |
| download | olio-linux-3.10-d25282d1c9b9bc4cda7f9d3c0205108e99aa7a9d.tar.xz olio-linux-3.10-d25282d1c9b9bc4cda7f9d3c0205108e99aa7a9d.zip  | |
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 b2be02ebf45..560ca53a75f 100644 --- a/include/linux/moduleloader.h +++ b/include/linux/moduleloader.h @@ -28,21 +28,49 @@ void *module_alloc(unsigned long size);  /* Free memory returned from module_alloc. */  void module_free(struct module *mod, void *module_region); -/* Apply the given relocation to the (simplified) ELF.  Return -error -   or 0. */ +/* + * Apply the given relocation to the (simplified) ELF.  Return -error + * or 0. + */ +#ifdef CONFIG_MODULES_USE_ELF_REL  int apply_relocate(Elf_Shdr *sechdrs,  		   const char *strtab,  		   unsigned int symindex,  		   unsigned int relsec,  		   struct module *mod); +#else +static inline int apply_relocate(Elf_Shdr *sechdrs, +				 const char *strtab, +				 unsigned int symindex, +				 unsigned int relsec, +				 struct module *me) +{ +	printk(KERN_ERR "module %s: REL relocation unsupported\n", me->name); +	return -ENOEXEC; +} +#endif -/* Apply the given add relocation to the (simplified) ELF.  Return -   -error or 0 */ +/* + * Apply the given add relocation to the (simplified) ELF.  Return + * -error or 0 + */ +#ifdef CONFIG_MODULES_USE_ELF_RELA  int apply_relocate_add(Elf_Shdr *sechdrs,  		       const char *strtab,  		       unsigned int symindex,  		       unsigned int relsec,  		       struct module *mod); +#else +static inline int apply_relocate_add(Elf_Shdr *sechdrs, +				     const char *strtab, +				     unsigned int symindex, +				     unsigned int relsec, +				     struct module *me) +{ +	printk(KERN_ERR "module %s: REL relocation unsupported\n", me->name); +	return -ENOEXEC; +} +#endif  /* Any final processing of module before access.  Return -error or 0. */  int module_finalize(const Elf_Ehdr *hdr,  |