Received: by 2002:ab2:7a55:0:b0:1f4:4a7d:290d with SMTP id u21csp557990lqp; Fri, 5 Apr 2024 01:50:43 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWO+sEhYkv2MMzt92/Ld3Af7Xi+Qg7R0dQUabJgLvoIyHR/iPKb6SrtpoyUstZHDAEeY7DEb9ijc4htnkmbYfTxffp2lb688SsKY9QnTQ== X-Google-Smtp-Source: AGHT+IEX6zpuq9ohhOgXTVapyJkcY7I/TTvO17J4TRbITL6+O35wP21LETKusdtQe/LBNc/JeXrX X-Received: by 2002:a17:906:4a81:b0:a4e:24cf:76d3 with SMTP id x1-20020a1709064a8100b00a4e24cf76d3mr571088eju.50.1712307043635; Fri, 05 Apr 2024 01:50:43 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712307043; cv=pass; d=google.com; s=arc-20160816; b=LmLzJaHoH1XCPpcgwwjlm0bzcjfmqOEHIXiMKaVQqCGpT+tyIVaeILn4p+LzkJE4rt FcoI9CLq32uadsQq+VY8E0Vga9ff/pW9xXF9c2VvVgYj3njVnAdokzhN4ZHv5jiSjjCT FEMJn/Iei2TWyjs1g+6FiYyTn26Odu6PIBA4J/b8CoOprhBlz/bcWukOuIGgHx0whHN2 sAN4oGHjlNW88G6zOHLyAgM0G7xae4Ct3byjbWqdQhUHkCnb1gOZvYdfCLy58d7/1Lif YucHonNAE3PXU7kPF/aSxlM8DiGWSZ+Q6GB1zy3q6XKuxtgGpcbYz7VQKNKyymFCnFXT gE7Q== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from; bh=C6eaAZ9iFyXz5XYAbb4HksB/1/yqf1OtSxIWgDiqcec=; fh=bMWmLlZXAR71tVf70xnZIXVqj+W2bGKnBeBj+ZqmWkg=; b=jtuPzS7XN4GJx6p6xfQ2eb0n9c8M6zYah4VUi+ERrDEHedBEAfTEMFkWXeipwypSuq bIT6wtHwSEa9jy/I4AyKC6nj+GgTXARuo01PfsJNHjjlvnMQ1tmEVjtANuoLhOaQh85+ JUiggjzQkChGURHvRXcTd+RBfv+RZ3Nr77pXfbovUflvB8CBKMDBb4kF06WXw5hxq9ff li+zmEN+Lb++jN2AgUvJ3JKyPF5Hb38l5SjWHc6WxpyMw4L2WfPdJTnAy1lw4F4D8aB7 55hnOCqw4SzVQCZ9tF8thsg68fUZIILdtbjV7Aixwt99g20WdW1yHAWhXIVjdcFQ6VwA A30A==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=arm.com dmarc=pass fromdomain=arm.com); spf=pass (google.com: domain of linux-kernel+bounces-132677-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-132677-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [2604:1380:4601:e00::3]) by mx.google.com with ESMTPS id f23-20020a50a6d7000000b0056e075465b0si511157edc.301.2024.04.05.01.50.43 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 05 Apr 2024 01:50:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-132677-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) client-ip=2604:1380:4601:e00::3; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=arm.com dmarc=pass fromdomain=arm.com); spf=pass (google.com: domain of linux-kernel+bounces-132677-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-132677-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 5D6551F21BA4 for ; Fri, 5 Apr 2024 08:50:43 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id C5C8815FD1F; Fri, 5 Apr 2024 08:50:03 +0000 (UTC) Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by smtp.subspace.kernel.org (Postfix) with ESMTP id CF61A15FD0A; Fri, 5 Apr 2024 08:50:01 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=217.140.110.172 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712307003; cv=none; b=jhtTyvblDRH/07NDbgaW3gHgTIu82+NWA+CTaQ5IPpNjtt3+JMqYUAOcKelTO02zwcqmhGrj7j84hy8DS68fCXtCi2kg2Dpyb9EDvqvr7GUTM6rYKJm8XG/w6YG9zy/a5gZRe74HOBaaKP+hQUoQKXSZsyXl/IVUYq7wupaeKh0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712307003; c=relaxed/simple; bh=p/8Fq+jpurELJ6V7Gi3YxX1mI3RCEZP5MKqChiEaFz0=; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References: MIME-Version; b=sfDqEbJMUnNfIkhtgYmouD1/Z5g79Iu+O2xK0fsB446Z6rJQuxY2aaykeIUq/8UmLHlMwj+wiwYuCmy//6GVFE8ilW1nNNqXWpJ3w8t+vaSAuJRy/YgWmJeBaDgwV2oOp2AulVlTzKwD5of14HDzDjo8ATQ6txLVXD9ocHFjW3A= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; arc=none smtp.client-ip=217.140.110.172 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id C73FFFEC; Fri, 5 Apr 2024 01:50:31 -0700 (PDT) Received: from e116581.blr.arm.com (e116581.arm.com [10.162.43.7]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id BF8443F64C; Fri, 5 Apr 2024 01:49:56 -0700 (PDT) From: Dev Jain To: shuah@kernel.org, linux-arm-kernel@lists.infradead.org Cc: linux-kselftest@vger.kernel.org, linux-kernel@vger.kernel.org, Anshuman.Khandual@arm.com, suzuki.poulose@arm.com, ryan.roberts@arm.com, rob.herring@arm.com, Catalin.Marinas@arm.com, broonie@kernel.org, will@kernel.org, mark.rutland@arm.com, Dev Jain Subject: [PATCH 3/4] selftests/arm: Add elf test Date: Fri, 5 Apr 2024 14:14:09 +0530 Message-Id: <20240405084410.256788-4-dev.jain@arm.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20240405084410.256788-1-dev.jain@arm.com> References: <20240405084410.256788-1-dev.jain@arm.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit This patch introduces an ELF parsing test; the 5th byte of the ELF header must be 0x01 for a 32-bit process. A basic sanity check is required to ensure that we are actually testing a 32-bit build. Signed-off-by: Dev Jain --- tools/testing/selftests/arm/elf/parse_elf.c | 75 +++++++++++++++++++++ 1 file changed, 75 insertions(+) create mode 100644 tools/testing/selftests/arm/elf/parse_elf.c diff --git a/tools/testing/selftests/arm/elf/parse_elf.c b/tools/testing/selftests/arm/elf/parse_elf.c new file mode 100644 index 000000000000..decd65699858 --- /dev/null +++ b/tools/testing/selftests/arm/elf/parse_elf.c @@ -0,0 +1,75 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Copyright (C) 2024 ARM Limited + * + * Author : Dev Jain + * + * Parse elf header to confirm 32-bit process + */ + +#define _GNU_SOURCE +#include +#include +#include +#include +#include + +#include + +/* The ELF file header. This appears at the start of every ELF file. */ + +struct elf_header { + unsigned char e_ident[16]; /* Magic number and other info */ + uint16_t e_type; /* Object file type */ + uint16_t e_machine; /* Architecture */ + uint32_t e_version; /* Object file version */ + uint64_t e_entry; /* Entry point virtual address */ + uint64_t e_phoff; /* Program header table file offset */ + uint64_t e_shoff; /* Section header table file offset */ + uint32_t e_flags; /* Processor-specific flags */ + uint16_t e_ehsize; /* ELF header size in bytes */ + uint16_t e_phentsize; /* Program header table entry size */ + uint16_t e_phnum; /* Program header table entry count */ + uint16_t e_shentsize; /* Section header table entry size */ + uint16_t e_shnum; /* Section header table entry count */ + uint16_t e_shstrndx; /* Section header string table index */ +}; + +static int read_elf_header(const char *elfFile) +{ + struct elf_header header; + FILE *file; + + file = fopen(elfFile, "r"); + if (file) { + + /* store header in struct */ + fread(&header, 1, sizeof(header), file); + fclose(file); + + /* sanity check: does it really follow ELF format */ + if (header.e_ident[0] == 0x7f && + header.e_ident[1] == 'E' && + header.e_ident[2] == 'L' && + header.e_ident[3] == 'F') { + if (header.e_ident[4] == 0x01) + return 0; + return 1; + } + ksft_exit_fail_msg("Cannot parse /proc/self/exe\n"); + } + ksft_exit_fail_msg("Cannot open /proc/self/exe\n"); + exit(EXIT_FAILURE); +} + +int main(int argc, char *argv[]) +{ + const char *file_name; + + ksft_print_header(); + ksft_set_plan(1); + + file_name = "/proc/self/exe"; + ksft_test_result(read_elf_header(file_name) == 0, "ELF is 32 bit\n"); + ksft_finished(); +} -- 2.39.2