Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp6192906rwl; Wed, 22 Mar 2023 07:38:50 -0700 (PDT) X-Google-Smtp-Source: AK7set8oqGAA1xIzEJSQ392U6BGkS1qEZ7qUHs1BuTO5j3kyt2/Nc4wRcqHkXWVEKGGsWyGi6n1z X-Received: by 2002:a05:6402:c99:b0:4bc:edde:150d with SMTP id cm25-20020a0564020c9900b004bcedde150dmr2759005edb.0.1679495930288; Wed, 22 Mar 2023 07:38:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1679495930; cv=none; d=google.com; s=arc-20160816; b=UZwKBTf8s+ek/WUGw4tCCZ9sRDMo20EWG1Hm9xdzeNY1gB/VgP16Q8856QCvUttsrl jQg8MLVD+8gCGYyi4ivRFYBRFctkr/GcnhCQJX7NS2HekAVHzfeePqpww6Nvzyz9iNQr zaxwCj7OzFTrhCHxudr4VXvtvi6EH6npQ9XpW7YO5fadtqZv537vCB/9M7v9+f33gm5F u+U7gUhMgvXxbn87RYvUuQctp5aQJLsGptg1VPqksK9xpWeCOSuVakf809XS+ieLO+lz 6ysb6cpqGePvkJFIAzwj1MKK7k5IFxIfbUdRcRBBNzKXWtj/GeOXvxmf+po0eSgTRzX4 scCA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=W136RYugUgB80VgRCM0xbESvfYDQwy0XIM0ZKQr8VOI=; b=s4SdgejViD+v/NgGtyRbYcByZsocprO2B6sUs2nsXrwphXb8ZxAD/imq57xIQ5n4ut RMoxZeTT9fvBA3YOnA7ewPcxXJ0MgXV1ajuToGIbCy5JHPQiyasLo2wmVHj8g3n7MdTx veUF8Btt05Ru7gvB0qcaHJFkFWlMmOh6A5RzvPWxlulu2GjuitFCgAn+JWmFDtt9JJhR C0af7NkdkHy4Jo9XL4iWXVIIa7RFJNWj3U+YgvsaUI/vRvrKjmzdQy8u2amz/Mu15GYZ g41wrvT32t76KHlmNLSadvQf8ilghx3EXo/ZoVI0AWVE0fMnDr7CrLWqs/6dmDVxS85Z T25A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id l20-20020aa7cad4000000b005004b4ca08dsi14011158edt.599.2023.03.22.07.38.26; Wed, 22 Mar 2023 07:38:50 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231300AbjCVOf2 (ORCPT + 99 others); Wed, 22 Mar 2023 10:35:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58870 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231395AbjCVOfQ (ORCPT ); Wed, 22 Mar 2023 10:35:16 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7AA0F2A6E1 for ; Wed, 22 Mar 2023 07:34:53 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id E7DE96212D for ; Wed, 22 Mar 2023 14:34:52 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 9A71DC433EF; Wed, 22 Mar 2023 14:34:51 +0000 (UTC) Date: Wed, 22 Mar 2023 10:34:46 -0400 From: Steven Rostedt To: Ricardo Ribalda Cc: Eric Biederman , Philipp Rudo , linux-kernel@vger.kernel.org, kexec@lists.infradead.org Subject: Re: [PATCH] kexec: Support purgatories with .text.hot sections Message-ID: References: <20230321-kexec_clang16-v1-0-a768fc2c7c4d@chromium.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230321-kexec_clang16-v1-0-a768fc2c7c4d@chromium.org> X-Spam-Status: No, score=-2.0 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 21, 2023 at 12:49:08PM +0100, Ricardo Ribalda wrote: > Clang16 links the purgatory text in two sections: > > [ 1] .text PROGBITS 0000000000000000 00000040 > 00000000000011a1 0000000000000000 AX 0 0 16 > [ 2] .rela.text RELA 0000000000000000 00003498 > 0000000000000648 0000000000000018 I 24 1 8 > ... > [17] .text.hot. PROGBITS 0000000000000000 00003220 > 000000000000020b 0000000000000000 AX 0 0 1 > [18] .rela.text.hot. RELA 0000000000000000 00004428 > 0000000000000078 0000000000000018 I 24 17 8 > > And both of them have their range [sh_addr ... sh_addr+sh_size] on the > area pointed by `e_entry`. > > This causes that image->start is calculated twice, once for .text and > another time for .text.hot. The second calculation leaves image->start > in a random location. > > Because of this, the system crashes inmediatly after: > > kexec_core: Starting new kernel > > Signed-off-by: Ricardo Ribalda > To: Eric Biederman > Cc: Philipp Rudo > Cc: kexec@lists.infradead.org > Cc: linux-kernel@vger.kernel.org > --- > kernel/kexec_file.c | 3 ++- > 1 file changed, 2 insertions(+), 1 deletion(-) > > diff --git a/kernel/kexec_file.c b/kernel/kexec_file.c > index f1a0e4e3fb5c..b1a25d97d5e2 100644 > --- a/kernel/kexec_file.c > +++ b/kernel/kexec_file.c > @@ -904,7 +904,8 @@ static int kexec_purgatory_setup_sechdrs(struct purgatory_info *pi, > if (sechdrs[i].sh_flags & SHF_EXECINSTR && > pi->ehdr->e_entry >= sechdrs[i].sh_addr && > pi->ehdr->e_entry < (sechdrs[i].sh_addr > - + sechdrs[i].sh_size)) { > + + sechdrs[i].sh_size) && > + kbuf->image->start != pi->ehdr->e_shnum) { Shouldn't this be: kbuf->image->start == pi->ehdr->e_shnum) { ? As you want to only do this update when it's not equal to the initial value. If this did work, then you may want to make sure that was the initial value. Also, please add a comment about why you are doing this check. Thanks! -- Steve > kbuf->image->start -= sechdrs[i].sh_addr; > kbuf->image->start += kbuf->mem + offset; > } > > --- > base-commit: 17214b70a159c6547df9ae204a6275d983146f6b > change-id: 20230321-kexec_clang16-4510c23d129c > > Best regards, > -- > Ricardo Ribalda