Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp1353644rwb; Thu, 8 Dec 2022 09:32:35 -0800 (PST) X-Google-Smtp-Source: AA0mqf7gp1dCxrzjQyqBl0+7hX8/ym4pwNtzNVsF9h4LIljJnJrpcEu+GjMCR/kmTq1sMpb0o3v0 X-Received: by 2002:a05:6402:538a:b0:458:fbd9:e3b1 with SMTP id ew10-20020a056402538a00b00458fbd9e3b1mr28122828edb.6.1670520755360; Thu, 08 Dec 2022 09:32:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1670520755; cv=none; d=google.com; s=arc-20160816; b=HmKt2AUnY1vvn4KrXP/gyV43SVKNHkCsqYoJcRequsVhLt9gi9pk9a+6wchAWtSMn3 2YVexNaCt2soa5iw/y/WxbKoWIJo9uz2tB4DhT1333AGkHSIVb/cdTw5LF/Prx5onDal OhqLy/DKvGYyvgEg0cLRYMivN/1PYvK4VktlnJsXqdWNxDjSsh4YIICdyOTqiWpzcXAd ubzaRtBvNHtg8E0A4cYncZWhTY3US3x35TgUHHfU1tTc+2xW2R8EY6t0E5YfqF1zyqbm dzOwJm1lf9KImYDoEJdmIUeSdDFm0a6SRnynu5hPlR9p0bUfFAcS59XzNtqHVr59pZZh C8og== 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-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:sender:dkim-signature; bh=q0YLsvBKzhSCVgibbSxOvtb/WdQ/EJIsYcqmRJMPdrA=; b=LDzD5LZ4wKPeRHzdr2XtbTeP3zXggJj8Gbohsny9c7tWdhhmZ/AJ7PWAxyS13bVzlz LIsf9hMxzzww3MQcaklmCQiMvxAjBr0O2u9wRWskEUQJcihT6L6IoIKdcDEQJe1FRLbm he7DSGIkDoXvRmB0FuA7pBh0fmv9OwTIlRlyXXyFYImSNPSsNJUkOSHutKyb7Ty+s6rq e/+po/6wwooe1+n9dmaJUJGJeajr9UIaPl0y2STXxs6WdOIwKfRP5BzSJiQy6f6KmkIT +6QnwJngK1RupMIVOSMYaQcoYKl4Hhi799qjF1gAATkJuLJa/qkfwTmMrTnovns1wD36 XJWA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=LKqMi50u; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id c7-20020a05640227c700b00458d1c48708si7516468ede.303.2022.12.08.09.32.00; Thu, 08 Dec 2022 09:32:35 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=LKqMi50u; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229619AbiLHP7n (ORCPT + 72 others); Thu, 8 Dec 2022 10:59:43 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45838 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229514AbiLHP7k (ORCPT ); Thu, 8 Dec 2022 10:59:40 -0500 Received: from mail-pg1-x533.google.com (mail-pg1-x533.google.com [IPv6:2607:f8b0:4864:20::533]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F06E889AEA; Thu, 8 Dec 2022 07:59:38 -0800 (PST) Received: by mail-pg1-x533.google.com with SMTP id 6so1506729pgm.6; Thu, 08 Dec 2022 07:59:38 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=in-reply-to:content-transfer-encoding:content-disposition :mime-version:references:message-id:subject:cc:to:from:date:sender :from:to:cc:subject:date:message-id:reply-to; bh=q0YLsvBKzhSCVgibbSxOvtb/WdQ/EJIsYcqmRJMPdrA=; b=LKqMi50ut5W+4QYLYDzZRJz8rOYDM1FZOI+bsaRUBjbfPxkaXOkGHv/B58zlQJCVp9 MOjRUaRqxNz0nLVuO6/F76JbXbGZitk+2iyDmotSKGPXPoVVHHddmOrwt9KP6Mv6y5Xd SxD/qLNSLtneYFA9954fdAcCxDvWe7t+RaCdqX50dbiBJuc0xdbdRlVvJKMOZr6k2AeA UN4OLtD63b3uEgMi5eMop+qH9rGyXYzEIxZ1PinFgbvoWMIZ8pq6K8gfKFZ/b8EHRO6N rXk0i0ECbUePeDcBgMkYPccKs/o9Q4EQc3aSt5FYGtktl4E40BnuiUuFe8kE39ATlds/ GDuA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=in-reply-to:content-transfer-encoding:content-disposition :mime-version:references:message-id:subject:cc:to:from:date:sender :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=q0YLsvBKzhSCVgibbSxOvtb/WdQ/EJIsYcqmRJMPdrA=; b=p01k9VIyA0yWCShjml6FkmnPt8vCsCvHHJeUMDkO4GTJGDsx9OVzUvqyJ6MH6KKten +1Gnvsz2qTHoMc0HGi69hCleoP+ZkA92oKLTkGD9lNCxMiwjZIo4SaJXAbEjhAoEEtps JLjRWHcpsaKxdDE2Tx4TDGU7XsyC5/RncrhogMMszqFGi09WoTA3IuOjUSQyaPAXQqMz 9DNP9zU9HfqPldmDN7cSImo6zBxXZk/oaao/qeTdlGqYgUP7tZdj982F3+8Nq4FG8AlQ itHwA5+hVjan7yOjxAUmFjJWdt9GeCX6e8GjgThzHJyTEVXV/EPUPvQuHiHX7Ernd+Gz mUuQ== X-Gm-Message-State: ANoB5pnBVZWk2rSxif8tPhrfCDn/o/SjxjhtXZAtRy3dRCJ98z8ruKSW 30OB2ZL3jkM+EOUE1C8NYtQ= X-Received: by 2002:a62:648a:0:b0:572:76dd:3756 with SMTP id y132-20020a62648a000000b0057276dd3756mr78402506pfb.9.1670515178140; Thu, 08 Dec 2022 07:59:38 -0800 (PST) Received: from localhost (2603-800c-1a02-1bae-a7fa-157f-969a-4cde.res6.spectrum.com. [2603:800c:1a02:1bae:a7fa:157f:969a:4cde]) by smtp.gmail.com with ESMTPSA id ij22-20020a170902ab5600b001893a002107sm16781662plb.0.2022.12.08.07.59.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 08 Dec 2022 07:59:37 -0800 (PST) Sender: Tejun Heo Date: Thu, 8 Dec 2022 05:59:36 -1000 From: Tejun Heo To: Yu Kuai Cc: Jens Axboe , hch@lst.de, josef@toxicpanda.com, cgroups@vger.kernel.org, linux-block@vger.kernel.org, linux-kernel@vger.kernel.org, yi.zhang@huawei.com, "yukuai (C)" Subject: Re: [PATCH v2 4/5] blk-iocost: fix sleeping in atomic context warnning Message-ID: References: <20221104023938.2346986-1-yukuai1@huaweicloud.com> <20221104023938.2346986-5-yukuai1@huaweicloud.com> <3da991c6-21e4-8ed8-ba75-ccb92059f0ae@huaweicloud.com> <1f52ccb1-c357-a2a0-ef9d-48d7e2eb51f8@kernel.dk> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-Spam-Status: No, score=-1.5 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE, SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Dec 05, 2022 at 05:39:33PM +0800, Yu Kuai wrote: > Hi, Tejun > > 在 2022/11/23 18:22, Yu Kuai 写道: > > Hi, Tejun > > > > 在 2022/11/23 8:42, Tejun Heo 写道: > > > On Tue, Nov 22, 2022 at 05:14:29PM -0700, Jens Axboe wrote: > > > > > > Then match_strdup() and kfree() in match_NUMBER() can be replaced with > > > > > > get_buffer() and put_buffer(). > > > > > > > > > > Sorry about the late reply. Yeah, something like this. > > > > I wonder can we just use arary directly in stack? The max size is just > 24 bytes, which should be fine: > > HEX: "0xFFFFFFFFFFFFFFFF" --> 18 > DEC: "18446744073709551615" --> 20 > OCT: "01777777777777777777777" --> 23 > > Something like: > #define U64_MAX_SIZE 23 > static int match_strdup_local(const substring_t *s, char *buf) > { > size_t len = s->to - s->from; > > if (len > U64_MAX_SIZE) > return -ERANGE; > > if (!s->from) > return -EINVAL; > > memcpy(buf, s->from, len); > buf[len] = '\0'; > return 0; > } > > static int match_u64int(substring_t *s, u64 *result, int base) > { > char buf[U64_MAX_SIZE + 1]; > int ret; > u64 val; > > ret = match_strdup_local(s, buf); > if (ret) > return ret; > ret = kstrtoull(buf, base, &val); > if (!ret) > *result = val;; > return ret; > } Oh yeah, absolutely. That's much better. Thanks. -- tejun