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>; + }; + }; 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: 720687 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 E820EEC8759 for ; Thu, 7 Sep 2023 21:40:21 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239586AbjIGVkX (ORCPT ); Thu, 7 Sep 2023 17:40:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56624 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239675AbjIGVkV (ORCPT ); Thu, 7 Sep 2023 17:40:21 -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 DB38D1BD6 for ; Thu, 7 Sep 2023 14:40:17 -0700 (PDT) Received: by mail-il1-x12a.google.com with SMTP id e9e14a558f8ab-34f2d7c1bc8so5528985ab.1 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=wlzv9/x/QD9zruI03jNv84y6edk327u26ybSF9gDetO28NGQgQC7B/Ckwbmu1ihYEk K2dNDx0/QrdKFHOEP3xsjpcd5VoAYYA0tZJrRDkSsn7+ZFe8ME5gX2mkBF6SJqfA7O3J 0ZeP/zdk93XlqN2+6vtK8ILuOP8eWnNgsTdhyWH0A08VAJFP64W+biML2iFhLUnYpjeN VvbdVecpGmjvWZ58wZGnO68eMfqlCxFy86hEx4xwQnI/g6d9ANC7+DvA15gQNiEm+Wb0 LoFJIWeDloF0cAYckrodvBXOupzR3zKK9auG6TI2MtjriWGHmf6RBIzqU2/F21J2jBfe jJTA== X-Gm-Message-State: AOJu0YxBuZ3ukZn96T18Rtp6WgZZO0hOp4MGIPBbP0Eug28DIj/YxZun o1pAtDYx81Iu7w7D9KAUr0CJzszWsfKIvKRCz5peeQ== 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: devicetree@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