Received: by 2002:a05:7412:31a9:b0:e2:908c:2ebd with SMTP id et41csp4669377rdb; Fri, 15 Sep 2023 08:52:12 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEXUbOUkVyiLpEfEUXU6SPXXbBG0hVzfT6F7RvTtyeA62nuSTSiXzZqtOczZR1XIDzNmYX6 X-Received: by 2002:a05:6a20:7d9e:b0:159:f71f:4083 with SMTP id v30-20020a056a207d9e00b00159f71f4083mr2591318pzj.6.1694793131921; Fri, 15 Sep 2023 08:52:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1694793131; cv=none; d=google.com; s=arc-20160816; b=FpHfPFH8L+OzbvkSwLszIHy9vxP304I52E6FKihMBIu9hzTUihAsf6MvFgWzSXGL1c KemR2RAp8l8ZA4rH6u8F9o9wEdYGK1fffQZK1InvIrdaxmhctPNhvLB1V4v5w+UaJ+6d Z2Lw4c/KCBIuYrgu8lp/xu8flb3N2MFtr4p2hvEzjH1fK0YDUKXdtgJ2uX8IWFHIJnmH bC+OzPmV4caB599q7DaMuE0y5MLgFM+2ZSFeFNcQEwAY+AUogic+w5eCMtc/06iUVj2J ldN+EghiXjIz9sJGFcKH+RjAKgu4Z7vOsi4HVOOrxBU8tKRsal9PRkJm7e28BXVJroOV btZg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=Ad1gGutAVP5/Tgl+c7iRZuNausX9kqPfW/rFp80jjCw=; fh=tmp1TYMHyWQr2svVXtUDPnDPAtRoi3sn6aTWcbkzNfs=; b=umvmOvJIcBbyMg0j0QV/s32BjQV1k0aypcR8wVOF5kzz7dkbN/DQqu1CuxDRQ5fiYM xuaZRDZ2k45kUgluyT9GYTsclPu2OjdV2KJdsEbRqO3WATfBnW07vEMhY774dsYmHqQw LqowEk9SmXz8bP/zk5eTiQwSYWT5KAOjOl9vp8BGr5hWAXEh1hdDFk5NSNzpj5wtThFm uHviRMPW43qmMg1KAK5a1aoF648FM/xgZ1eggn8BQC14tRxamD38rLiCyNnFeNmbcWcL 1lILiYtSV/nWBnpoh34AhTAt/Y3uFy6xPrZqD9tlP44UhlJCZnMP5TMwOsVDPzGkOoCN sxxg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@hefring-com.20230601.gappssmtp.com header.s=20230601 header.b=uncMKVYF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [23.128.96.33]) by mx.google.com with ESMTPS id 4-20020a630004000000b00573f83d85e8si3539172pga.467.2023.09.15.08.51.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Sep 2023 08:52:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) client-ip=23.128.96.33; Authentication-Results: mx.google.com; dkim=pass header.i=@hefring-com.20230601.gappssmtp.com header.s=20230601 header.b=uncMKVYF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id AFDB481E0FC1; Fri, 15 Sep 2023 08:45:49 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236211AbjIOPpS (ORCPT + 99 others); Fri, 15 Sep 2023 11:45:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44508 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236250AbjIOPoy (ORCPT ); Fri, 15 Sep 2023 11:44:54 -0400 Received: from mail-qt1-x833.google.com (mail-qt1-x833.google.com [IPv6:2607:f8b0:4864:20::833]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 77AE0F3 for ; Fri, 15 Sep 2023 08:44:45 -0700 (PDT) Received: by mail-qt1-x833.google.com with SMTP id d75a77b69052e-4142ca41b89so13475721cf.0 for ; Fri, 15 Sep 2023 08:44:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=hefring-com.20230601.gappssmtp.com; s=20230601; t=1694792684; x=1695397484; darn=vger.kernel.org; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:from:to:cc:subject:date:message-id:reply-to; bh=Ad1gGutAVP5/Tgl+c7iRZuNausX9kqPfW/rFp80jjCw=; b=uncMKVYFg6E+IO0/LthlqxYKHvF/Lt6BnSataDD12U0PjFjNRKjHufTyChsXVSqAC0 FOqZnzKWo2iCKOwoeubNc17ZiP1D4sbizCo/P3aal8KrXGWKNYXjCPOlNShHj3VjRpgr Q+Pc7iw6shrlmQszD6UxkczHCx9AR0b34ozywWVEAhkdXB3v7BKed5a1XrhMNSv8r/5a x/ctnC1k2bJ0qh6XeZdiX5rK7/ilnmesrLYkBc0/YRBObhrvt/102kfwooQOrzkGo6iN 3KTFW3L6N3R6uqzhaPL5/6LoYe0UTT4ZoKmas5noOF5kJ3drrkXBxzxsqH7x6ak7cu+y p6nQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1694792684; x=1695397484; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=Ad1gGutAVP5/Tgl+c7iRZuNausX9kqPfW/rFp80jjCw=; b=sG8VQ8ugjCa1oqjpi0dojF0j31lDbs0M14BxlAi/gK+vWL+K596melOrTjJHra2Gmf sueKU7HzpqnNejCo51blZu+CWsulPNzKV6D+kogD+iDVE4OB4CXj60re3eEerZScXSve p/RTYCd+BUoBYlEO3RYKe+fRTEANqnc/OcQx1WX4RzzzhRdqYbIn3b8KieiL2vsZYLdm Z612c6DEsh0VSi5k3VUtxpHm8BFXG9miE81ScCR6lEvkqF3I72sSplY7xvf0NjRsWv+e ds9U9ev4aJpupzyjKkOo7kfGuVQjq5l9eoOku609ZUg+nnreVjv3Ol1Np9X4PZliIETF eV4g== X-Gm-Message-State: AOJu0YzRSi3Nanc0OUzOeX9et3/h6Jeib8I+MZYGrig6r1JVWy3U6a6e uFVQ5UO3WSdepj0n4wv+lM6fb16IME8YCXNSQAJapA== X-Received: by 2002:ac8:5d0b:0:b0:403:b395:b450 with SMTP id f11-20020ac85d0b000000b00403b395b450mr2764065qtx.2.1694792684693; Fri, 15 Sep 2023 08:44:44 -0700 (PDT) Received: from dell-precision-5540 ([50.212.55.89]) by smtp.gmail.com with ESMTPSA id ih17-20020a05622a6a9100b004100c132990sm1225549qtb.44.2023.09.15.08.44.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Sep 2023 08:44:43 -0700 (PDT) Date: Fri, 15 Sep 2023 11:44:40 -0400 From: Ben Wolsieffer To: Oleg Nesterov Cc: linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, Greg Ungerer , Andrew Morton , Giulio Benetti Subject: Re: [PATCH] proc: nommu: /proc//maps: release mmap read lock Message-ID: References: <20230914163019.4050530-2-ben.wolsieffer@hefring.com> <20230915121514.GA2768@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230915121514.GA2768@redhat.com> X-Spam-Status: No, score=-0.8 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (lipwig.vger.email [0.0.0.0]); Fri, 15 Sep 2023 08:45:49 -0700 (PDT) On Fri, Sep 15, 2023 at 02:15:15PM +0200, Oleg Nesterov wrote: > Sorry for the offtopic question. I know NOTHING about nommu and when I tried to > review this patch I was puzzled by > > /* See m_next(). Zero at the start or after lseek. */ > if (addr == -1UL) > return NULL; > > at the start of m_start(). OK, lets look at > > static void *m_next(struct seq_file *m, void *_p, loff_t *pos) > { > struct vm_area_struct *vma = _p; > > *pos = vma->vm_end; > return find_vma(vma->vm_mm, vma->vm_end); > } > > where does this -1UL come from? Does this mean that on nommu > > last_vma->vm_end == -1UL > > or what? > > fs/proc/task_mmu.c has the same check at the start, but in this case > the "See m_next()" comment actually helps. Yes, this is another copying mistake from the MMU implementation. In fact, it turns out that no-MMU /proc//maps is completely broken after 0c563f148043 ("proc: remove VMA rbtree use from nommu"). It just returns an empty file. This happens because find_vma() doesn't do what we want here. It "look[s] up the first VMA in which addr resides, NULL if none", and the address will be zero in in m_start(), which makes find_vma() return NULL (unless presumably the zero address is actually part of the process's address space). I didn't run into this because I developed my patch against an older kernel, and didn't test the latest version until today. I'm preparing a second patch to fix this bug. > > Just curious, thanks. > > Oleg. > Thanks, Ben