Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp5359452ybi; Wed, 12 Jun 2019 00:55:51 -0700 (PDT) X-Google-Smtp-Source: APXvYqy0DDZkZAWMjFSZWwDbOuDtzndFm/0cY2kU7LBAMoVl7o9Wsd9+VcnIYs3/MFEnJrd/tjYJ X-Received: by 2002:a65:62cc:: with SMTP id m12mr23939600pgv.237.1560326151176; Wed, 12 Jun 2019 00:55:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560326151; cv=none; d=google.com; s=arc-20160816; b=t9Z4Yp0Clu45DBWjPaq/+j7NEnIYLPE7G0AFHxOMo8pA41rg5lWzuWTSjaoD155bh1 nr0zLnOo5Ge4k3f7MO12zD1zwCBN0c62x6WOGqOV15DaYtKddIHXf9ABnMcvf8dJKqPK ou7EuvViIHK4v3eSJFN9VzjuNAC1jBWubwCkqhmXjdTEpdM8yMpUcSG+1jgeURIXiMNG Z939BmLYeDZkvzH/W9MWc3Gpp+Yf2SgP8pk9CxPrLfROGqORqL3DYvQvhId0fsU9ueOp li7/YdY8UZnfgF+x0wdD/XhbuarCjTKbgy93Dy/T/7bzdxX8gOwh00+94i9Bu8q/Yma1 2Y6g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=FXV5Ws8+r5RPo/nKXnoHiLtGYbtFqiKOKRPXyhCi7kk=; b=PO/l6ilixLvWGtxNgwnFO+kqSiU5Rd5oLekIIlW3VJ4zYSSD/xtxiMvEKzzSPUe7/w ozga5kJZd/TrqIZU9vd8WJ/K6uY5Y1uEaGQh2vh5ni6dn/dshfyepEsH5UY2wpXU6Z1L Mccyqlhq6OD4Om4GuRHpDqSq4UPNY+KjToWCgJMaee5q8ewefM58wv6Lfh+09flgRMcA OOI5xmqB/1A63vLZIseldpujux/dy10aNjT1Hvu0Dv5TAYmwWvUC3Z3pZNWVlAW8lJsr fnmYyspceZwRjVHvbeR6+0E+p8zzOSQzIdP6JzJmXLeVylHK+RzyN3ATCAtK3OF/ojOj ry4Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=WF6XEcrj; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d3si4685029pju.69.2019.06.12.00.55.31; Wed, 12 Jun 2019 00:55:51 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=WF6XEcrj; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729786AbfFLEel (ORCPT + 99 others); Wed, 12 Jun 2019 00:34:41 -0400 Received: from mail-pl1-f194.google.com ([209.85.214.194]:38796 "EHLO mail-pl1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729755AbfFLEel (ORCPT ); Wed, 12 Jun 2019 00:34:41 -0400 Received: by mail-pl1-f194.google.com with SMTP id f97so6074401plb.5 for ; Tue, 11 Jun 2019 21:34:41 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=FXV5Ws8+r5RPo/nKXnoHiLtGYbtFqiKOKRPXyhCi7kk=; b=WF6XEcrjnYm/TJx+cI4M997rrpyH1cFTH/f3AQedIs7pSSTy79gf+vaznSHQIU0Ezg ayYK7Azudp1Y8gy7eeukeYwME2A85H/PSOe3OM5sjWoSvbRQ/iRC3xvytM4I2hRtcL0H 2zFtgHFPl3zJ4Q+z9IKlwaWjBy24AtA4JKSR4= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=FXV5Ws8+r5RPo/nKXnoHiLtGYbtFqiKOKRPXyhCi7kk=; b=BPxr+ncclYVVcsSLxGHXVLunQiPwgUliyvV8WBu1c4J5ACA8Hxt9fjVHqwYI8ghqsa j9Td2z0eUygvzPOhmoberRNFrF43fB0+Yw1Wff+Txu/x2hkLDd4qj2uZXY1dPDG+RTm/ xm20nAvu3YTYDDT7ROw8zzV5NhR/7vMtde1y5/zlTcGa2G+/d/08Gx4Zu3ad11/FIUk5 BlhrnDjjNMaA/1DgWlWGc5a6tBCybMIEcd8sy1RdhlSCLNpSpZt3b1bdLGXe33ffuSOe TJCbq8M3GyoMKtID9G1xyiJQn0ux9MVyFHE1/Td2NcRXzZhe7fb7SIlo2tb1HL8NJIGL L0+w== X-Gm-Message-State: APjAAAU6rx/q9E17GFo2jt6XepQYpbpIGTnpD/MwvfkayrEMxsVScuJP mcmozfcvcJYm+JP3c4qeC5uQSQ== X-Received: by 2002:a17:902:b705:: with SMTP id d5mr44143880pls.274.1560314080888; Tue, 11 Jun 2019 21:34:40 -0700 (PDT) Received: from hsinyi-z840.tpe.corp.google.com ([2401:fa00:1:10:b852:bd51:9305:4261]) by smtp.gmail.com with ESMTPSA id k8sm15285998pfi.168.2019.06.11.21.34.37 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Tue, 11 Jun 2019 21:34:40 -0700 (PDT) From: Hsin-Yi Wang To: linux-arm-kernel@lists.infradead.org Cc: Rob Herring , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Frank Rowand , Catalin Marinas , Will Deacon , Andrew Morton , Mike Rapoport , Ard Biesheuvel , Miles Chen , Hsin-Yi Wang , James Morse , Andrew Murray , Mark Rutland , Jun Yao , Yu Zhao , Robin Murphy , Laura Abbott , Stephen Boyd , Kees Cook Subject: [PATCH v6 2/3] fdt: add support for rng-seed Date: Wed, 12 Jun 2019 12:33:00 +0800 Message-Id: <20190612043258.166048-3-hsinyi@chromium.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190612043258.166048-1-hsinyi@chromium.org> References: <20190612043258.166048-1-hsinyi@chromium.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Introducing a chosen node, rng-seed, which is an entropy that can be passed to kernel called very early to increase initial device randomness. Bootloader should provide this entropy and the value is read from /chosen/rng-seed in DT. Signed-off-by: Hsin-Yi Wang Reviewed-by: Stephen Boyd --- change log v5->v6: * remove Documentation change --- drivers/of/fdt.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/drivers/of/fdt.c b/drivers/of/fdt.c index 3d36b5afd9bd..369130dbd42c 100644 --- a/drivers/of/fdt.c +++ b/drivers/of/fdt.c @@ -24,6 +24,7 @@ #include #include #include +#include #include /* for COMMAND_LINE_SIZE */ #include @@ -1052,6 +1053,7 @@ int __init early_init_dt_scan_chosen(unsigned long node, const char *uname, { int l; const char *p; + const void *rng_seed; pr_debug("search \"chosen\", depth: %d, uname: %s\n", depth, uname); @@ -1086,6 +1088,14 @@ int __init early_init_dt_scan_chosen(unsigned long node, const char *uname, pr_debug("Command line is: %s\n", (char*)data); + rng_seed = of_get_flat_dt_prop(node, "rng-seed", &l); + if (rng_seed && l > 0) { + add_device_randomness(rng_seed, l); + + /* try to clear seed so it won't be found. */ + fdt_nop_property(initial_boot_params, node, "rng-seed"); + } + /* break now */ return 1; } -- 2.20.1