Received: by 2002:a05:6602:18e:0:0:0:0 with SMTP id m14csp1658693ioo; Sun, 22 May 2022 23:20:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz4JjeSJN6I9pd3nBz+aRTFNbLebXIoL00PrjgWORNjPQQLRc1cvZ6aNILMND4NGuitIcTQ X-Received: by 2002:a05:6a00:a85:b0:4e0:57a7:2d5d with SMTP id b5-20020a056a000a8500b004e057a72d5dmr22269436pfl.81.1653286824781; Sun, 22 May 2022 23:20:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1653286824; cv=none; d=google.com; s=arc-20160816; b=nkV5CGyfCXxpzN4ic3+RYRFR8QdTLR+cGJa5GQzysoywvsIntt2gL4Obbuy9eGX46f 5lCEySG5oCHQFbpCVtZ8gx7b/2s1M29ieUpSUhQnG23Ja1l1mHCzJuCouLPab3GAxhIi ljweg1KnYqLqGY0ORbsuG0parWOmIYlJmcjOPpOineqBwtYqUxYOugoBDpZOcrIrBnlP l+GQMyntENOkr9FbBW3eBkFKLZeIs4Mv00uc1cC26fNMsRGdzy0r7bxZz3+3PnZmGCCm Gr4PCsuimjekAsKFCYrivAEQ7nJUUmJGfRDqRLX5SUnttT1yB2I5btv39HvJhvIqeUyT G6Cg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=8UOFKpBlVl67udR+va19FltTZxwf5dr1CAwPsKAWcf8=; b=JoN4DSx2sG9Gz7aIz3Ty0disTOAAQFi8AZ/KFN57UXj20Rv3WkAwo6CR5twHGqfaIk URZkfMn3cvLP+ZjRLrV4rqBff4ea7iOBYZsdykr+cYe7qTQCiaWANLCmjxSDfAV2U6OQ gNxH1/riu3rZSwjbppYsQCU8Th5y2zFavKkaCLmDff56evCjyaTga82kKSbxfT8sdxkm TpJ8bzVA5ZgjWAQOhO0QsQySvVbNtzKYG4I+5ZqNaNL3ioingfpJZjJm1URRQ2P1Z1at 06ifNZ3tnMsdzpnOELrnw81PCAVjvBddhTZnLU53q192tv2SbvdaZ80vr7NWYI8hCgS0 1EMQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel-dk.20210112.gappssmtp.com header.s=20210112 header.b="I3/C3Iwr"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id t28-20020a63461c000000b003f27e1916bbsi9775576pga.162.2022.05.22.23.20.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 22 May 2022 23:20:24 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel-dk.20210112.gappssmtp.com header.s=20210112 header.b="I3/C3Iwr"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id B4E5B433BC; Sun, 22 May 2022 23:04:18 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1343522AbiESXVj (ORCPT + 99 others); Thu, 19 May 2022 19:21:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38386 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343559AbiESXVf (ORCPT ); Thu, 19 May 2022 19:21:35 -0400 Received: from mail-pj1-x1035.google.com (mail-pj1-x1035.google.com [IPv6:2607:f8b0:4864:20::1035]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BF6E657B3D for ; Thu, 19 May 2022 16:21:34 -0700 (PDT) Received: by mail-pj1-x1035.google.com with SMTP id a23-20020a17090acb9700b001df4e9f4870so6506204pju.1 for ; Thu, 19 May 2022 16:21:34 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kernel-dk.20210112.gappssmtp.com; s=20210112; h=message-id:date:mime-version:user-agent:subject:content-language:to :cc:references:from:in-reply-to:content-transfer-encoding; bh=8UOFKpBlVl67udR+va19FltTZxwf5dr1CAwPsKAWcf8=; b=I3/C3Iwr52u1ma3ooqmr93RnTeH1cdvDfV0lMBY7P7csxL1nmN1rVVxlaovF8MYTtZ u0Z9fGxyqocP6JD9SyidLnUkQF3xuPkP0usRS/igsCKNWMH/zENplRkL6zwkvmSyfblp hHl9crw7cunS1EO5vLvfWYGZlys3FhnXKKXo2gLVPMXf1T7/K8V367nJXgeX3DlBW9iE ZS71CNqq5EJ/oGrpa9j6ne05oAEIJYrvhE229D37iiM63kIsFmObkk++KnZrHwaLRdaB 0mXb23078z/V7GNYUFssoSkWgQFvtR4PvgIzfvvy37f4rY0BAoKskiAq19F939643/bq WnDg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :content-language:to:cc:references:from:in-reply-to :content-transfer-encoding; bh=8UOFKpBlVl67udR+va19FltTZxwf5dr1CAwPsKAWcf8=; b=Ye8bAU6mMidvIoPatZT7qRkIL14PCi+8/61mZqX4DvG6SkEVY1BSebaxsLVZceKchX 3BFyB4478FIkrJXZNG9D0Crqkp21OJCIlvr9Gp/G5qHz0acCs/L06ibXtBV12e49jHjr mZpRd9ZOrBQPoytOZDUCOGKUEELDbt899UsWqwcWRP+9Qaf7K8WPwwj68/SDDkPo90Zr CHE3/C3/gdceq775cZAccFfCaZaFsJGw6k8UlXzl939u8s3o/HdCIdBpgeKIYRVaX5nM hNhvRFGbsmCQaAmoM7pPgmSrTLsWOuq/Pvy7Hd+HUEgbx8cYuqTg20ePAKa3w25gQCOA 5aAg== X-Gm-Message-State: AOAM530IQJMq12uoNwn/Meuyv/BE9qZCT3croz20RdPrk5JdEwnn9Rxp c/vTozTYPKWiEOH60PvnyMuz7w== X-Received: by 2002:a17:902:8645:b0:15f:2eb5:3d49 with SMTP id y5-20020a170902864500b0015f2eb53d49mr6875545plt.42.1653002494223; Thu, 19 May 2022 16:21:34 -0700 (PDT) Received: from [192.168.1.100] ([198.8.77.157]) by smtp.gmail.com with ESMTPSA id x21-20020a1709027c1500b001613dfe1678sm4228322pll.273.2022.05.19.16.21.33 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 19 May 2022 16:21:33 -0700 (PDT) Message-ID: <8251e0d7-d506-16ea-7bc8-4c8bf098deea@kernel.dk> Date: Thu, 19 May 2022 17:21:32 -0600 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux aarch64; rv:91.0) Gecko/20100101 Thunderbird/91.8.1 Subject: Re: [PATCH 1/2] random: convert to using fops->read_iter() Content-Language: en-US To: "Jason A. Donenfeld" Cc: tytso@mit.edu, hch@lst.de, linux-kernel@vger.kernel.org References: <20220519193133.194138-1-axboe@kernel.dk> <20220519193133.194138-2-axboe@kernel.dk> From: Jens Axboe In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-3.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, NICE_REPLY_A,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable 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 5/19/22 5:20 PM, Jason A. Donenfeld wrote: > On Fri, May 20, 2022 at 01:12:04AM +0200, Jason A. Donenfeld wrote: >> Hi Jens, >> >> On Thu, May 19, 2022 at 01:31:32PM -0600, Jens Axboe wrote: >>> for (;;) { >>> chacha20_block(chacha_state, output); >>> if (unlikely(chacha_state[12] == 0)) >>> ++chacha_state[13]; >>> >>> block_len = min_t(size_t, len, CHACHA_BLOCK_SIZE); >>> - left = copy_to_user(ubuf, output, block_len); >>> - if (left) { >>> - ret += block_len - left; >>> + block_len = copy_to_iter(output, block_len, to); >>> + if (!block_len) >>> break; >>> - } >>> >>> - ubuf += block_len; >>> ret += block_len; >>> len -= block_len; >>> - if (!len) >>> - break; >>> >>> BUILD_BUG_ON(PAGE_SIZE % CHACHA_BLOCK_SIZE != 0); >>> if (ret % PAGE_SIZE == 0) { >>> if (signal_pending(current)) >>> break; >>> cond_resched(); >>> } >>> } >> >> This isn't quite the same, is it? Before, it would immediately break out >> of the loop on any short copy. Now, it will only break out on a zero >> copy, which means it's possible that ret % PAGE_SIZE == 0, and there'll >> be an unnecessary cond_resched() before copy_to_iter() runs again and >> then breaks. > > Maybe something like the below would do the trick? > > > static ssize_t get_random_bytes_user(struct iov_iter *to) > { > size_t block_len, copied, ret = 0, len = iov_iter_count(to); > u32 chacha_state[CHACHA_STATE_WORDS]; > u8 output[CHACHA_BLOCK_SIZE]; > > if (!len) > return 0; > > /* > * Immediately overwrite the ChaCha key at index 4 with random > * bytes, in case userspace causes copy_to_user() below to sleep > * forever, so that we still retain forward secrecy in that case. > */ > crng_make_state(chacha_state, (u8 *)&chacha_state[4], CHACHA_KEY_SIZE); > /* > * However, if we're doing a read of len <= 32, we don't need to > * use chacha_state after, so we can simply return those bytes to > * the user directly. > */ > if (len <= CHACHA_KEY_SIZE) { > ret = copy_to_iter(&chacha_state[4], len, to); > goto out_zero_chacha; > } > > for (;;) { > chacha20_block(chacha_state, output); > if (unlikely(chacha_state[12] == 0)) > ++chacha_state[13]; > > block_len = min_t(size_t, len, CHACHA_BLOCK_SIZE); > copied = copy_to_iter(output, block_len, to); > ret += copied; > if (block_len != copied) > break; > len -= copied; Yep, that looks good! Do you still want a v2? -- Jens Axboe