Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp3266829pxb; Mon, 9 Nov 2020 06:59:27 -0800 (PST) X-Google-Smtp-Source: ABdhPJwVaMSocKxiY7w9DxfUexWT8c38h0Fkp6sbzwq2vZVMYnuAJu8YBWDbnwdLBcYCkgfEA8ov X-Received: by 2002:a17:906:138c:: with SMTP id f12mr15981343ejc.108.1604933967113; Mon, 09 Nov 2020 06:59:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604933967; cv=none; d=google.com; s=arc-20160816; b=lM6Hx8S3mlybB3+TsKOE0rI9rxZWmtL2XBjDMXxT9sjwfswC8OlLQU9C/SPHyn5+xO IgG1hhyHdzIzzoPmH4OtPdKZFJ2VLP4PoyxOhV2KD9g6YzYP3oDZHLhFzmJPdvtIK0xl 7Zsmdwfop/IH/LxpPuVCS+A+33sc/BPs+spvsnjMYpmT84XHEzQlTs5cW7dih4ASuygV l24gJkZBhErQ5R8KEx3Bpgs+K1HCEJ+j1m/YmUU/QWHgJWBOs+D7oQU/l4RVsW+5/c2u 61+QBW7B2NDW4LeA6rs/fXXUHHqG1ac4gsPH779gYH/WbrkgpHZQ1K/sGx4BETco/oaC n98Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=DQ15cBqOAfFIH05xvKC1uGM4xBFFPGn3P3XJTdj98fo=; b=LfkApBUInSmm8/Pq88n/JfbGnE5QsGFV4r2DMipS+JDRDkZ3/sJflUvPhFldCC0Vau OYb8iVVNG1DMumyVrqpnq752pMiHEFXxso98OXoh0/z6hxP2wdFQD+wEeiS5Eggn9w4K IUI7g+lbi207CciYFjwGaAsdqQt+hkN48QK66juON9YBj5gY4uMlCtBT62q9RosnVuX3 3qVrjnkP8JkYZuJAB/okNZBPnqrD98DXkCg1LY1uE0T/93++ARHo5IbdnWPsVsPlvHpb GPRNKYuvzOtA3b4XTEarugI1SW0HOKWGK9vGMamnBEgqfnEfr4b4UexebBj8bZe3g59Z yYww== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=SG5YMG5+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id jp23si7141866ejb.561.2020.11.09.06.59.02; Mon, 09 Nov 2020 06:59:27 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=SG5YMG5+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730449AbgKINAN (ORCPT + 99 others); Mon, 9 Nov 2020 08:00:13 -0500 Received: from mail.kernel.org ([198.145.29.99]:54232 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730411AbgKINAE (ORCPT ); Mon, 9 Nov 2020 08:00:04 -0500 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id EDDDF216C4; Mon, 9 Nov 2020 13:00:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604926802; bh=AztB8MVXQZdYwfXZ7uEqQsU1R83qfU9ZPAlsqcv9pnA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=SG5YMG5+nkrHhEaqV5sZm4sDCEoMqE7EPZ5olh/5mRTHWbpOBq8FjYHefOjtnEGxL K6n0azaQeUgu06MsHv2nJ2eDEdJ0B0GBnY4U1oPxUxbebQmNffRhmQBEn+LaZg6pby zdkoGvrqW7eo7d9l3QJ8DLIglyaNoraLoCIoNOHI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Rasmus Villemoes , Masahiro Yamada Subject: [PATCH 4.9 002/117] scripts/setlocalversion: make git describe output more reliable Date: Mon, 9 Nov 2020 13:53:48 +0100 Message-Id: <20201109125025.750106289@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201109125025.630721781@linuxfoundation.org> References: <20201109125025.630721781@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Rasmus Villemoes commit 548b8b5168c90c42e88f70fcf041b4ce0b8e7aa8 upstream. When building for an embedded target using Yocto, we're sometimes observing that the version string that gets built into vmlinux (and thus what uname -a reports) differs from the path under /lib/modules/ where modules get installed in the rootfs, but only in the length of the -gabc123def suffix. Hence modprobe always fails. The problem is that Yocto has the concept of "sstate" (shared state), which allows different developers/buildbots/etc. to share build artifacts, based on a hash of all the metadata that went into building that artifact - and that metadata includes all dependencies (e.g. the compiler used etc.). That normally works quite well; usually a clean build (without using any sstate cache) done by one developer ends up being binary identical to a build done on another host. However, one thing that can cause two developers to end up with different builds [and thus make one's vmlinux package incompatible with the other's kernel-dev package], which is not captured by the metadata hashing, is this `git describe`: The output of that can be affected by (1) git version: before 2.11 git defaulted to a minimum of 7, since 2.11 (git.git commit e6c587) the default is dynamic based on the number of objects in the repo (2) hence even if both run the same git version, the output can differ based on how many remotes are being tracked (or just lots of local development branches or plain old garbage) (3) and of course somebody could have a core.abbrev config setting in ~/.gitconfig So in order to avoid `uname -a` output relying on such random details of the build environment which are rather hard to ensure are consistent between developers and buildbots, make sure the abbreviated sha1 always consists of exactly 12 hex characters. That is consistent with the current rule for -stable patches, and is almost always enough to identify the head commit unambigously - in the few cases where it does not, the v5.4.3-00021- prefix would certainly nail it down. [Adapt to `` vs $() differences between 5.4 and upstream.] Signed-off-by: Rasmus Villemoes Signed-off-by: Masahiro Yamada Signed-off-by: Greg Kroah-Hartman --- scripts/setlocalversion | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) --- a/scripts/setlocalversion +++ b/scripts/setlocalversion @@ -44,7 +44,7 @@ scm_version() # Check for git and a git repo. if test -z "$(git rev-parse --show-cdup 2>/dev/null)" && - head=`git rev-parse --verify --short HEAD 2>/dev/null`; then + head=$(git rev-parse --verify HEAD 2>/dev/null); then # If we are at a tagged commit (like "v2.6.30-rc6"), we ignore # it, because this version is defined in the top level Makefile. @@ -58,11 +58,22 @@ scm_version() fi # If we are past a tagged commit (like # "v2.6.30-rc5-302-g72357d5"), we pretty print it. - if atag="`git describe 2>/dev/null`"; then - echo "$atag" | awk -F- '{printf("-%05d-%s", $(NF-1),$(NF))}' + # + # Ensure the abbreviated sha1 has exactly 12 + # hex characters, to make the output + # independent of git version, local + # core.abbrev settings and/or total number of + # objects in the current repository - passing + # --abbrev=12 ensures a minimum of 12, and the + # awk substr() then picks the 'g' and first 12 + # hex chars. + if atag="$(git describe --abbrev=12 2>/dev/null)"; then + echo "$atag" | awk -F- '{printf("-%05d-%s", $(NF-1),substr($(NF),0,13))}' - # If we don't have a tag at all we print -g{commitish}. + # If we don't have a tag at all we print -g{commitish}, + # again using exactly 12 hex chars. else + head="$(echo $head | cut -c1-12)" printf '%s%s' -g $head fi fi