Received: by 2002:ab2:3319:0:b0:1ef:7a0f:c32d with SMTP id i25csp95745lqc; Thu, 7 Mar 2024 11:16:38 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCW2f9c02PLmB6xPCbW5l63/EJ7WnrAp2D37ZQyC9mGiu7SL2/sfe5kp5mBrwDfRmQwsgld03PVmetiF9OZB8Kpz48W+geVPflZd2cMIuw== X-Google-Smtp-Source: AGHT+IEL0bjErhejwpaoj6woegN/CekHnTLx2ULDypFEtRk80FOJT5WOMWWs+FSgtNGUgVibynLV X-Received: by 2002:a05:620a:3906:b0:788:2ed3:b005 with SMTP id qr6-20020a05620a390600b007882ed3b005mr11718074qkn.59.1709838997846; Thu, 07 Mar 2024 11:16:37 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1709838997; cv=pass; d=google.com; s=arc-20160816; b=pP1dDsgAoi6hYsxqDXxXxxMRIWhAoCylnjEKttXtgr7lZo6EPsxIV+REnDPwVqdOEw 3X8ESfT9hhCbqu1nu2ylC/8eLRr7G9NvvM4EMk/iVL/VA6vj7SRoh1FRXlaEH0TmoFtW mgBNqeY1z9G/OC7jwyZN62tNCEK7P1pqxoiQc+FFdziRmeJ0XJpHzvslZfAZ6I4TCl8V LMk1br5cxbMvNHdYoPbCVmJxyYOiwnJDZhhgcWZUPHJeqKrY3XD8BrmCYDvoVOfqdIPO GxjVmgJvLUNLGOWgf/YC3r0a3D5XyrOCXzJdLi4FDkvNbBMwEKXRkn/YPmfw8+hOb7ii TL4A== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-disposition:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:message-id:subject:cc :to:date:from:dkim-signature; bh=4OUeKVtKJPLFMBmWIglHJRvn/ZfzCTXm54FGIBKHaik=; fh=E18XBgKHQEvwjD5lqvVtmsGsrgcMKYtmdD9j0szcv58=; b=jnTxNhscyQ0eKFwQoVGxhVvF1EDCBwZbX84/2g4PYOO+78NQOUkeCTouD8YfnfA+D/ 8hUNphpdSN7Xd/fHyG0e9RMiBXzXI9HfRuAK1zLDFfZreVYYoprk9tPwaRUwuTqga3K9 bjEtuHT0g6OT4fkacwpdJS9VIHJBerEuU7TPxcp9nJgBQHy1rqCS9DHbIfcCzV2rqoVr BafqZOrevwSZbUZR1mdusd2W9qVogC4cUl+N1iY4gMNvz9bZ4xsr/cwvo7R04B+Y9G0G D3wcM0ohuu+fZKnxo7V9tfC3M7XZVWiImeW/VzuOO1Mrsy3it38o5xatcIXa7ThyrSSX KExQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b="iYoeE/kM"; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-96083-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-96083-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id wk14-20020a05620a578e00b007882523276dsi10050394qkn.405.2024.03.07.11.16.37 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 Mar 2024 11:16:37 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-96083-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b="iYoeE/kM"; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-96083-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-96083-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 82D261C20DD2 for ; Thu, 7 Mar 2024 19:16:37 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 1484F135A7E; Thu, 7 Mar 2024 19:16:32 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="iYoeE/kM" Received: from mail-lf1-f51.google.com (mail-lf1-f51.google.com [209.85.167.51]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 29614135A68 for ; Thu, 7 Mar 2024 19:16:28 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.167.51 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709838991; cv=none; b=c21q7ZQRHCAmuNvBQXLG6iIe1E+9E7oDAdhOEFf9ZuH6+8pto81QeFq/VKppNOpq2tMl35qzXEKrPHH38dTv6Q4RozHvzZW8IPsWi2LpimxlfrD675AvpbrjiLsx4NBlPeFaWbm86lpHPmA2UcddJp80tSws5QA8TNFgnYPHVaE= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709838991; c=relaxed/simple; bh=x7BQ76O//NapXe3gdeT390Tm8e0JCj6TttWJIiSF0mg=; h=From:Date:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=ZqHskBlAEzFhf8q8OSJpWF/twOn4MbpRcR1u9Gh246XLcZJLDknKc5c21pRZOEMPVJCJaH3KRRWXWdWCE1hji83AKJssuwSUgnE3cNYhxDR0YFP1xVW4uw4j6ItZZ4oyKEgwWkALwdm1lw0v0Uaxsjbd9ReEffEINv/Uaqm1gcE= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=iYoeE/kM; arc=none smtp.client-ip=209.85.167.51 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-lf1-f51.google.com with SMTP id 2adb3069b0e04-5131a9b3d5bso122400e87.0 for ; Thu, 07 Mar 2024 11:16:28 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1709838987; x=1710443787; darn=vger.kernel.org; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:date:from:from:to:cc:subject:date:message-id:reply-to; bh=4OUeKVtKJPLFMBmWIglHJRvn/ZfzCTXm54FGIBKHaik=; b=iYoeE/kMHs2LcPVBUaY8Zx4sFfOgyuAYP7LacolGIrElFhPdRtaxKD5AqD4TxFc9AT HSBGmwXCQNRZDVtEc70f7v8X92t/+K15ymFdkhvksvs38wnewztWuTjsY9lkFu+6JJ/B G2XygdakOCu0G2WKCLtV+ErwiaYHq9g/rr0sh8Zse+H0Lb6SmhDB5x7PvV87K6U6zXFw Jc7z/mSCl+yEgwpOD74TlUA3q6YeEQsRuZR7lmyanjzFDuJex6RmoD1DUc9TzGXW722l nr/S8SsxLANyR9OfEUgKOHW49m5RajLqNW1+zbVpY0ukn36qGf7GPUat7QnltxRg1trI rv4A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1709838987; x=1710443787; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:date:from:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=4OUeKVtKJPLFMBmWIglHJRvn/ZfzCTXm54FGIBKHaik=; b=LKcy9lGdqaGDsd1yAqIXWXN118tU792t345UKIhR+Url1YqgueY3miLNpBemO1BIUU R74zcWqTr+x8nYib4Av3iPw5xesZ53PHJo9gB+E61+elJYDMNYDS5SYyaN3h9ak5ej6A EkOOkEwzj0jWhP10KsrqwqkMWuIp/G/wjIcy1UMCMTgWpBgZPsRXOXUPVaFdsupT1a0l if1jT+JWUOj8eH5m8b71HnuBZ1NVw+4F6cnQ69zmbKk9NUF3GR6ZVScjHfogJfNgSNMS 0tV7Venm+cYt6MS5tLww84BBUgPSk1d6xUPSQ0H2BREM7E0cuqemMDIZvnz0Ahwbq/Ov j2zA== X-Forwarded-Encrypted: i=1; AJvYcCXoFz+trorUPKNYldIfIQGrnPAHJP3wRELdMekv2dz0zK3VZg8e0hVdWBFBbkv8WTO0LFHjWCxJTnVBvIRRgTfjFfCPkMqqR3cWb363 X-Gm-Message-State: AOJu0YwWEjRl5CLNOsYi3tXxFhCSIMswnV51z/qIMDAhZYsvVyF3hSuv Jy74YOVM4kK/GyDbzc0mZ08jy17soprZIA22xdz7c0Q4vIpSCa2s X-Received: by 2002:a05:6512:290:b0:513:49f7:70f with SMTP id j16-20020a056512029000b0051349f7070fmr2029999lfp.57.1709838986809; Thu, 07 Mar 2024 11:16:26 -0800 (PST) Received: from pc638.lan (host-185-121-47-193.sydskane.nu. [185.121.47.193]) by smtp.gmail.com with ESMTPSA id p4-20020a19f004000000b005131b457ee7sm3130537lfc.264.2024.03.07.11.16.25 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 Mar 2024 11:16:26 -0800 (PST) From: Uladzislau Rezki X-Google-Original-From: Uladzislau Rezki Date: Thu, 7 Mar 2024 20:16:24 +0100 To: Baoquan He , rulinhuang Cc: Uladzislau Rezki , rulinhuang , akpm@linux-foundation.org, colin.king@intel.com, hch@infradead.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, lstoakes@gmail.com, tianyou.li@intel.com, tim.c.chen@intel.com, wangyang.guo@intel.com, zhiguo.zhou@intel.com Subject: Re: [PATCH v7 1/2] mm/vmalloc: Moved macros with no functional change happened Message-ID: References: <20240301155417.1852290-1-rulin.huang@intel.com> <20240301155417.1852290-2-rulin.huang@intel.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: On Thu, Mar 07, 2024 at 09:23:10AM +0800, Baoquan He wrote: > On 03/06/24 at 08:01pm, Uladzislau Rezki wrote: > > On Fri, Mar 01, 2024 at 10:54:16AM -0500, rulinhuang wrote: > ...... > > > > Sorry for the late answer, i also just noticed this email. It was not in > > my inbox... > > > > OK, now you move part of the per-cpu allocator on the top and leave > > another part down making it split. This is just for the: > > > > BUG_ON(va_flags & VMAP_RAM); > > > > VMAP_RAM macro. Do we really need this BUG_ON()? > > Sorry, I suggested that when reviewing v5: > https://lore.kernel.org/all/ZdiltpK5fUvwVWtD@MiWiFi-R3L-srv/T/#u > > About part of per-cpu kva allocator moving and the split making, I would > argue that we will have vmap_nodes defintion and basic helper functions > like addr_to_node_id() etc at top, and leave other part like > size_to_va_pool(), node_pool_add_va() etc down. These are similar. > > While about whether we should add 'BUG_ON(va_flags & VMAP_RAM);', I am > not sure about it. When I suggested that, I am also hesitant. From the > current code, alloc_vmap_area() is called in below three functions, only > __get_vm_area_node() will pass the non-NULL vm. > new_vmap_block() -| > vm_map_ram() ----> alloc_vmap_area() > __get_vm_area_node() -| > > It could be wrongly passed in the future? Only checking if vm is > non-NULL makes me feel a little unsafe. While I am fine if removing the > BUG_ON, because there's no worry in the current code. We can wait and > see in the future. > > if (vm) { > BUG_ON(va_flags & VMAP_RAM); > setup_vmalloc_vm(vm, va, flags, caller); > } > I would remove it, because it is really hard to mess it, there is only one place also BUG_ON() is really a show stopper. I really appreciate what rulinhuang is doing and i understand that it might be not so easy. So, if we can avoid of moving the code, that looks to me that we can do, if we can pass less arguments into alloc_vmap_area() since it is overloaded that would be great. Just an example: diff --git a/mm/vmalloc.c b/mm/vmalloc.c index 25a8df497255..b6050e018539 100644 --- a/mm/vmalloc.c +++ b/mm/vmalloc.c @@ -1841,6 +1841,30 @@ node_alloc(unsigned long size, unsigned long align, return va; } +static inline void +__pre_setup_vmalloc_vm(struct vm_struct *vm, + unsigned long flags, const void *caller) +{ + vm->flags = flags; + vm->caller = caller; +} + +static inline void +__post_setup_vmalloc_vm(struct vm_struct *vm, struct vmap_area *va) +{ + vm->addr = (void *)va->va_start; + vm->size = va->va_end - va->va_start; + va->vm = vm; +} + +static inline void +setup_vmalloc_vm_locked(struct vm_struct *vm, struct vmap_area *va, + unsigned long flags, const void *caller) +{ + __pre_setup_vmalloc_vm(vm, flags, caller); + __post_setup_vmalloc_vm(vm, va); +} + /* * Allocate a region of KVA of the specified size and alignment, within the * vstart and vend. @@ -1849,7 +1873,7 @@ static struct vmap_area *alloc_vmap_area(unsigned long size, unsigned long align, unsigned long vstart, unsigned long vend, int node, gfp_t gfp_mask, - unsigned long va_flags) + unsigned long va_flags, struct vm_struct *vm) { struct vmap_node *vn; struct vmap_area *va; @@ -1912,6 +1936,9 @@ static struct vmap_area *alloc_vmap_area(unsigned long size, va->vm = NULL; va->flags = (va_flags | vn_id); + if (vm) + __post_setup_vmalloc_vm(vm, va); + vn = addr_to_node(va->va_start); spin_lock(&vn->busy.lock); @@ -2486,7 +2513,7 @@ static void *new_vmap_block(unsigned int order, gfp_t gfp_mask) va = alloc_vmap_area(VMAP_BLOCK_SIZE, VMAP_BLOCK_SIZE, VMALLOC_START, VMALLOC_END, node, gfp_mask, - VMAP_RAM|VMAP_BLOCK); + VMAP_RAM|VMAP_BLOCK, NULL); if (IS_ERR(va)) { kfree(vb); return ERR_CAST(va); @@ -2843,7 +2870,8 @@ void *vm_map_ram(struct page **pages, unsigned int count, int node) struct vmap_area *va; va = alloc_vmap_area(size, PAGE_SIZE, VMALLOC_START, VMALLOC_END, - node, GFP_KERNEL, VMAP_RAM); + node, GFP_KERNEL, VMAP_RAM, NULL); + if (IS_ERR(va)) return NULL; @@ -2946,26 +2974,6 @@ void __init vm_area_register_early(struct vm_struct *vm, size_t align) kasan_populate_early_vm_area_shadow(vm->addr, vm->size); } -static inline void setup_vmalloc_vm_locked(struct vm_struct *vm, - struct vmap_area *va, unsigned long flags, const void *caller) -{ - vm->flags = flags; - vm->addr = (void *)va->va_start; - vm->size = va->va_end - va->va_start; - vm->caller = caller; - va->vm = vm; -} - -static void setup_vmalloc_vm(struct vm_struct *vm, struct vmap_area *va, - unsigned long flags, const void *caller) -{ - struct vmap_node *vn = addr_to_node(va->va_start); - - spin_lock(&vn->busy.lock); - setup_vmalloc_vm_locked(vm, va, flags, caller); - spin_unlock(&vn->busy.lock); -} - static void clear_vm_uninitialized_flag(struct vm_struct *vm) { /* @@ -3002,14 +3010,15 @@ static struct vm_struct *__get_vm_area_node(unsigned long size, if (!(flags & VM_NO_GUARD)) size += PAGE_SIZE; - va = alloc_vmap_area(size, align, start, end, node, gfp_mask, 0); + /* post-setup is done in the alloc_vmap_area(). */ + __pre_setup_vmalloc_vm(area, flags, caller); + + va = alloc_vmap_area(size, align, start, end, node, gfp_mask, 0, area); if (IS_ERR(va)) { kfree(area); return NULL; } - setup_vmalloc_vm(area, va, flags, caller); - /* * Mark pages for non-VM_ALLOC mappings as accessible. Do it now as a * best-effort approach, as they can be mapped outside of vmalloc code. -- Uladzislau Rezki