Since aarch64 kernel can be configured with compat 32-bit support enabled, extend translation rules in a way similar to x86/x86_64. Suggested-by: "Dmitry V. Levin" <ldv@xxxxxxxxxxxx> Signed-off-by: Alexey Gladkov <gladkov.alexey@xxxxxxxxx> --- sys-utils/setarch.c | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/sys-utils/setarch.c b/sys-utils/setarch.c index b057b4df8..6914d791b 100644 --- a/sys-utils/setarch.c +++ b/sys-utils/setarch.c @@ -206,6 +206,19 @@ static struct arch_domain *init_arch_domains(void) {PER_LINUX, "e2k12c", "e2k"}, {PER_LINUX, "e2k16c", "e2k"}, {PER_LINUX, "e2k2c3", "e2k"}, +#endif +#if defined(__arm__) || defined(__aarch64__) +# ifdef __BIG_ENDIAN__ + {PER_LINUX32, "armv7b", "arm"}, + {PER_LINUX32, "armv8b", "arm"}, +# else + {PER_LINUX32, "armv7l", "arm"}, + {PER_LINUX32, "armv8l", "arm"}, +# endif + {PER_LINUX32, "armh", "arm"}, + {PER_LINUX32, "arm", "arm"}, + {PER_LINUX, "arm64", "aarch64"}, + {PER_LINUX, "aarch64", "aarch64"}, #endif /* place holder, will be filled up at runtime */ {-1, NULL, NULL}, @@ -266,7 +279,8 @@ static void verify_arch_domain(struct arch_domain *doms, struct arch_domain *tar if (!strcmp(un.machine, target->result_arch)) return; - if (!strcmp(target->result_arch, "i386")) { + if (!strcmp(target->result_arch, "i386") || + !strcmp(target->result_arch, "arm")) { struct arch_domain *dom; for (dom = doms; dom->target_arch != NULL; dom++) { if (!dom->result_arch || strcmp(dom->result_arch, target->result_arch)) -- 2.25.4