Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp751378ybg; Mon, 1 Jun 2020 13:30:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxcQN7o1ZF8VGioq00/AweQWgsYUpZ8pCgjfLHLtM/+vgKkf0vXHMnzNbGerVQoj5Jv+e5T X-Received: by 2002:aa7:d612:: with SMTP id c18mr24572926edr.282.1591043411820; Mon, 01 Jun 2020 13:30:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591043411; cv=none; d=google.com; s=arc-20160816; b=mwrXIzWgY13UgJEeIyJceysjQOVC4j/vZWVmowymJrXfHkOhvCJ5l686g3SqvKwPjk oHFcDt7ynT6ScwEA5Tv5rC0gLKpG6/7gzBeFsj+94gN3IjZfmJZ6HeTUKNLXmW+07eMS 0gxLQijM7C1NsnFVSaervk2NKclTMABK7JCjxXyQVAznebVHYsouyZ0lGxALpC9ZOBLj +Ie1fH0+q7840wowlTidgtO3WTJCIOZndLAxbwRdIvp3/iZAHnLPrAt0G6YG4Kgg6vWR i0H3krpPyg59PJ4AX9KwePV+aQCrs9SzFyDcex4dLTPSvHKVOQlA8rkj6hRk1FSymQGu 6fng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:cms-type:mime-version :user-agent:message-id:in-reply-to:date:subject:cc:to:from :dkim-signature:dkim-filter; bh=PDQg9D3HcC/RvEzGxrOVLnYHE3k+Zs1sSiqBViavFVg=; b=MHZG5X6oE6/vi/TB43iU5Pv1wcsdSI9IAibASE0D6lS/j5q+UVxAs7iIkxV3xU2d1r HDHayG2q0J7JKPnYGApw8Jfp0OFk3DzC+L9HYVGNPegbfNv0Ticv/q4KOzNn5HE2xLcb z7Q7S2OF8vR9hL9Rsd1Gq/KZ06lks9wMLWmaKtoDNXdoG1pVkVrgwuy+//7I0xxJqiwL e/siQ6r3uQFzqQm2gI1Ah5AeN+4PfB6aYToF413KrT+W77xIYcqY/JEzddpgvC8YdbRu CEts+2wIfEweqxyA3zQqNhNUg3qCDzXVEAuGMFNDBYTMRT4cYQOu/HNY84l40lsC1+NA g3RQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@samsung.com header.s=mail20170921 header.b="pl/Aw0Yc"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=samsung.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dt4si311141ejb.454.2020.06.01.13.29.48; Mon, 01 Jun 2020 13:30:11 -0700 (PDT) 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=@samsung.com header.s=mail20170921 header.b="pl/Aw0Yc"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=samsung.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728376AbgFAU2B (ORCPT + 99 others); Mon, 1 Jun 2020 16:28:01 -0400 Received: from mailout2.w1.samsung.com ([210.118.77.12]:51652 "EHLO mailout2.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727096AbgFAU2A (ORCPT ); Mon, 1 Jun 2020 16:28:00 -0400 Received: from eucas1p1.samsung.com (unknown [182.198.249.206]) by mailout2.w1.samsung.com (KnoxPortal) with ESMTP id 20200601202758euoutp022aaa10d0913830004adf5984972d1be3~UhW60jmpw1473614736euoutp02F; Mon, 1 Jun 2020 20:27:58 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 mailout2.w1.samsung.com 20200601202758euoutp022aaa10d0913830004adf5984972d1be3~UhW60jmpw1473614736euoutp02F DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=samsung.com; s=mail20170921; t=1591043278; bh=PDQg9D3HcC/RvEzGxrOVLnYHE3k+Zs1sSiqBViavFVg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pl/Aw0YcrKRI470p58IQrG8LkcDPfrdsxWT56zwTAnBX8y3lN0vIyy3hJUkZH6LBT bFhdbuwpD6Qsck+TSmVrILQFxMfYL5ap/vhUS/MFftUCDi3eU0DQClVJia1w0HCIv9 UQA1nJbiSHQCH9kDpa54rk6Kb6M2VEOHOUmMYxHM= Received: from eusmges1new.samsung.com (unknown [203.254.199.242]) by eucas1p2.samsung.com (KnoxPortal) with ESMTP id 20200601202758eucas1p2651c0d1a9494913ae9839daf3c19c8a6~UhW6c_R6S1505515055eucas1p27; Mon, 1 Jun 2020 20:27:58 +0000 (GMT) Received: from eucas1p2.samsung.com ( [182.198.249.207]) by eusmges1new.samsung.com (EUCPMTA) with SMTP id DE.09.61286.EC465DE5; Mon, 1 Jun 2020 21:27:58 +0100 (BST) Received: from eusmtrp1.samsung.com (unknown [182.198.249.138]) by eucas1p1.samsung.com (KnoxPortal) with ESMTPA id 20200601202757eucas1p11d380be9e0b2fe912a358d21e2d8dc2a~UhW5xIFUX1796617966eucas1p19; Mon, 1 Jun 2020 20:27:57 +0000 (GMT) Received: from eusmgms2.samsung.com (unknown [182.198.249.180]) by eusmtrp1.samsung.com (KnoxPortal) with ESMTP id 20200601202757eusmtrp17294f9403de7f243b5537780759d9702~UhW5wdgBc2812128121eusmtrp1L; Mon, 1 Jun 2020 20:27:57 +0000 (GMT) X-AuditID: cbfec7f2-f0bff7000001ef66-cf-5ed564ce0dce Received: from eusmtip2.samsung.com ( [203.254.199.222]) by eusmgms2.samsung.com (EUCPMTA) with SMTP id 74.A8.07950.DC465DE5; Mon, 1 Jun 2020 21:27:57 +0100 (BST) Received: from localhost (unknown [106.120.51.46]) by eusmtip2.samsung.com (KnoxPortal) with ESMTPA id 20200601202757eusmtip27fc9c7a39cc74f78ffa2c19285d5aa59~UhW5i52wu2351523515eusmtip2f; Mon, 1 Jun 2020 20:27:57 +0000 (GMT) From: Lukasz Stelmach To: Russell King - ARM Linux admin Cc: Masahiro Yamada , Nick Desaulniers , Thomas Gleixner , Enrico Weigelt , Kees Cook , Ingo Molnar , Ben Dooks , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, AKASHI Takahiro , Bartlomiej Zolnierkiewicz , Marek Szyprowski Subject: Re: [PATCH 3/5] arm: decompressor: define a new zImage tag Date: Mon, 01 Jun 2020 22:27:45 +0200 In-Reply-To: <20200601182555.GP1551@shell.armlinux.org.uk> (Russell King's message of "Mon, 1 Jun 2020 19:25:55 +0100") Message-ID: User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/26.1 (gnu/linux) MIME-Version: 1.0 Content-Type: multipart/signed; boundary="=-=-="; micalg="pgp-sha256"; protocol="application/pgp-signature" X-Brightmail-Tracker: H4sIAAAAAAAAA02SWUxTURCGOb1LL2jxWFFGXDBVE5cIGlyuC0bFh/toYuKCila5wUZaSK+I mBjgQaLIWlCkkshiFIssFmQTI6lElB2xBCIErQQRQVCWqKFVysHEt29m/vln5uRwlHKa8eI0 uouiXqcOVbFudPmrX62bWoKtQZv7LcA/uVPM8IaiWhnfHftMxjfd1PLmT50M31GdxfKWW88R X1jXK+c/fuhi+AJHA+LHUv7I+OkXv2i+1HyL2qcQOjrbKeFuTDst2E2DlJBtjhDMphus0NNZ wwrfWlrkQun9aCFlbIQVkspMSBg3rzw0L9BtT7AYqrkk6n33nnE7P9FbyoZ/X3c5o2QSxaBR 73jkygHeCq3J16l45MYpcT6C6sz7iAQTCPq/58lIMI7ANl4g+9fSF9c6V3iIIO7JYzkJPiNo 633DxCOOY7EPFBYec6IH3gVtCeucEgqPUNBut88aLcIBcO1R9yzTeC2kZqUzTnbFUTBgvTfL CrwDjNfy5U5ejHdC2WCfnOQXwpvMftrJFNZCZuvw7NqAczhIra5iyaYHwfLezhBeBEP1ZXLC y6ExLYF2Lgc4GtIM20lvAoLyrJ800eyGnpbfcz77wVpShYjeHbpGFpK57mAoz6BIWgHX45RE vQaKkmvmXLwgcSgfERbgd24pS54qEUFB8xSVglYZ/zvH+N85xhlbCq+H4mpfkt4ID3K+UoT9 oaholM5GjAl5ihGSNkSUtujESB9JrZUidCE+58K0ZjTzDxsd9T8q0eTbsxaEOaSaryjpexek ZNSXpCitBa2ZcbKVFLQhL1oXphNVHooDzY1BSkWwOuqKqA87rY8IFSULWsbRKk+FX+6XU0oc or4oXhDFcFH/ryrjXL1i0O3EqBMu2tFmc89TW+1zb3t8Xl12gHV1ZmDsgqsa01Vv6woX0W+Z 9rDxnP/DqUrlkaT58sHXbwPr9q1y+Kzn0hp0tm0ux6j6WmNTTuRLw1H8pfdzwxLd6iNLu/IH ypIE8WSFbVg66lAaTEZNRYXQNL222K9/rN6Rbj1eE64ZeK+ipfPqLRsovaT+C7XBr/OPAwAA X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFvrMIsWRmVeSWpSXmKPExsVy+t/xe7pnU67GGWxZoW6xccZ6VotJ6w4w Wdxs3M1kcaY712LT42usFpd3zWGzODR1L6PF2iN32S0ePrjBarH63ylGiw8T/jNZ/Nn/k8Vi 86apzA68HpevXWT2mN1wkcXj76oXzB4LNpV6bFrVyeZx59oeNo93586xe2xeUu8x4cNbNo++ LasYPT5vkgvgjtKzKcovLUlVyMgvLrFVija0MNIztLTQMzKx1DM0No+1MjJV0rezSUnNySxL LdK3S9DL+HJ3M1vBR42K6Ru+MjYwvpfvYuTkkBAwkbjfdp6pi5GLQ0hgKaPEuoZN7F2MHEAJ KYmVc9MhaoQl/lzrYoOoecoo8f3PeTaQGjYBPYm1ayNATBEBK4kLPRogJcwCD5klNl28yQLS KyzgLNG68iYTiC0kYCkx83AnM4jNIqAqMXHOFFYQm1OgUuLZ1flgNq+AucSs1hXsILYoUP2W F/fZIeKCEidnPgGbySyQLfF19XPmCYwCs5CkZiFJzQI6iVlAU2L9Ln2IsLbEsoWvmSFsW4l1 696zLGBkXcUoklpanJueW2ykV5yYW1yal66XnJ+7iREYyduO/dyyg7HrXfAhRgEORiUe3g33 r8QJsSaWFVfmHmJUARrzaMPqC4xSLHn5ealKIrxOZ0/HCfGmJFZWpRblxxeV5qQWH2I0Bfpz IrOUaHI+MPnklcQbmhqaW1gamhubG5tZKInzdggcjBESSE8sSc1OTS1ILYLpY+LglGpgPN33 ypPbUfjdFJfpHiZfFD787H8TmL17x/Mfsn3cyTpvFM19XlxrqTFoCulNWCJ+vyQnza16emy7 7ca/xlreynNd1JxSD+48dtY+TiZF9sCiuxfu5qtvvLE4SmJln3ZE8dTC+OzZjH/qO/gN17xd vakq8mtRI8Ovy+utbBkCSnTNHLiubrdUYinOSDTUYi4qTgQAnoD6vgYDAAA= X-CMS-MailID: 20200601202757eucas1p11d380be9e0b2fe912a358d21e2d8dc2a X-Msg-Generator: CA X-RootMTR: 20200601202757eucas1p11d380be9e0b2fe912a358d21e2d8dc2a X-EPHeader: CA CMS-TYPE: 201P X-CMS-RootMailID: 20200601202757eucas1p11d380be9e0b2fe912a358d21e2d8dc2a References: <20200601182555.GP1551@shell.armlinux.org.uk> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --=-=-= Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable It was <2020-06-01 pon 19:25>, when Russell King - ARM Linux admin wrote: > On Mon, Jun 01, 2020 at 06:19:52PM +0200, Lukasz Stelmach wrote: >> It was <2020-06-01 pon 15:55>, when Russell King - ARM Linux admin wrote: >> > On Mon, Jun 01, 2020 at 04:27:52PM +0200, =C5=81ukasz Stelmach wrote: >> >> Add DCSZ tag which holds dynamic memory (stack, bss, malloc pool) >> >> requirements of the decompressor code. >> > >> > Why do we need to know the stack and BSS size, when the userspace >> > kexec tool doesn't need to know this to perform the same function. >>=20 >>=20 >> kexec-tools load zImage as low in DRAM as possible and rely on two >> assumptions: >>=20 >> + the zImage will copy itself to make enough room for the kernel, >> + sizeof(zImage+mem) < sizeof(kernel+mem), which is true because >> of compression. >>=20 >> DRAM start >> + 0x8000 >>=20 >> zImage |-----------|-----|-------| >> text+data bss stack=20 >>=20 >> text+data bss=20=20=20 >> kernel |---------------------|-------------------| >>=20 >>=20 >> initrd |-initrd-|-dtb-| > > This is actually incorrect, because the decompressor will self- > relocate itself to avoid the area that it is going to decompress > into. I described the state right after kexec(8) invocation. > So, while the decompressor runs, in the above situation it > ends up as: > > > ram |------------------------------------------------------... > text+data bss=20=20=20 > kernel |---------------------|-------------------| > zImage |-----------|-----|-------| > text+data bss stack+malloc And I am trying to achieve this state before the decompressor starts so it won't need to copy itself during boot. The only exception is (as we discussed under a different patch) when edata_size >=3D 128-eps MiB because loading zImage above 128 MiB prevents it from properly detecting physical memory. In such unlikely case my code behaves like kexec-tools and loads zImage low. That is why I suggested that passing detailed information about memory layout to the decompressor would help. > Where "text+data" is actually smaller than the image size that > was loaded - the part of the image that performs the relocation > is discarded (the first chunk of code up to "restart" - 200 > bytes.) The BSS is typically smaller than 200 bytes, so we've > been able to get away without knowing the actual BSS size so > far. > > > ram |--|-----------------------------------------|---------... > |<>| TEXT_OFFSET > kernel |---------------------|-------------------| > |<----edata_size----->|<-----bss_size---->| > |<---------------kernel_size------------->| > zImage |-----------|-----|-------| > |<-------len------->| (initial) > |<----------len------------>| (final) > > The "final" len value is what the decompressor prints as the "zImage > requires" debugging value. > > Hence, the size that the decompressed kernel requires is kernel_size. > > The size that the decompressor requires is edata_size + len(final). > > Now, if you intend to load the kernel to ram + TEXT_OFFSET + edata_size > then it isn't going to lose the first 200 bytes of code, so as you > correctly point out, we need to know the BSS size. Formal note: can we keep using terms zImage and kernel as separate, where zImage is what is loaded with kexec and kernel is the decompressed code loaded at TEXT_OFFSET. I believe, it will help us avoid mistakes. >> >> +struct arm_zimage_tag_dc { >> >> + struct tag_header hdr; >> >> + union { >> >> +#define ZIMAGE_TAG_DECOMP_SIZE ARM_ZIMAGE_MAGIC4 >> >> + struct zimage_decomp_size { >> >> + __le32 bss_size; >> >> + __le32 stack_size; >> >> + __le32 malloc_size; >> >> + } decomp_size; > > You certainly don't need to know all this. All you need to know is > how much space the decompressor requires after the end of the image, > encompassing the BSS size, stack size and malloc size, which is one > value. I agree. However, since we are not fighting here for every single byte, I'd rather add them as separate values and make the tag, even if only slightly, more future-proof. Kind regards, =2D-=20 =C5=81ukasz Stelmach Samsung R&D Institute Poland Samsung Electronics --=-=-= Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQEzBAEBCAAdFiEEXpuyqjq9kGEVr9UQsK4enJilgBAFAl7VZMIACgkQsK4enJil gBBE6ggAmCX2V5lKQ4KXbFaOvSbxLjCzXxJrWedAUwBsVPrIewPmDaOEEn8oez4K nBhyDSFVNTbZhmGMMAf108/z2466ffTdQu3vzY1AuuJMk4PSPuLDEnbuq0HQoVAS tNemISFpAIsF8s1wqAqeOGznabyDh5mrFnnOMI5nv3s4PuUR8es5dUJSQQiXD9p8 a5qhixnQDLVc+k//jldAYjTmjr2ZU8c/m1OInGpQLcnb+e+nIK2FzKbjnAt7fsqw jiproC69Kt2Dsl8lYzop7pLDPFog/Cq3Iq8Mhb7RNf8BuvyUuXlBq44zXRKkoiVu 4QYGtReBJKCdmVAVxrbgQ0imEHfRLg== =E5A3 -----END PGP SIGNATURE----- --=-=-=--