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: 720650 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 7F8C4EC875B for ; Thu, 7 Sep 2023 21:40:18 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236616AbjIGVkV (ORCPT ); Thu, 7 Sep 2023 17:40:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56598 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238633AbjIGVkU (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 408B3B4 for ; Thu, 7 Sep 2023 14:40:16 -0700 (PDT) Received: by mail-il1-x12a.google.com with SMTP id e9e14a558f8ab-34ca1aadcccso5891365ab.3 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=S41CyzQy8xpxW+gaNik0SXzMarta2gQsmOch5gqT8SHeiY/ogGW7PlDwtUJtMHIvBo zt6S3BNXFK5xoAPjQcmOGBcUQh0lmffoqLeuDYOg3rMZDRlSRY8Hz+32vS0fZI3+4t1m xvt6OfTdgQFI0wzfVdiS0AkEQ8jIAlta1+vYlsHfwKSRnzAvwNE9VYbStUdsaK4Y0ZZM RrLHLdk95TOkiyweUyAINo2YMxDAhmSHKzhcSD+k58gZ4wsrpfQdwUu03zPbf93vlwes DrUgDiGunU8AXXraP3hnG1O/GJquAmrV2ryZ0nuDpe4N8EzA/Vkok7IqaGA6wzhGRNL/ 5pNA== X-Gm-Message-State: AOJu0YzAMKsFGiNEoS98QOMXU43L9/7tup705Wx9ZLkzrDsV8j10Fabe o18cWnyzl5A7Fi/A5ABphQEohQ== 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: linux-acpi@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>; + }; + }; From patchwork Thu Sep 7 21:40:11 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Simon Glass X-Patchwork-Id: 721131 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 0E5FBEC875B for ; Thu, 7 Sep 2023 21:40:22 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239675AbjIGVkY (ORCPT ); Thu, 7 Sep 2023 17:40:24 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56612 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239094AbjIGVkV (ORCPT ); Thu, 7 Sep 2023 17:40:21 -0400 Received: from mail-il1-x12c.google.com (mail-il1-x12c.google.com [IPv6:2607:f8b0:4864:20::12c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C42E31BD2 for ; Thu, 7 Sep 2023 14:40:17 -0700 (PDT) Received: by mail-il1-x12c.google.com with SMTP id e9e14a558f8ab-34ca1bcb48fso5502065ab.2 for ; Thu, 07 Sep 2023 14:40:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; t=1694122817; x=1694727617; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=b5daRRTdLNlkY+bK37VVR4v3WldsBabAY6GSX8MwLbs=; b=OyHT13bXBPctSXjNAl3OPDab+bC4pZcxqmpQSrIhCcnms4Q/6xZslH2mCIu18Y2B88 gIMYlOKZwBIqs+J4s9Tuyg50W0gq1o4pGmgG22MfvpqiVVEVKZgUjI6NLELZGdbosczf 6RoVT7/ihB0VLbbdHcFMBx14PUAZu1RMRWC/A= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1694122817; x=1694727617; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=b5daRRTdLNlkY+bK37VVR4v3WldsBabAY6GSX8MwLbs=; b=OU0dk3U1eUZrVuHWwVbkBr/ZPsKM5xKWU0gKJjxnJe1121WCZ7frYuT7MW+4YaPjUY rp1Je/34TIkQS7ikKfkriMjnF6Io6AvGiFmwyGHl6wRX3ugwDjfnzehkGbxBMUPwp6/U vNfAuUH/s0fERgEewyKDY06k9fmawg40Pd2JtZYry6r3Rp2GjWbTOWfSO39iNfRBohyP 9zykJ8xeqB4wvVFP3c1Xv5iljBFpO0dLLahsV4SQSkr4aF4weAlJkKac/HOgz6f6rcws XSSzDZp5JcgEUa1tVVIX3I43f97Lof0s2Z/WLMfVi5IvL20XxYF4SsNGd5N/ifJJO37X xzbw== X-Gm-Message-State: AOJu0YxLgpxmSP6zFDgMnF+BloXXzwWbdzFU9egJPnXwAN3d3dGK2p/o MMMyww2qoOGx12wTV+fvkURZIg== X-Google-Smtp-Source: AGHT+IEOo9i8+AV7SDMWoVUID/hLd8I+L2Kc4qthbyfM9QnHCrPKzqJp7ucAuhasGZkxp4mk+KwwGw== X-Received: by 2002:a05:6e02:219b:b0:34a:c751:28ca with SMTP id j27-20020a056e02219b00b0034ac75128camr1176329ila.15.1694122817229; Thu, 07 Sep 2023 14:40:17 -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.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 Sep 2023 14:40:17 -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 2/2] schemas: memory: Add ECC properties Date: Thu, 7 Sep 2023 15:40:11 -0600 Message-ID: <20230907214012.74978-2-sjg@chromium.org> X-Mailer: git-send-email 2.42.0.283.g2d96d420d3-goog In-Reply-To: <20230907214012.74978-1-sjg@chromium.org> References: <20230907214012.74978-1-sjg@chromium.org> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-acpi@vger.kernel.org Some memories provide ECC detection and/or correction. For software which wants to check memory, it is helpful to see which regions provide this feature. Add this as a property of the /memory nodes, since it presumably follows the hardware-level memory system. Signed-off-by: Simon Glass --- Changes in v6: - Use a number of bits instead of a string property - Fix inidcates typo Changes in v5: - Redo to make this property specific to ECC - Provide properties both for detection and correction Changes in v3: - Add new patch to update the /memory nodes dtschema/schemas/memory.yaml | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/dtschema/schemas/memory.yaml b/dtschema/schemas/memory.yaml index 1d74410..1a48b1c 100644 --- a/dtschema/schemas/memory.yaml +++ b/dtschema/schemas/memory.yaml @@ -31,10 +31,21 @@ patternProperties: numa-node-id: $ref: types.yaml#/definitions/uint32 - description: + description: | For the purpose of identification, each NUMA node is associated with a unique token known as a node id. - + ecc-detection-bits: + default: 0 + description: | + If present, this indicates the number of bits of memory error which + can be detected and reported by the Error-Correction Code (ECC) memory + subsystem (typically 0, 1 or 2). + ecc-correction-bits: + default: 0 + description: | + If present, this indicates the number of bits of memory error which + can be corrected by the Error-Correction Code (ECC) memory subsystem + (typically 0, 1 or 2). required: - device_type