Received: by 2002:a05:6a10:a852:0:0:0:0 with SMTP id d18csp3447551pxy; Tue, 4 May 2021 02:22:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz7RPp2m0UlLOo/S7NHrHOy7KxaJ3AUQb7mDnhsZTLwpAA5XanV5c3kOW3pWhlSVUZ4AKtq X-Received: by 2002:a17:90a:d582:: with SMTP id v2mr27949848pju.88.1620120160565; Tue, 04 May 2021 02:22:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620120160; cv=none; d=google.com; s=arc-20160816; b=Am9TsAim1RLQNEmHzOAp76mVGnkoCDaMNAoHkBTSd7gGhxiRoHk+RjE5nWUJymJtSM kq2BHoaZMjTtg18sUSppkPfWJ/0GFrqtDHdHKTLr9S4BlG9dY+TYUNi57R4d/TZKGIeM +hzY0px0YolK8gYlX12G3nL8mwcuQeK0AicMb5xhWsgLL+RRlfwKAeN4UpJuVdYHjUBR ZMg6dObFMXEQdUGZl38TAJsUfWD6pceFZM683TLrGRh92arxy02g8tXg8mUgfcyzirGw 8JOS+QzZN6AWAxRvvjnOIUxtbClFf7D5j9gZd2bzJB2Y0ZQzX+a1p2VhBmblLiSHv4F7 HAdQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=ghASH/1ZjKnCf6B2pmQxxmRZuCfU5tGuXnSxSWfI9+I=; b=nkAhnlgF/TOvkzWUZ6B8B36qdqMoLFyA332bkE4T9lZMeL/+Ild5z0dwnIl7yXtXcj HuGncNuQNgFl8c34Rhu8SBb9J6nEp6uI3e1gsRyAW5Dl1rn2DsEvm5EW67EQuuEVxI2Z uT/TEeIAVrEKbV3VZL7cpUXUCC4oU0eQcRV7JgsqLLh7g/Efqeoy+5Kpn0flYyUCKklf c2ZPQXfeuP44eB5TpCVql+pJvfHAMiHwBHuoUzfQqSSfgm+D3vIsON2aFGzkzB2p1Sco /Ghn8P5bI2XjGcExdLPbo7wvOLB1AWoxHcLh+LK5rIOoJA6KdoyEU9Xym8bOThGXpRoX 1fHA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ibm.com header.s=pp1 header.b=C2g+OzlS; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i22si2684363pjl.16.2021.05.04.02.22.28; Tue, 04 May 2021 02:22:40 -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=@ibm.com header.s=pp1 header.b=C2g+OzlS; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229994AbhEDJV5 (ORCPT + 99 others); Tue, 4 May 2021 05:21:57 -0400 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:62066 "EHLO mx0b-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229703AbhEDJV4 (ORCPT ); Tue, 4 May 2021 05:21:56 -0400 Received: from pps.filterd (m0127361.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.43/8.16.0.43) with SMTP id 1449IApQ146629; Tue, 4 May 2021 05:20:45 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=from : to : cc : subject : date : message-id : mime-version : content-transfer-encoding; s=pp1; bh=ghASH/1ZjKnCf6B2pmQxxmRZuCfU5tGuXnSxSWfI9+I=; b=C2g+OzlS9dN+EZZkB4MXK3F3eMBANMrRHfNwkYwLgaTvc9GL+w+O4X9oLgjTRHKYFryW 5vPEBKTy22cBk9gqMQ5iD4LL6VCbWWC5JkT+qhKkoVDztQroPh8FCK8EVWhbLu9Y1hYR 8PIdA9zI1gOIZMVTFlIAQpEWL/L4tiPrDm8RKZ9fI02/l8V4OBBEDt3v+qmZJb7COav/ 9p4Ovp37cPM5hWROFfVvK1wkYq1Pc9nFoBY6xHbDLcRDXRsMvUX/4a6G6bXg+q+2QqhE C2lcI2Z+FrUiQY1rlj8akYQIhwu/RT4FgCOUc689oL8N9OQdsS6X2T2UHFQ62w4nbe9q Ew== Received: from ppma03ams.nl.ibm.com (62.31.33a9.ip4.static.sl-reverse.com [169.51.49.98]) by mx0a-001b2d01.pphosted.com with ESMTP id 38b3h381tf-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 04 May 2021 05:20:44 -0400 Received: from pps.filterd (ppma03ams.nl.ibm.com [127.0.0.1]) by ppma03ams.nl.ibm.com (8.16.0.43/8.16.0.43) with SMTP id 1449CAWX001876; Tue, 4 May 2021 09:20:43 GMT Received: from b06cxnps4076.portsmouth.uk.ibm.com (d06relay13.portsmouth.uk.ibm.com [9.149.109.198]) by ppma03ams.nl.ibm.com with ESMTP id 388xm8h3ms-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 04 May 2021 09:20:43 +0000 Received: from d06av21.portsmouth.uk.ibm.com (d06av21.portsmouth.uk.ibm.com [9.149.105.232]) by b06cxnps4076.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 1449KeNd39649774 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 4 May 2021 09:20:40 GMT Received: from d06av21.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 30BEA52057; Tue, 4 May 2021 09:20:40 +0000 (GMT) Received: from localhost.localdomain (unknown [9.145.18.121]) by d06av21.portsmouth.uk.ibm.com (Postfix) with ESMTP id CFC7052052; Tue, 4 May 2021 09:20:39 +0000 (GMT) From: Laurent Dufour To: mpe@ellerman.id.au, benh@kernel.crashing.org, paulus@samba.org Cc: nathanl@linux.ibm.com, linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, "Aneesh Kumar K . V" , Tyrel Datwyler Subject: [PATCH v4] pseries/drmem: update LMBs after LPM Date: Tue, 4 May 2021 11:20:38 +0200 Message-Id: <20210504092038.8514-1-ldufour@linux.ibm.com> X-Mailer: git-send-email 2.31.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-TM-AS-GCONF: 00 X-Proofpoint-GUID: spypsdd0VtkukeYQ_Hd_k6BH3C1qnZQ8 X-Proofpoint-ORIG-GUID: spypsdd0VtkukeYQ_Hd_k6BH3C1qnZQ8 X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.391,18.0.761 definitions=2021-05-04_05:2021-05-04,2021-05-04 signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 impostorscore=0 phishscore=0 clxscore=1015 adultscore=0 mlxlogscore=999 priorityscore=1501 malwarescore=0 bulkscore=0 mlxscore=0 suspectscore=0 lowpriorityscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2104060000 definitions=main-2105040067 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org After a LPM, the device tree node ibm,dynamic-reconfiguration-memory may be updated by the hypervisor in the case the NUMA topology of the LPAR's memory is updated. This is caught by the kernel, but the memory's node is updated because there is no way to move a memory block between nodes. If later a memory block is added or removed, drmem_update_dt() is called and it is overwriting the DT node to match the added or removed LMB. But the LMB's associativity node has not been updated after the DT node update and thus the node is overwritten by the Linux's topology instead of the hypervisor one. Introduce a hook called when the ibm,dynamic-reconfiguration-memory node is updated to force an update of the LMB's associativity. However, ignore the call to that hook when the update has been triggered by drmem_update_dt(). Because, in that case, the LMB tree has been used to set the DT property and thus it doesn't need to be updated back. Since drmem_update_dt() is called under the protection of the device_hotplug_lock and the hook is called in the same context, use a simple boolean variable to detect that call. Cc: Aneesh Kumar K.V Cc: Tyrel Datwyler Signed-off-by: Laurent Dufour --- V4: - Prevent the LMB to be updated back in the case the request came from the LMB tree's update. V3: - Check rd->dn->name instead of rd->dn->full_name V2: - Take Tyrel's idea to rely on OF_RECONFIG_UPDATE_PROPERTY instead of introducing a new hook mechanism. --- arch/powerpc/include/asm/drmem.h | 1 + arch/powerpc/mm/drmem.c | 46 +++++++++++++++++++ .../platforms/pseries/hotplug-memory.c | 4 ++ 3 files changed, 51 insertions(+) diff --git a/arch/powerpc/include/asm/drmem.h b/arch/powerpc/include/asm/drmem.h index bf2402fed3e0..4265d5e95c2c 100644 --- a/arch/powerpc/include/asm/drmem.h +++ b/arch/powerpc/include/asm/drmem.h @@ -111,6 +111,7 @@ int drmem_update_dt(void); int __init walk_drmem_lmbs_early(unsigned long node, void *data, int (*func)(struct drmem_lmb *, const __be32 **, void *)); +void drmem_update_lmbs(struct property *prop); #endif static inline void invalidate_lmb_associativity_index(struct drmem_lmb *lmb) diff --git a/arch/powerpc/mm/drmem.c b/arch/powerpc/mm/drmem.c index 9af3832c9d8d..22197b18d85e 100644 --- a/arch/powerpc/mm/drmem.c +++ b/arch/powerpc/mm/drmem.c @@ -18,6 +18,7 @@ static int n_root_addr_cells, n_root_size_cells; static struct drmem_lmb_info __drmem_info; struct drmem_lmb_info *drmem_info = &__drmem_info; +static bool in_drmem_update; u64 drmem_lmb_memory_max(void) { @@ -178,6 +179,11 @@ int drmem_update_dt(void) if (!memory) return -1; + /* + * Set in_drmem_update to prevent the notifier callback to process the + * DT property back since the change is coming from the LMB tree. + */ + in_drmem_update = true; prop = of_find_property(memory, "ibm,dynamic-memory", NULL); if (prop) { rc = drmem_update_dt_v1(memory, prop); @@ -186,6 +192,7 @@ int drmem_update_dt(void) if (prop) rc = drmem_update_dt_v2(memory, prop); } + in_drmem_update = false; of_node_put(memory); return rc; @@ -307,6 +314,45 @@ int __init walk_drmem_lmbs_early(unsigned long node, void *data, return ret; } +/* + * Update the LMB associativity index. + */ +static int update_lmb(struct drmem_lmb *updated_lmb, + __maybe_unused const __be32 **usm, + __maybe_unused void *data) +{ + struct drmem_lmb *lmb; + + for_each_drmem_lmb(lmb) { + if (lmb->drc_index != updated_lmb->drc_index) + continue; + + lmb->aa_index = updated_lmb->aa_index; + break; + } + return 0; +} + +/* + * Update the LMB associativity index. + * + * This needs to be called when the hypervisor is updating the + * dynamic-reconfiguration-memory node property. + */ +void drmem_update_lmbs(struct property *prop) +{ + /* + * Don't update the LMBs if triggered by the update done in + * drmem_update_dt(), the LMB values have been used to the update the DT + * property in that case. + */ + if (in_drmem_update) + return; + if (!strcmp(prop->name, "ibm,dynamic-memory")) + __walk_drmem_v1_lmbs(prop->value, NULL, NULL, update_lmb); + else if (!strcmp(prop->name, "ibm,dynamic-memory-v2")) + __walk_drmem_v2_lmbs(prop->value, NULL, NULL, update_lmb); +} #endif static int init_drmem_lmb_size(struct device_node *dn) diff --git a/arch/powerpc/platforms/pseries/hotplug-memory.c b/arch/powerpc/platforms/pseries/hotplug-memory.c index 8377f1f7c78e..672ffbee2e78 100644 --- a/arch/powerpc/platforms/pseries/hotplug-memory.c +++ b/arch/powerpc/platforms/pseries/hotplug-memory.c @@ -949,6 +949,10 @@ static int pseries_memory_notifier(struct notifier_block *nb, case OF_RECONFIG_DETACH_NODE: err = pseries_remove_mem_node(rd->dn); break; + case OF_RECONFIG_UPDATE_PROPERTY: + if (!strcmp(rd->dn->name, + "ibm,dynamic-reconfiguration-memory")) + drmem_update_lmbs(rd->prop); } return notifier_from_errno(err); } -- 2.31.1