From patchwork Wed Dec 11 10:54:41 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Ilias Apalodimas X-Patchwork-Id: 849139 Delivered-To: patch@linaro.org Received: by 2002:a05:6000:2c4:b0:385:e875:8a9e with SMTP id o4csp244770wry; Wed, 11 Dec 2024 02:55:14 -0800 (PST) X-Forwarded-Encrypted: i=2; AJvYcCVXdp6TSA3LXCMYzKM3S2gOEQdYwJATE7q0JwVE9pB/cTLx5/M3PKyPW+arVkbxXjqR0Zvxlg==@linaro.org X-Google-Smtp-Source: AGHT+IGhyLvoVzSWNHEi4ueU1aq/NxEByUR2ujCkc2eLewbkF1YP8Ze/Gan/78AZfNLmv+ruk4Bo X-Received: by 2002:a05:6402:234f:b0:5d0:e7a0:154a with SMTP id 4fb4d7f45d1cf-5d4331b182dmr2041085a12.8.1733914514650; Wed, 11 Dec 2024 02:55:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1733914514; cv=none; d=google.com; s=arc-20240605; b=NbfcjNgNdx2HQmmb+5Q2mMEznrt4cTjluAvzHTCO+88j4Gb7cMUtmgqxgfLoskyBke L67doZpppPxhofNYEn8MO3upBiGTeSpIPP6xR0NFBHTHCjisa7rytgAP0mwcKeNGf1J0 PFXhj7gQ43mUwGDBjDriLt8iTQFgv9qW56xWDhg8P8zsSDBJINLjp5JtCkwQP5Va01YT Lp1aurfE5DbNVhwlMj/RNyVW2viSsnIDbh4YkNwQnpNivWXvg6DAaHDkif6DeuwfuRCU 7Daq1HCkmVUSzQWrzW3xeQZhlbmiu+KIE9AS8sJu3YfboYFkfOv3AzpvCdo0puMghHZB eApA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20240605; h=sender:errors-to:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:message-id:date:subject:cc:to:from:dkim-signature; bh=oVS5maf9KllNKx/w3oCMP5752UFQu5gJ/SlM1/qiCQU=; fh=f9tdQ2juWlSAOYGdDU8hnmZIbIW5yqBvGTazyfZEwl8=; b=kgT8tGcS790uugVDZdA2wtuTAV1lxKj4Mhpli2S1ymWtVe23gLc1SAkXq2/QZizxR/ pRMdI9Y+OB+XdI3L8pQQNFwZxFntdDIMYEefSQddtZieMtA8kwEtHYWk056piF0aEGGY 3erDyyHmzKFzbM3UJmfPhbKrakLFiY8vjkafhDlN/S/xyEM2apH9zjf3NNNIRnzHyJzF zm1VpzKRXhzrd6i8eW3vz7009wQp2CED/9q2//VIEXGzacwNtBIcTqnK8hIkREdmCXqf mJESvk3huwRcBbmzJcKTIF0MSyaLltfLYXj4MzFDIQjfbYrjAxvfesa6iEICZqPPwJnm 0VRQ==; dara=google.com ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=W3cyjZvM; spf=pass (google.com: domain of u-boot-bounces@lists.denx.de designates 2a01:238:438b:c500:173d:9f52:ddab:ee01 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org; dara=neutral header.i=@linaro.org Return-Path: Received: from phobos.denx.de (phobos.denx.de. [2a01:238:438b:c500:173d:9f52:ddab:ee01]) by mx.google.com with ESMTPS id 4fb4d7f45d1cf-5d3c018f57dsi8403306a12.400.2024.12.11.02.55.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 11 Dec 2024 02:55:14 -0800 (PST) Received-SPF: pass (google.com: domain of u-boot-bounces@lists.denx.de designates 2a01:238:438b:c500:173d:9f52:ddab:ee01 as permitted sender) client-ip=2a01:238:438b:c500:173d:9f52:ddab:ee01; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=W3cyjZvM; spf=pass (google.com: domain of u-boot-bounces@lists.denx.de designates 2a01:238:438b:c500:173d:9f52:ddab:ee01 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org; dara=neutral header.i=@linaro.org Received: from h2850616.stratoserver.net (localhost [IPv6:::1]) by phobos.denx.de (Postfix) with ESMTP id 5C660801EB; Wed, 11 Dec 2024 11:55:13 +0100 (CET) Authentication-Results: phobos.denx.de; dmarc=pass (p=none dis=none) header.from=linaro.org Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Authentication-Results: phobos.denx.de; dkim=pass (2048-bit key; unprotected) header.d=linaro.org header.i=@linaro.org header.b="W3cyjZvM"; dkim-atps=neutral Received: by phobos.denx.de (Postfix, from userid 109) id D9AFF801F0; Wed, 11 Dec 2024 11:55:12 +0100 (CET) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on phobos.denx.de X-Spam-Level: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_BLOCKED, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.2 Received: from mail-ej1-x62f.google.com (mail-ej1-x62f.google.com [IPv6:2a00:1450:4864:20::62f]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits)) (No client certificate requested) by phobos.denx.de (Postfix) with ESMTPS id 1FFD8801EA for ; Wed, 11 Dec 2024 11:55:10 +0100 (CET) Authentication-Results: phobos.denx.de; dmarc=pass (p=none dis=none) header.from=linaro.org Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=ilias.apalodimas@linaro.org Received: by mail-ej1-x62f.google.com with SMTP id a640c23a62f3a-aa662795ca3so110157366b.1 for ; Wed, 11 Dec 2024 02:55:10 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1733914509; x=1734519309; darn=lists.denx.de; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=oVS5maf9KllNKx/w3oCMP5752UFQu5gJ/SlM1/qiCQU=; b=W3cyjZvM5mBhWex2sxKaAU7qkY38GRkrnmURWUEHJSQSms6pzZE70zeuCDLMD0TR7O R26KcNPO/pXzC84XT/xrW4HHDyTFoQI+Q8ftY+bjZ2f9VtmeycA0bZ4UXhIDkaibuDE3 cSmEwbz4iS6dAgz2zS8SGggSn1PUaIoU44hudVlVR+koIRMQv5XQCV1U8DgQIDnXQ70H yNg8VcbimspKbpuWh5DDmdm87jNb3r0lfarWSfiiM6pg1vZmh6RDc0e94ekei0VirqDA hZRkMiEEp0kPcJCABD4wZix0kL3vG8Q9tLcmTGE6fXxNqZm5rVpOQ9AkJf2bGeEMtLsx plPA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1733914509; x=1734519309; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=oVS5maf9KllNKx/w3oCMP5752UFQu5gJ/SlM1/qiCQU=; b=fryvq0XYAxfAofyYwdPsjOTjn0PSM4YZcg6V6YOsNFRurKAnNlOZbua80MNRUTMG0R U+fOGxwEoccntQuf2Wo8wLPOOrr0oKydKDD8/ktdGE2lkpm/8Ta0b15EObyIURMjCes7 Ao30mZ1FH5AH+OOyqMasYV6YLQIoARneB9z1fC7pxqTdreKUkoWXtGmM3DQ3vrNl4hb8 pLxVJx8WHk3z8e1VPHW14Censx/41oRkmaw/19hLJw5MWJdIQfFYDQDAuBBtK/jFkEV+ pw2m5UpCl+CYkrF1x/GYJQ8CXo0elJ8z4NrZQpQJVZZjjFLvJm7Gn4UyDt2vIqS3tNf+ 5ovw== X-Forwarded-Encrypted: i=1; AJvYcCWgQXJ0TFa8EA6mkjqmpZ5J78FZpZWVUPt5XztQuxE1ZLxyplsyaCoNy4VC/SnbJgamM3foGEw=@lists.denx.de X-Gm-Message-State: AOJu0YzkCaT+srZc6dlnE23UvvR7klRxk68eCRAnEHTk0jV5jBSZOzE8 rRZnNf7IEmYYJFqfUN00p8i0zyjWyG217/LLFazMRqPj48i+eIosfDI8B29zkaA= X-Gm-Gg: ASbGncuCFWa9Vjy7K5CowPSwrxPEU9Akc2yAurZPWPzz43aCa6v3L6qXVDRBDY3XVYP xYfy/OIeloj7/lXdh66ko1OAgHEQTez3M1eNCfaFUpMD6eHh/d5DGKaFljq6kow575ilC5JDiJp 273AMlEVnRGIQt0WHe1RlBcAXmaeKRYjkoJupFpiXPLgNsII4aw8aBFCKst7yHMh5OoJOsHRAkC s3jg6zz0KmwbGmM/czDa1oS+U35IJV1LrXO1Eo/TVJn2o+Af4KvAKIWx6BGQum5s14T1vwdH8Ej 3xUtEtunCemAndcHhT50161gqAAqmd4= X-Received: by 2002:a17:907:94cc:b0:aa5:b1bb:10db with SMTP id a640c23a62f3a-aa6b15555cemr143274966b.1.1733914509501; Wed, 11 Dec 2024 02:55:09 -0800 (PST) Received: from localhost.localdomain (ppp176092181030.access.hol.gr. [176.92.181.30]) by smtp.gmail.com with ESMTPSA id a640c23a62f3a-aa67e652b1dsm508006566b.172.2024.12.11.02.55.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 11 Dec 2024 02:55:08 -0800 (PST) From: Ilias Apalodimas To: xypron.glpk@gmx.de, trini@konsulko.com Cc: Ilias Apalodimas , =?utf-8?q?Marek_Beh?= =?utf-8?q?=C3=BAn?= , Marek Vasut , Sughosh Ganu , Simon Glass , Mattijs Korpershoek , Peter Korsgaard , Roman Stratiienko , Laurent Pinchart , Matthias Schiffer , Dario Binacchi , AKASHI Takahiro , Baruch Siach , Nam Cao , Sam Protsenko , Janne Grunau , Caleb Connolly , u-boot@lists.denx.de Subject: [PATCH v1 0/8] Cleanup the LMB subsystem Date: Wed, 11 Dec 2024 12:54:41 +0200 Message-ID: <20241211105504.453234-1-ilias.apalodimas@linaro.org> X-Mailer: git-send-email 2.45.2 MIME-Version: 1.0 X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.39 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" X-Virus-Scanned: clamav-milter 0.103.8 at phobos.denx.de X-Virus-Status: Clean Hi all, This is v1 of the rfc [0] The LMB subsystem was used opportunistically for a number of years. A while back Sughosh merged it with the EFI subsystem in order to have a common allocator and avoid subsystems overwriting memory they shouldn't. This is an initial cleanup of all the crud we gathered over the years. There's no functional change expected from the patches as they just cleanup some abstraction functions and rename a few variables to make more sense. I plan to make even bigger changes -- e.g I don't see the point of having *_alloc() and *_reserve() versions of the functions since they mostly do the same thing and just cause confusion. lmb_alloc_addr_flags() returning the base address on success makes little sense since we already *request* the address on the function arguments, etc. Since this patchset grew enough already, I'd like to get it in before more refactoring happens. It's worth noting that although some patches slightly increase the code size due to an extra flags argument being carried around, the final result is eventually smaller. # qemu_arm64_lwip_defconfig (version string adds another 20b) add/remove: 0/5 grow/shrink: 15/1 up/down: 568/-628 (-60) Function old new delta lmb_alloc_base 80 324 +244 lmb_alloc_addr 8 144 +136 lmb_reserve 8 96 +88 version_string 50 70 +20 boot_relocate_fdt 488 508 +20 boot_ramdisk_high 268 284 +16 lmb_add_region_flags 696 704 +8 boot_fdt_reserve_region 100 108 +8 load_serial 548 552 +4 lmb_alloc 8 12 +4 image_setup_libfdt 368 372 +4 do_load 728 732 +4 do_bootz 332 336 +4 do_booti 520 524 +4 bootm_run_states 2176 2180 +4 lmb_alloc_addr_flags 4 - -4 boot_fdt_add_mem_rsv_regions 284 280 -4 lmb_alloc_base_flags 76 - -76 lmb_reserve_flags 96 - -96 _lmb_alloc_addr 144 - -144 _lmb_alloc_base 304 - -304 Total: Before=1020102, After=1020042, chg -0.01% # sandbox_defconfig (version string adds another 20b) add/remove: 0/3 grow/shrink: 24/3 up/down: 523/-501 (22) Function old new delta lmb_alloc_base 48 299 +251 lmb_alloc_addr 4 92 +88 lmb_reserve 4 58 +54 test_alloc_addr 2933 2963 +30 version_string 50 70 +20 lib_test_lmb_overlapping_reserve 1018 1030 +12 lmb_add_region_flags 600 610 +10 test_multi_alloc.constprop 3034 3042 +8 test_get_unreserved_size 1032 1038 +6 boot_relocate_fdt 599 605 +6 boot_fdt_reserve_region 67 73 +6 lmb_alloc 4 9 +5 lmb_free_flags 190 194 +4 wget_handler 1530 1533 +3 tftp_handler 1190 1192 +2 test_noreserved 1207 1209 +2 test_bigblock 911 913 +2 load_serial 946 948 +2 lib_test_lmb_flags 2101 2103 +2 do_spi_flash 3150 3152 +2 do_bootz 526 528 +2 do_bootm_linux 2067 2069 +2 bootm_run_states 5275 5277 +2 _fs_read.lto_priv 331 333 +2 lmb_dump_region.lto_priv 356 353 -3 lmb_add 59 52 -7 efi_allocate_pages.part 303 249 -54 lmb_reserve_flags 65 - -65 _lmb_alloc_addr.lto_priv 92 - -92 _lmb_alloc_base.lto_priv 280 - -280 Total: Before=2492722, After=2492744, chg +0.00% [0] https://lore.kernel.org/u-boot/20241208105223.2821049-1-ilias.apalodimas@linaro.org/T/#m43927af3f758f8d0be897a8a6c77b4325546afd5 Changes since v1: - Rebased on top of https://lore.kernel.org/u-boot/20241211021703.2333-1-semen.protsenko@linaro.org/ https://lore.kernel.org/u-boot/20241211022550.2995-1-semen.protsenko@linaro.org/ - Converted enum lmb_flags to a u32 - Removed the _flags from all the functions - Added a patch that removes lmb_align_down() - Picked up r-b tags. Tom I kept your on patch #3 since I only changed the name of the function and assumed you are ok with it. Ilias Apalodimas (8): lmb: Remove lmb_align_down() lmb: Move enum lmb_flags to a u32 lmb: Remove lmb_reserve_flags() lmb: Rename free_mem to available_mem lmb: Remove lmb_add_region() lmb: Remove lmb_alloc_addr_flags() lmb: Remove lmb_alloc_base_flags() lmb: Rename _lmb_alloc_addr() to lmb_alloc_addr_flags() arch/powerpc/cpu/mpc85xx/mp.c | 2 +- arch/powerpc/lib/misc.c | 2 +- boot/bootm.c | 3 +- boot/image-board.c | 20 +++-- boot/image-fdt.c | 15 ++-- cmd/booti.c | 2 +- cmd/bootz.c | 2 +- cmd/load.c | 2 +- fs/fs.c | 2 +- include/lmb.h | 58 ++++++--------- lib/efi_loader/efi_memory.c | 6 +- lib/lmb.c | 136 +++++++++++----------------------- test/cmd/bdinfo.c | 4 +- test/lib/lmb.c | 92 +++++++++++------------ 14 files changed, 145 insertions(+), 201 deletions(-) Tested-by: Sam Protsenko --- 2.45.2