From patchwork Thu Sep 7 21:40:10 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Simon Glass X-Patchwork-Id: 721320 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 088B1EC8759 for ; Thu, 7 Sep 2023 21:40:19 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238633AbjIGVkV (ORCPT ); Thu, 7 Sep 2023 17:40:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56610 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239094AbjIGVkU (ORCPT ); Thu, 7 Sep 2023 17:40:20 -0400 Received: from mail-il1-x12a.google.com (mail-il1-x12a.google.com [IPv6:2607:f8b0:4864:20::12a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 86950E47 for ; Thu, 7 Sep 2023 14:40:16 -0700 (PDT) Received: by mail-il1-x12a.google.com with SMTP id e9e14a558f8ab-34df502d238so5995945ab.0 for ; Thu, 07 Sep 2023 14:40:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; t=1694122815; x=1694727615; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=uuNfNRXcT/k9V+ptR/yNdUXnw9b7b9R/vB+EyNk6U1Q=; b=DUcnESjB2G4a+r+kZyaMIL95itY3jFk9Xf2wUH31Wsb1CWuNuPD5M/TeOL/9MsS/Mn fXDSD7la8pGixY+KDfBy9uawuatiDHbuPm03RI2uQMrEjGoeizcLIwJDF+/4ZPnKjfgy VwR0caEPZOy1ONn6sfKEGK0JbfqKfdCpr/ItQ= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1694122815; x=1694727615; 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=uuNfNRXcT/k9V+ptR/yNdUXnw9b7b9R/vB+EyNk6U1Q=; b=WHxxFoQCrr96Ph+3lQyMmS8GJ7Jvt99E3rzXZp4yYRvuA+R/1cvt8abkuqMJv/Wk9I BpLXhKbzB4J0hmtJDIEszlj6Re9mQagqNki55ZzQ4QRB6W+iRMmdlECubdux0Rkogml3 2NZXlPqi2oAlgzY9xcvStjgMKDzcttqWBEbCv9uHWyOZA9helZ1cSZSm+LKM1LcH3Nqt e27HXKWCMpJZx6VwcHmYOGwi305QKXbBpCnZbz+/ySp8r/0NH7QMEnQsLiBEFE3B0b9p fZXmBhK+5CtLG7qVHl17c4r6RR64RcRmuWS/MbefjFmzgL3RBIgGEUAcDWiJBbjr/LBo okeQ== X-Gm-Message-State: AOJu0YxZF6kzT2Blr7wzIikJBDUXS8yJMNdTLlqHt9+nxlnQ/XaXN3gT QQxnbDD6qkp0qlOUjQf3TCVpBihL2MoDTT6iS79VLw== X-Google-Smtp-Source: AGHT+IHDLp8Ggcfk51qBwQHePnX3O5h7/52QV2/g5gnYYMU/kivj6AJyv0nmeNnWNBadoPNLcyCjng== X-Received: by 2002:a92:d44c:0:b0:349:8a8b:70ca with SMTP id r12-20020a92d44c000000b003498a8b70camr1055691ilm.14.1694122815649; Thu, 07 Sep 2023 14:40:15 -0700 (PDT) Received: from sjg1.lan (c-73-243-118-188.hsd1.co.comcast.net. [73.243.118.188]) by smtp.gmail.com with ESMTPSA id x14-20020a92d30e000000b00348edca2abesm72006ila.47.2023.09.07.14.40.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 Sep 2023 14:40:15 -0700 (PDT) From: Simon Glass To: devicetree@vger.kernel.org Cc: Dhaval Sharma , Guo Dong , U-Boot Mailing List , Yunhui Cui , Chiu Chasel , Mark Rutland , linux-acpi@vger.kernel.org, Rob Herring , Maximilian Brune , Ard Biesheuvel , Tom Rini , Lean Sheng Tan , Gua Guo , ron minnich , Simon Glass Subject: [PATCH v6 1/2] schemas: Add some common reserved-memory usages Date: Thu, 7 Sep 2023 15:40:10 -0600 Message-ID: <20230907214012.74978-1-sjg@chromium.org> X-Mailer: git-send-email 2.42.0.283.g2d96d420d3-goog MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org It is common to split firmware into 'Platform Init', which does the initial hardware setup and a "Payload" which selects the OS to be booted. Thus an handover interface is required between these two pieces. This aims to provide an small schema addition for the memory mapping needed to keep these two pieces working together well. Signed-off-by: Simon Glass --- Changes in v6: - Drop mention of UEFI - Use compatible strings instead of node names Changes in v5: - Drop the memory-map node (should have done that in v4) - Tidy up schema a bit Changes in v4: - Make use of the reserved-memory node instead of creating a new one Changes in v3: - Reword commit message again - cc a lot more people, from the FFI patch - Split out the attributes into the /memory nodes Changes in v2: - Reword commit message .../reserved-memory/common-reserved.yaml | 71 +++++++++++++++++++ 1 file changed, 71 insertions(+) create mode 100644 dtschema/schemas/reserved-memory/common-reserved.yaml diff --git a/dtschema/schemas/reserved-memory/common-reserved.yaml b/dtschema/schemas/reserved-memory/common-reserved.yaml new file mode 100644 index 0000000..4889f59 --- /dev/null +++ b/dtschema/schemas/reserved-memory/common-reserved.yaml @@ -0,0 +1,71 @@ +# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/reserved-memory/common-reserved.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Common memory reservations + +description: | + Specifies that the reserved memory region can be used for the purpose + indicated by its compatible string. + + Clients may reuse this reserved memory if they understand what it is for, + subject to the notes below. + +maintainers: + - Simon Glass + +allOf: + - $ref: reserved-memory.yaml + +properties: + compatible: + description: | + This describes some common memory reservations: + + acpi-reclaim: Contains ACPI tables; memory may be reclaimed when the + tables are no-longer needed + acpi-nvs: Contains ACPI Non-volatile-storage data; memory may be + reclaimed when the tables are no-longer needed + boot-code: Contains code used for booting; memory may be reclaimed by + the OS when it is running + boot-code: Contains data used for booting; memory may be reclaimed by + the OS when it is running + runtime-code: Contains code used for interacting with the system when + running; memory may be reclaimed if this code is not called + runtime-data: Contains data used for interacting with the system when + running; memory may be reclaimed if the runtime code is not used + enum: + - acpi-reclaim + - acpi-nvs + - boot-code + - boot-data + - runtime-code + - runtime-data + + reg: + description: region of memory that is reserved for the purpose indicated + by the compatible string. + +required: + - reg + +unevaluatedProperties: false + +examples: + - | + reserved-memory { + #address-cells = <1>; + #size-cells = <1>; + + reserved@12340000 { + compatible = "boot-code"; + reg = <0x12340000 0x00800000>; + }; + + reserved@43210000 { + compatible = "boot-data"; + reg = <0x43210000 0x00800000>; + }; + };