Commit cf9a566c authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Greg Ungerer

binfmt_flat: make support for old format binaries optional

No need to carry the extra code around, given that systems using flat
binaries are generally very resource constrained.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarGreg Ungerer <gerg@linux-m68k.org>
parent aef0f78e
...@@ -106,6 +106,13 @@ config BINFMT_FLAT_ARGVP_ENVP_ON_STACK ...@@ -106,6 +106,13 @@ config BINFMT_FLAT_ARGVP_ENVP_ON_STACK
config BINFMT_FLAT_OLD_ALWAYS_RAM config BINFMT_FLAT_OLD_ALWAYS_RAM
bool bool
config BINFMT_FLAT_OLD
bool "Enable support for very old legacy flat binaries"
depends on BINFMT_FLAT
help
Support decade old uClinux FLAT format binaries. Unless you know
you have some of those say N here.
config BINFMT_ZFLAT config BINFMT_ZFLAT
bool "Enable ZFLAT support" bool "Enable ZFLAT support"
depends on BINFMT_FLAT depends on BINFMT_FLAT
......
...@@ -374,6 +374,7 @@ calc_reloc(unsigned long r, struct lib_info *p, int curid, int internalp) ...@@ -374,6 +374,7 @@ calc_reloc(unsigned long r, struct lib_info *p, int curid, int internalp)
/****************************************************************************/ /****************************************************************************/
#ifdef CONFIG_BINFMT_FLAT_OLD
static void old_reloc(unsigned long rl) static void old_reloc(unsigned long rl)
{ {
static const char *segment[] = { "TEXT", "DATA", "BSS", "*UNKNOWN*" }; static const char *segment[] = { "TEXT", "DATA", "BSS", "*UNKNOWN*" };
...@@ -411,6 +412,7 @@ static void old_reloc(unsigned long rl) ...@@ -411,6 +412,7 @@ static void old_reloc(unsigned long rl)
pr_debug("Relocation became %lx\n", val); pr_debug("Relocation became %lx\n", val);
} }
#endif /* CONFIG_BINFMT_FLAT_OLD */
/****************************************************************************/ /****************************************************************************/
...@@ -461,6 +463,7 @@ static int load_flat_file(struct linux_binprm *bprm, ...@@ -461,6 +463,7 @@ static int load_flat_file(struct linux_binprm *bprm,
if (flags & FLAT_FLAG_KTRACE) if (flags & FLAT_FLAG_KTRACE)
pr_info("Loading file: %s\n", bprm->filename); pr_info("Loading file: %s\n", bprm->filename);
#ifdef CONFIG_BINFMT_FLAT_OLD
if (rev != FLAT_VERSION && rev != OLD_FLAT_VERSION) { if (rev != FLAT_VERSION && rev != OLD_FLAT_VERSION) {
pr_err("bad flat file version 0x%x (supported 0x%lx and 0x%lx)\n", pr_err("bad flat file version 0x%x (supported 0x%lx and 0x%lx)\n",
rev, FLAT_VERSION, OLD_FLAT_VERSION); rev, FLAT_VERSION, OLD_FLAT_VERSION);
...@@ -476,6 +479,23 @@ static int load_flat_file(struct linux_binprm *bprm, ...@@ -476,6 +479,23 @@ static int load_flat_file(struct linux_binprm *bprm,
goto err; goto err;
} }
/*
* fix up the flags for the older format, there were all kinds
* of endian hacks, this only works for the simple cases
*/
if (rev == OLD_FLAT_VERSION &&
(flags || IS_ENABLED(CONFIG_BINFMT_FLAT_OLD_ALWAYS_RAM)))
flags = FLAT_FLAG_RAM;
#else /* CONFIG_BINFMT_FLAT_OLD */
if (rev != FLAT_VERSION) {
pr_err("bad flat file version 0x%x (supported 0x%lx)\n",
rev, FLAT_VERSION);
ret = -ENOEXEC;
goto err;
}
#endif /* !CONFIG_BINFMT_FLAT_OLD */
/* /*
* Make sure the header params are sane. * Make sure the header params are sane.
* 28 bits (256 MB) is way more than reasonable in this case. * 28 bits (256 MB) is way more than reasonable in this case.
...@@ -487,14 +507,6 @@ static int load_flat_file(struct linux_binprm *bprm, ...@@ -487,14 +507,6 @@ static int load_flat_file(struct linux_binprm *bprm,
goto err; goto err;
} }
/*
* fix up the flags for the older format, there were all kinds
* of endian hacks, this only works for the simple cases
*/
if (rev == OLD_FLAT_VERSION &&
(flags || IS_ENABLED(CONFIG_BINFMT_FLAT_OLD_ALWAYS_RAM)))
flags = FLAT_FLAG_RAM;
#ifndef CONFIG_BINFMT_ZFLAT #ifndef CONFIG_BINFMT_ZFLAT
if (flags & (FLAT_FLAG_GZIP|FLAT_FLAG_GZDATA)) { if (flags & (FLAT_FLAG_GZIP|FLAT_FLAG_GZDATA)) {
pr_err("Support for ZFLAT executables is not enabled.\n"); pr_err("Support for ZFLAT executables is not enabled.\n");
...@@ -833,6 +845,7 @@ static int load_flat_file(struct linux_binprm *bprm, ...@@ -833,6 +845,7 @@ static int load_flat_file(struct linux_binprm *bprm,
goto err; goto err;
} }
} }
#ifdef CONFIG_BINFMT_FLAT_OLD
} else { } else {
for (i = 0; i < relocs; i++) { for (i = 0; i < relocs; i++) {
__be32 relval; __be32 relval;
...@@ -840,6 +853,7 @@ static int load_flat_file(struct linux_binprm *bprm, ...@@ -840,6 +853,7 @@ static int load_flat_file(struct linux_binprm *bprm,
return -EFAULT; return -EFAULT;
old_reloc(ntohl(relval)); old_reloc(ntohl(relval));
} }
#endif /* CONFIG_BINFMT_FLAT_OLD */
} }
flush_icache_range(start_code, end_code); flush_icache_range(start_code, end_code);
......
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