Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp792673pxk; Mon, 31 Aug 2020 00:36:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzy/gvzKjXL06ONM5h8naPbyJ10PEKDllK41RRXJi0aW+inWos0Ent+T8B9xHtB/R7qA2s8 X-Received: by 2002:a17:906:fa01:: with SMTP id lo1mr10587631ejb.394.1598859404792; Mon, 31 Aug 2020 00:36:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598859404; cv=none; d=google.com; s=arc-20160816; b=QaHmA20uHsn394zdfWAWpmr0Sii6sfSM6XLf6I4xVd9d9Lqh202+BgsQM0RURmd+Ga OWZPbhQVFZ8xGchYpxw3BG9MFKllB/Fw8mjqKKif1eASzsK0XVfTzZ58GvZbfctEmHQ0 S8LGOdLdQ7/+V/p4B3WANB/Yu72WnETfHY2pj4a5wO12hKrwj4MJqsqshThyDg2ZF0gK TF+9H5RVzEYuqdjUphAcJSZMU2/a/ExbZ7plrax7IzKW4Ft3eJvDgd+9LqFQah76zYXF so4ADFMDtrtr60X10j7Jtiv7RzQL1fpZU2IebAzcFLw7C+NuMij2yf07l1dcOlpcT/gq D1PQ== 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=L8nXsELlGPOePYVbXqOXdNoTjjuLOTGOh+u2B39XJu8=; b=lbrxyV6PPDvdGTJlk7gUyxRyMvn6LukebaDHVPrC3W0t1JDkpQoZDUhIHw4nAwyydb wU0PjyJFtSqTdxUKoLmCYAWLVEWIbRPAVIHXhbjzYt9d31LEK/W+4v7gMJYRPdqcj+Mh CSK5YLTVwDlmRryqO+7snxm+PjA/fsdn0fqOK/r3u1kjy/dcfbYkJLLeBqfZHqd8wdxE VNgJrqMtYmIECoixN+DbXOeJf2SplcyZr4erE7HuE95pmipQgvwyNhuAlQcSsW6NEA+y xWMm/IteomafhWu5lunB1vgVMgeE+a2zzbZzI5nE4LhYvajXO0ISeyd2DBNjWB/Mx6F5 8uYw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=PgK3vno4; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d16si4845742ejr.668.2020.08.31.00.36.22; Mon, 31 Aug 2020 00:36:44 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=PgK3vno4; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728047AbgHaHeD (ORCPT + 99 others); Mon, 31 Aug 2020 03:34:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37234 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725949AbgHaHdz (ORCPT ); Mon, 31 Aug 2020 03:33:55 -0400 Received: from mail-pl1-x644.google.com (mail-pl1-x644.google.com [IPv6:2607:f8b0:4864:20::644]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AEE24C061575 for ; Mon, 31 Aug 2020 00:33:55 -0700 (PDT) Received: by mail-pl1-x644.google.com with SMTP id bh1so2603383plb.12 for ; Mon, 31 Aug 2020 00:33:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sifive.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=L8nXsELlGPOePYVbXqOXdNoTjjuLOTGOh+u2B39XJu8=; b=PgK3vno4y4uwW0Yi58wlX6/1YevWE+eaNCNklNzhaveHpwsIaI1MOoSH3cPpLFUUq8 Daf9oeWZJge40WMlzQBLFJQJKeCb+bgKr9G4rja5pujve83hHa8vhB6QAX5nwGGxDGub SLidwctwFMKDMb1q6daswpBm9XAYxPD9Gdz4rwQa8NTs71hTlTb53lJYgQI983OD9hqb 1Fv/iK3Rd7OyRSPQWASC8XjqbN/Xvv63t8YtjVNaYepP4Onp7W79GMFT2pevIYsOKgt1 kjVapBj+6KPTM3zgGOGjeOGqfdM0tRkidE3wpB0nWtuZcO5NeChEuDItjsr7WI8AZvy/ 8nwA== 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=L8nXsELlGPOePYVbXqOXdNoTjjuLOTGOh+u2B39XJu8=; b=BA9OaEkIzVzT2XQEUmKIco+O3ApU8Eodlgw0UTA/si+nq/Qq3BePr3vNdFmvKjfSMX SbZuw11bxMweCcwJ2kSCTWoQm4oTKast2IUM/zIzrF+dS/wkEe5E7/DkzOBmiw61J6kR BpaAyAn4LlKnx+SYyIBbPtZfcthPuNqMZFgjvyszt361Mt8XGkpQh+oNrMh91XfJWpSn j7FPlP6uoWwQsVfVizPhBOq5DjfScr30xGm0MGv+SGPGmRGZvTwIoaNFJJzTjpMMuPa5 KPjVeXW38TxdRGlH7uZEeLEDg33JrT0oLLzlV2Z3lvV02sXW9+1tL8pDQJaqOwQrm1La bt5w== X-Gm-Message-State: AOAM531JPyWLG8XYed3QW/eUhCLar7aFadi2TiA80dr93QDJHBD7y7ol E3wKpk3zvgO2aBE0qIOeWqnymA== X-Received: by 2002:a17:90a:4214:: with SMTP id o20mr229469pjg.232.1598859235279; Mon, 31 Aug 2020 00:33:55 -0700 (PDT) Received: from hsinchu02.internal.sifive.com (114-34-229-221.HINET-IP.hinet.net. [114.34.229.221]) by smtp.gmail.com with ESMTPSA id m3sm6065979pjn.28.2020.08.31.00.33.53 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 31 Aug 2020 00:33:54 -0700 (PDT) From: Zong Li To: palmer@dabbelt.com, paul.walmsley@sifive.com, david.abdurachmanov@sifive.com, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Cc: Zong Li Subject: [PATCH v4 1/3] riscv: Set more data to cacheinfo Date: Mon, 31 Aug 2020 15:33:48 +0800 Message-Id: <77ead0a4d6f48966429dbb1ea48d901d589217af.1598859038.git.zong.li@sifive.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: References: 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 Set cacheinfo.{size,sets,line_size} for each cache node, then we can get these information from userland through auxiliary vector. Signed-off-by: Zong Li --- arch/riscv/kernel/cacheinfo.c | 66 +++++++++++++++++++++++++++-------- 1 file changed, 51 insertions(+), 15 deletions(-) diff --git a/arch/riscv/kernel/cacheinfo.c b/arch/riscv/kernel/cacheinfo.c index bd0f122965c3..291d7d8f748b 100644 --- a/arch/riscv/kernel/cacheinfo.c +++ b/arch/riscv/kernel/cacheinfo.c @@ -25,12 +25,53 @@ cache_get_priv_group(struct cacheinfo *this_leaf) return NULL; } -static void ci_leaf_init(struct cacheinfo *this_leaf, - struct device_node *node, - enum cache_type type, unsigned int level) +static void ci_leaf_init(struct cacheinfo *this_leaf, enum cache_type type, + unsigned int level, unsigned int size, + unsigned int sets, unsigned int line_size) { this_leaf->level = level; this_leaf->type = type; + this_leaf->size = size; + this_leaf->number_of_sets = sets; + this_leaf->coherency_line_size = line_size; + + /* + * If the cache is fully associative, there is no need to + * check the other properties. + */ + if (sets == 1) + return; + + /* + * Set the ways number for n-ways associative, make sure + * all properties are big than zero. + */ + if (sets > 0 && size > 0 && line_size > 0) + this_leaf->ways_of_associativity = (size / sets) / line_size; +} + +static void fill_cacheinfo(struct cacheinfo **this_leaf, + struct device_node *node, unsigned int level) +{ + unsigned int size, sets, line_size; + + if (!of_property_read_u32(node, "cache-size", &size) && + !of_property_read_u32(node, "cache-block-size", &line_size) && + !of_property_read_u32(node, "cache-sets", &sets)) { + ci_leaf_init((*this_leaf)++, CACHE_TYPE_UNIFIED, level, size, sets, line_size); + } + + if (!of_property_read_u32(node, "i-cache-size", &size) && + !of_property_read_u32(node, "i-cache-sets", &sets) && + !of_property_read_u32(node, "i-cache-block-size", &line_size)) { + ci_leaf_init((*this_leaf)++, CACHE_TYPE_INST, level, size, sets, line_size); + } + + if (!of_property_read_u32(node, "d-cache-size", &size) && + !of_property_read_u32(node, "d-cache-sets", &sets) && + !of_property_read_u32(node, "d-cache-block-size", &line_size)) { + ci_leaf_init((*this_leaf)++, CACHE_TYPE_DATA, level, size, sets, line_size); + } } static int __init_cache_level(unsigned int cpu) @@ -83,29 +124,24 @@ static int __populate_cache_leaves(unsigned int cpu) struct device_node *prev = NULL; int levels = 1, level = 1; - if (of_property_read_bool(np, "cache-size")) - ci_leaf_init(this_leaf++, np, CACHE_TYPE_UNIFIED, level); - if (of_property_read_bool(np, "i-cache-size")) - ci_leaf_init(this_leaf++, np, CACHE_TYPE_INST, level); - if (of_property_read_bool(np, "d-cache-size")) - ci_leaf_init(this_leaf++, np, CACHE_TYPE_DATA, level); + /* Level 1 caches in cpu node */ + fill_cacheinfo(&this_leaf, np, level); + /* Next level caches in cache nodes */ prev = np; while ((np = of_find_next_cache_node(np))) { of_node_put(prev); prev = np; + if (!of_device_is_compatible(np, "cache")) break; if (of_property_read_u32(np, "cache-level", &level)) break; if (level <= levels) break; - if (of_property_read_bool(np, "cache-size")) - ci_leaf_init(this_leaf++, np, CACHE_TYPE_UNIFIED, level); - if (of_property_read_bool(np, "i-cache-size")) - ci_leaf_init(this_leaf++, np, CACHE_TYPE_INST, level); - if (of_property_read_bool(np, "d-cache-size")) - ci_leaf_init(this_leaf++, np, CACHE_TYPE_DATA, level); + + fill_cacheinfo(&this_leaf, np, level); + levels = level; } of_node_put(np); -- 2.28.0