Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp2466639pxu; Mon, 14 Dec 2020 03:07:37 -0800 (PST) X-Google-Smtp-Source: ABdhPJwGsSTbX5BkQhx41zj5v6rqaTfldlsgeFgGkp17gBL8AIYUGvMn3lz8tejXJ6NVtPmO2ZL8 X-Received: by 2002:a17:906:4e52:: with SMTP id g18mr22693394ejw.385.1607944057245; Mon, 14 Dec 2020 03:07:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607944057; cv=none; d=google.com; s=arc-20160816; b=zMec6xE3zASqJMCfa0NN/pB9Uwy4M9YcqN2+fYkj0rNZB6cFR5TFIAdAR4MXocTBwb EOKYFbMIwFoWjb2VCntoGXxABhbfutEy8UT6Yfxl/ChOnQ/y0IFHR4Sh1qg4w0uTrEFD WevAzxPWI+Pem6mZAe5niXHElpZIZLZix1WvgrnbEeRdcsnqqqX1jDgVrA05iwivQX8D mcF1HiuPiF9lYYN6NQACwE+sd2HZN/nVRaQbgSC2rUCL/ENlog5rSZaPwADGvlkp+L9V VpB8zegQ1Sd/xKsdQWf6v3kLJlihMxwuRVpQT9jKRF93yXwJUcZvAt52zbT+3a+r+AOz hPWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dmarc-filter:sender:dkim-signature; bh=yiNSB5/kL+ebilHZGKTlYMi4SWyHcjVUGoOqsM+QGwk=; b=CNPPU8R07V2yBzT8hL3hvIyazBXXN9M0V8DMloTkj4/+LpkVrPINIBCdqIqlEtNiJn XYIRuoxaoIytNRyRoDePac00Hri0vso1gdNHMw58wgjrqg8lJJJFKwlX816bNwjlMJO7 TzBXU3ZM7C6j2WOvbgcvBBEHFRw20SRO2/Wb+yP1tDyD1eJ58IHbsNfoe8YJ3MWJlUR6 pIZgEUffa0R38KCUKgwV3zYgi8ZOXDrEEES/Xm7tXlrGhFZVLLzVGGJnnEDGG49vosCm oq77Ce0hnzp7TtaqmnVK3fpm8a+LGMndA87I5jCD30fwc0de0Y9d/mYMakd3q9F/e5fQ c1Eg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=tHXtdfoU; 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 c17si10599151eds.556.2020.12.14.03.07.14; Mon, 14 Dec 2020 03:07:37 -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=@mg.codeaurora.org header.s=smtp header.b=tHXtdfoU; 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 S1730020AbgLNKdF (ORCPT + 99 others); Mon, 14 Dec 2020 05:33:05 -0500 Received: from so254-31.mailgun.net ([198.61.254.31]:26336 "EHLO so254-31.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725798AbgLNKdF (ORCPT ); Mon, 14 Dec 2020 05:33:05 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1607941965; h=Content-Transfer-Encoding: Content-Type: In-Reply-To: MIME-Version: Date: Message-ID: From: References: Cc: To: Subject: Sender; bh=yiNSB5/kL+ebilHZGKTlYMi4SWyHcjVUGoOqsM+QGwk=; b=tHXtdfoU61TYe931pmMU54/xtPlp7imFuNFVDLeHY0VHaxABVWBfVOpTs0Kp/GVU5eECCcQq X1jcXtJagk21P4+B3UiUXnSca+JvZ5l5j2zy3stUYIdMADjduEonorvdfSfh5tb6QU8hGhhn VDQ17MA0bdtYavQb5fi9qVye/OY= X-Mailgun-Sending-Ip: 198.61.254.31 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n02.prod.us-west-2.postgun.com with SMTP id 5fd73f4c63480bb0d291aaee (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Mon, 14 Dec 2020 10:32:44 GMT Sender: vjitta=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 2A972C43463; Mon, 14 Dec 2020 10:32:44 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00, NICE_REPLY_A,SPF_FAIL,URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.0 Received: from [192.168.0.105] (unknown [182.18.191.136]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: vjitta) by smtp.codeaurora.org (Postfix) with ESMTPSA id 9FB00C433C6; Mon, 14 Dec 2020 10:32:38 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 9FB00C433C6 Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=fail smtp.mailfrom=vjitta@codeaurora.org Subject: Re: [PATCH v3] lib: stackdepot: Add support to configure STACK_HASH_SIZE To: Alexander Potapenko Cc: Minchan Kim , Vincenzo Frascino , dan.j.williams@intel.com, broonie@kernel.org, Masami Hiramatsu , LKML , Andrew Morton , Andrey Konovalov , qcai@redhat.com, ylal@codeaurora.org, vinmenon@codeaurora.org References: <1607576401-25609-1-git-send-email-vjitta@codeaurora.org> <77e98f0b-c9c3-9380-9a57-ff1cd4022502@codeaurora.org> <6cc89f7b-bf40-2fd3-96ce-2a02d7535c91@codeaurora.org> From: Vijayanand Jitta Message-ID: <255400db-67d5-7f42-8dcb-9a440e006b9d@codeaurora.org> Date: Mon, 14 Dec 2020 16:02:35 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.5.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 12/14/2020 3:04 PM, Alexander Potapenko wrote: > On Mon, Dec 14, 2020 at 5:02 AM Vijayanand Jitta wrote: >> >> >> >> On 12/11/2020 6:55 PM, Alexander Potapenko wrote: >>> On Fri, Dec 11, 2020 at 1:45 PM Vijayanand Jitta wrote: >>>> >>>> >>>> >>>> On 12/11/2020 2:06 PM, Alexander Potapenko wrote: >>>>> On Thu, Dec 10, 2020 at 6:01 AM wrote: >>>>>> >>>>>> From: Yogesh Lal >>>>>> >>>>>> Add a kernel parameter stack_hash_order to configure STACK_HASH_SIZE. >>>>>> >>>>>> Aim is to have configurable value for STACK_HASH_SIZE, so that one >>>>>> can configure it depending on usecase there by reducing the static >>>>>> memory overhead. >>>>>> >>>>>> One example is of Page Owner, default value of STACK_HASH_SIZE lead >>>>>> stack depot to consume 8MB of static memory. Making it configurable >>>>>> and use lower value helps to enable features like CONFIG_PAGE_OWNER >>>>>> without any significant overhead. >>>>> >>>>> Can we go with a static CONFIG_ parameter instead? >>>>> Guess most users won't bother changing the default anyway, and for >>>>> CONFIG_PAGE_OWNER users changing the size at boot time is not strictly >>>>> needed. >>>>> >>>> Thanks for review. >>>> >>>> One advantage of having run time parameter is we can simply set it to a >>>> lower value at runtime if page_owner=off thereby reducing the memory >>>> usage or use default value if we want to use page owner so, we have some >>>> some flexibility here. This is not possible with static parameter as we >>>> have to have some predefined value. >>> >>> If we are talking about a configuration in which page_owner is the >>> only stackdepot user in the system, then for page_owner=off it >>> probably makes more sense to disable stackdepot completely instead of >>> setting it to a lower value. This is a lot easier to do in terms of >>> correctness. >>> But if there are other users (e.g. KASAN), their stackdepot usage may >>> actually dominate that of page_owner. >>> >>>>>> -static struct stack_record *stack_table[STACK_HASH_SIZE] = { >>>>>> - [0 ... STACK_HASH_SIZE - 1] = NULL >>>>>> +static unsigned int stack_hash_order = 20; >>>>> >>>>> Please initialize with MAX_STACK_HASH_ORDER instead. >>>>> >>>> >>>> Sure, will update this. >>>> >>> >>> >>>>>> + >>>>>> +static int __init init_stackdepot(void) >>>>>> +{ >>>>>> + size_t size = (STACK_HASH_SIZE * sizeof(struct stack_record *)); >>>>>> + >>>>>> + stack_table = vmalloc(size); >>>>>> + memcpy(stack_table, stack_table_def, size); >>>>> >>>>> Looks like you are assuming stack_table_def already contains some data >>>>> by this point. >>>>> But if STACK_HASH_SIZE shrinks this memcpy() above will just copy some >>>>> part of the table, whereas the rest will be lost. >>>>> We'll need to: >>>>> - either explicitly decide we can afford losing this data (no idea how >>>>> bad this can potentially be), >>>>> - or disallow storing anything prior to full stackdepot initialization >>>>> (then we don't need stack_table_def), >>>>> - or carefully move all entries to the first part of the table. >>>>> >>>>> Alex >>>>> >>>> >>>> The hash for stack_table_def is computed using the run time parameter >>>> stack_hash_order, though stack_table_def is a bigger array it will only >>>> use the entries that are with in the run time configured STACK_HASH_SIZE >>>> range. so, there will be no data loss during copy. >>> >>> Do we expect any data to be stored into stack_table_def before >>> setup_stack_hash_order() is called? >>> If the answer is no, then we could probably drop stack_table_def and >>> allocate the table right in setup_stack_hash_order()? >>> >> >> Yes, we do see an allocation from stack depot even before init is called >> from kasan, thats the reason for having stack_table_def. >> This is the issue reported due to that on v2, so i added stack_table_def. >> https://lkml.org/lkml/2020/12/3/839 > > But at that point STACK_HASH_SIZE is still equal to 1L << > MAX_STACK_HASH_ORDER, isn't it? > Then we still need to take care of the records that fit into the > bigger array, but not the smaller one. > At this point early_param is already called which sets stack_hash_order. So, STACK_HASH_SIZE will be set to this updated value and not MAX_STACK_HASH_SIZE.So, no additional entires in the bigger array. Thanks, Vijay >> Thanks, >> Vijay >> >>>> Thanks, >>>> Vijay >>>> >>>> -- >>>> QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a >>>> member of Code Aurora Forum, hosted by The Linux Foundation >>> >>> >>> >> >> -- >> QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a >> member of Code Aurora Forum, hosted by The Linux Foundation > > > -- QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation