Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp2748326pxb; Mon, 31 Jan 2022 03:32:00 -0800 (PST) X-Google-Smtp-Source: ABdhPJxtL7xqHshqnbzyWU44s7L2MMrROos1hzVC2WXhw7Bx/VRKUQi82VBBsFnukA0lEpJD1Pkx X-Received: by 2002:a17:90b:1bcc:: with SMTP id oa12mr23581130pjb.93.1643628720065; Mon, 31 Jan 2022 03:32:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643628720; cv=none; d=google.com; s=arc-20160816; b=H6w+3O0eMYv6yygdOM+G5dyBIQdtG5ekeARb1360YDgxnOcdlC0BYXpJ3w4R2QZrnk iQb/Az06VFOEbPvDzvNIst+HN3spDgPVhl0rAHZgeC1F550Hzj9OUWVNU92gkKsB8VFb ufkSbOzuovMLmL7l0ifa61sv1YxWq1xr3zANJcMhz+DX7w09xnnsd7kLkNHtWprOqT7k 7qllPpcBTupoTGLpxKHqRkXizU302YgYrwGHC7OwH9w+XQF8VRRTnzGW+cTtiNWp/ZI8 amA9h59b6m6MiDE/GU5GBRGHteEeLtyzvKHSE8y+re7HuRXjMMCjH9yciq6JV2UtQogc Rvew== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=z7PkS3p7o3c1KlQT9mE47JFulyDrby+E1xl/snWb8i0=; b=hObNI+7hfwtwUtYmcpsCrSe2euT5RS7//eZ3zRcgVRfgHZfASYqyAqKMaXpFyMpzwB vqpO/N16HoTEJo54lKoj2czp8VojJ7vLxE0PoLtjLWcmgrPism8Dd8AaCeLgWYcCHPBi c86Pl5wHbPxgejmLaa0u8q8ebRO/eVh3L3y7Y+u17RD1lbzCUvRvuxRjkrXfHD660ETW fHdrTq0gdvoLfLINzY/gGxvfHrHP9bRNWz4ZPr2La3X4989o4VbimEOeq0rmgkypIZvc Y/YNpIdyIHBb54k4fpzO5DZdIQYu1Yh6bug2xvy3YV9ESR1taHXiSZB2IwL4nzyfLBn8 R73g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=ZmdZqs0q; 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j32si13215756pgb.452.2022.01.31.03.31.49; Mon, 31 Jan 2022 03:32:00 -0800 (PST) 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=@redhat.com header.s=mimecast20190719 header.b=ZmdZqs0q; 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351022AbiA1T5f (ORCPT + 99 others); Fri, 28 Jan 2022 14:57:35 -0500 Received: from us-smtp-delivery-124.mimecast.com ([170.10.129.124]:49875 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1351020AbiA1T5a (ORCPT ); Fri, 28 Jan 2022 14:57:30 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1643399849; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=z7PkS3p7o3c1KlQT9mE47JFulyDrby+E1xl/snWb8i0=; b=ZmdZqs0qj1/Nqe1eOgebpdN7IIG08owjDtRMU0p6RzzEj3zqsHl0ZJYgokLJLTUx5QLAHa djCL3agpOZ5JGXg5FfHgkFw9ZGR6sd1qEeanYtnvyTpnquVThnBu0ojENNWZwZohprABjY wVfaluFUYc00bq6QlAdud4l8nV+TG8g= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-463-iCC205RvNbe_8lZYT7eujw-1; Fri, 28 Jan 2022 14:57:26 -0500 X-MC-Unique: iCC205RvNbe_8lZYT7eujw-1 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id C9FE31083F6D; Fri, 28 Jan 2022 19:57:24 +0000 (UTC) Received: from llong.com (unknown [10.22.33.1]) by smtp.corp.redhat.com (Postfix) with ESMTP id D155C5DB82; Fri, 28 Jan 2022 19:57:23 +0000 (UTC) From: Waiman Long To: Johannes Weiner , Michal Hocko , Vladimir Davydov , Andrew Morton Cc: linux-kernel@vger.kernel.org, cgroups@vger.kernel.org, linux-mm@kvack.org, Rafael Aquini , Waiman Long Subject: [PATCH 1/2] mm/page_owner: Introduce SNPRINTF() macro that includes length error check Date: Fri, 28 Jan 2022 14:56:41 -0500 Message-Id: <20220128195642.416743-2-longman@redhat.com> In-Reply-To: <20220128195642.416743-1-longman@redhat.com> References: <20220128195642.416743-1-longman@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In print_page_owner(), there is a repetitive check after each snprintf() to make sure that the final length is less than the buffer size. Simplify the code and make it easier to read by embedding the buffer length check and increment inside the macro. Signed-off-by: Waiman Long --- mm/page_owner.c | 50 +++++++++++++++++++++++-------------------------- 1 file changed, 23 insertions(+), 27 deletions(-) diff --git a/mm/page_owner.c b/mm/page_owner.c index 99e360df9465..c52ce9d6bc3b 100644 --- a/mm/page_owner.c +++ b/mm/page_owner.c @@ -325,12 +325,20 @@ void pagetypeinfo_showmixedcount_print(struct seq_file *m, seq_putc(m, '\n'); } +#define SNPRINTF(_buf, _size, _len, _err, _fmt, ...) \ + do { \ + _len += snprintf(_buf + _len, _size - _len, _fmt, \ + ##__VA_ARGS__); \ + if (_len >= _size) \ + goto _err; \ + } while (0) + static ssize_t print_page_owner(char __user *buf, size_t count, unsigned long pfn, struct page *page, struct page_owner *page_owner, depot_stack_handle_t handle) { - int ret, pageblock_mt, page_mt; + int ret = 0, pageblock_mt, page_mt; char *kbuf; count = min_t(size_t, count, PAGE_SIZE); @@ -338,44 +346,32 @@ print_page_owner(char __user *buf, size_t count, unsigned long pfn, if (!kbuf) return -ENOMEM; - ret = snprintf(kbuf, count, - "Page allocated via order %u, mask %#x(%pGg), pid %d, ts %llu ns, free_ts %llu ns\n", - page_owner->order, page_owner->gfp_mask, - &page_owner->gfp_mask, page_owner->pid, - page_owner->ts_nsec, page_owner->free_ts_nsec); - - if (ret >= count) - goto err; + SNPRINTF(kbuf, count, ret, err, + "Page allocated via order %u, mask %#x(%pGg), pid %d, ts %llu ns, free_ts %llu ns\n", + page_owner->order, page_owner->gfp_mask, + &page_owner->gfp_mask, page_owner->pid, + page_owner->ts_nsec, page_owner->free_ts_nsec); /* Print information relevant to grouping pages by mobility */ pageblock_mt = get_pageblock_migratetype(page); page_mt = gfp_migratetype(page_owner->gfp_mask); - ret += snprintf(kbuf + ret, count - ret, - "PFN %lu type %s Block %lu type %s Flags %pGp\n", - pfn, - migratetype_names[page_mt], - pfn >> pageblock_order, - migratetype_names[pageblock_mt], - &page->flags); - - if (ret >= count) - goto err; + SNPRINTF(kbuf, count, ret, err, + "PFN %lu type %s Block %lu type %s Flags %pGp\n", + pfn, migratetype_names[page_mt], + pfn >> pageblock_order, + migratetype_names[pageblock_mt], + &page->flags); ret += stack_depot_snprint(handle, kbuf + ret, count - ret, 0); if (ret >= count) goto err; - if (page_owner->last_migrate_reason != -1) { - ret += snprintf(kbuf + ret, count - ret, + if (page_owner->last_migrate_reason != -1) + SNPRINTF(kbuf, count, ret, err, "Page has been migrated, last migrate reason: %s\n", migrate_reason_names[page_owner->last_migrate_reason]); - if (ret >= count) - goto err; - } - ret += snprintf(kbuf + ret, count - ret, "\n"); - if (ret >= count) - goto err; + SNPRINTF(kbuf, count, ret, err, "\n"); if (copy_to_user(buf, kbuf, ret)) ret = -EFAULT; -- 2.27.0