Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3164648pxf; Sun, 21 Mar 2021 22:15:06 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz92y52UbJ9Vlb3vgnNGkmCiANZt3Zg2/QPiEp/c4+hWnYLPsfeH9gsgMa2jUpLlrlhsCd3 X-Received: by 2002:a17:907:3e92:: with SMTP id hs18mr16961474ejc.396.1616390106190; Sun, 21 Mar 2021 22:15:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616390106; cv=none; d=google.com; s=arc-20160816; b=NVJyJxrsPcE1Gunl2nBAppZeQ/GU1swe/2GnMeCk2v1K4ZR7VRPqHrwu8ndzFHc/c8 S6fpI40NCGRvz5cZ1dHRjG9w2Y+x6I2JKqKCgf9UeL5Z/g5pM6OUbH+IIyYgT6ICCJ8z N/1A3KtKkrk55yhCvNNcv4t1MkVYuLyTbr9m+gzmwdy2xtoBrYoAa1jrtS3YXF3TDqBG M5rVIomOKsXb2PA2c72txCkpZYE5Ai5guvQIPzDkbQdYX0M1RaMRhq5EDquMOf72unok sf6E8TfRdKfjdYdPGLMiu9/LCF+xbK/Qs0IOYgdCKQlq4KbNgIdjnwNLwaViK+cVt/9E r0cg== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=DZrbUhe2Bt3vvxQ3QU07EAdvACpKFvcnJ9gytsfcasU=; b=BHwh5HngPuW1KEo7c+S0yPnGOg7WU6kAM3n6xCWrVW+g5M00egEdP8fKXmfLFvPkXi YIzGfrt7Ov9MhXYfUeIGBbqtc0b4UBAeIIK2/mOGF75rL/9778UcU7AxwGSShWfbiGHQ 6GOQ9c+/bK7O4M5W9PLN0hQxZBpFCNsSs7ftlpvWZiowhBueMBzwtziPlGMWL6vQ10e2 HZKP1/OJ4RE0APrAx+YuNp7EG8BD4bCLScmVf04oFoUNB4Zx2eYXP17UvgvUeilUO2qs K+Cs+BGkUugswWpz09VOMCOyuF2AwROGlVqnx9FX1YsoJv+Xu6t7RHBEkia2xRXt3Gn2 1tmg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Ouusz8aa; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id jg8si10937427ejc.657.2021.03.21.22.14.42; Sun, 21 Mar 2021 22:15:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-crypto-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=@kernel.org header.s=k20201202 header.b=Ouusz8aa; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-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 S229455AbhCVFON (ORCPT + 99 others); Mon, 22 Mar 2021 01:14:13 -0400 Received: from mail.kernel.org ([198.145.29.99]:43880 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229547AbhCVFOD (ORCPT ); Mon, 22 Mar 2021 01:14:03 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 228EE61966; Mon, 22 Mar 2021 05:14:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1616390043; bh=kvzUarcK5ql0ZCwi4iYGL+4ZF5ovTepKQPphb29B/zw=; h=From:To:Cc:Subject:Date:From; b=Ouusz8aa/JfyyLv5IsUnBfS4leVXVO8pUKNA2XGUsG0hxH1bIpG0u6EQENnrwjp0U FdI03Dy1VGZ6jIECYoTMZR4VHAGnS4kE9zC1DlQHRKsVqc26qQr/GbR5eDJ4JnXdo/ wPHW8UUwB5QlIK7woIo2vOv4CNv0ewe0xy1VMRtB3wEo1DV78g5X/Ga9MbzgL9poyT GTDxRm3K8uhI71GNxaqjWX2GZwQVyNSA5hg1F1ajUahyvF8mJ3B276AHGcngOndH7J y+WfWeefFdXQ8R1e9lYAhIKm1PvYmEsUA0IkF7wDjesaEnYQiNz8QWSxf534AArqEv WYXSngtXh1RxA== From: Eric Biggers To: Theodore Ts'o Cc: linux-kernel@vger.kernel.org, linux-crypto@vger.kernel.org, Andy Lutomirski , Jann Horn , Ard Biesheuvel Subject: [PATCH RESEND] random: remove dead code left over from blocking pool Date: Sun, 21 Mar 2021 22:14:00 -0700 Message-Id: <20210322051400.266903-1-ebiggers@kernel.org> X-Mailer: git-send-email 2.31.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org From: Eric Biggers Remove some dead code that was left over following commit 90ea1c6436d2 ("random: remove the blocking pool"). Cc: linux-crypto@vger.kernel.org Cc: Andy Lutomirski Cc: Jann Horn Cc: Theodore Ts'o Reviewed-by: Andy Lutomirski Acked-by: Ard Biesheuvel Signed-off-by: Eric Biggers --- drivers/char/random.c | 17 ++----- include/trace/events/random.h | 83 ----------------------------------- 2 files changed, 3 insertions(+), 97 deletions(-) diff --git a/drivers/char/random.c b/drivers/char/random.c index 5d6acfecd919b..605969ed0f965 100644 --- a/drivers/char/random.c +++ b/drivers/char/random.c @@ -500,7 +500,6 @@ struct entropy_store { unsigned short add_ptr; unsigned short input_rotate; int entropy_count; - unsigned int initialized:1; unsigned int last_data_init:1; __u8 last_data[EXTRACT_SIZE]; }; @@ -660,7 +659,7 @@ static void process_random_ready_list(void) */ static void credit_entropy_bits(struct entropy_store *r, int nbits) { - int entropy_count, orig, has_initialized = 0; + int entropy_count, orig; const int pool_size = r->poolinfo->poolfracbits; int nfrac = nbits << ENTROPY_SHIFT; @@ -717,23 +716,14 @@ static void credit_entropy_bits(struct entropy_store *r, int nbits) if (cmpxchg(&r->entropy_count, orig, entropy_count) != orig) goto retry; - if (has_initialized) { - r->initialized = 1; - kill_fasync(&fasync, SIGIO, POLL_IN); - } - trace_credit_entropy_bits(r->name, nbits, entropy_count >> ENTROPY_SHIFT, _RET_IP_); if (r == &input_pool) { int entropy_bits = entropy_count >> ENTROPY_SHIFT; - if (crng_init < 2) { - if (entropy_bits < 128) - return; + if (crng_init < 2 && entropy_bits >= 128) crng_reseed(&primary_crng, r); - entropy_bits = ENTROPY_BITS(r); - } } } @@ -1372,8 +1362,7 @@ static size_t account(struct entropy_store *r, size_t nbytes, int min, } /* - * This function does the actual extraction for extract_entropy and - * extract_entropy_user. + * This function does the actual extraction for extract_entropy. * * Note: we assume that .poolwords is a multiple of 16 words. */ diff --git a/include/trace/events/random.h b/include/trace/events/random.h index 9570a10cb949b..3d7b432ca5f31 100644 --- a/include/trace/events/random.h +++ b/include/trace/events/random.h @@ -85,28 +85,6 @@ TRACE_EVENT(credit_entropy_bits, __entry->entropy_count, (void *)__entry->IP) ); -TRACE_EVENT(push_to_pool, - TP_PROTO(const char *pool_name, int pool_bits, int input_bits), - - TP_ARGS(pool_name, pool_bits, input_bits), - - TP_STRUCT__entry( - __field( const char *, pool_name ) - __field( int, pool_bits ) - __field( int, input_bits ) - ), - - TP_fast_assign( - __entry->pool_name = pool_name; - __entry->pool_bits = pool_bits; - __entry->input_bits = input_bits; - ), - - TP_printk("%s: pool_bits %d input_pool_bits %d", - __entry->pool_name, __entry->pool_bits, - __entry->input_bits) -); - TRACE_EVENT(debit_entropy, TP_PROTO(const char *pool_name, int debit_bits), @@ -161,35 +139,6 @@ TRACE_EVENT(add_disk_randomness, MINOR(__entry->dev), __entry->input_bits) ); -TRACE_EVENT(xfer_secondary_pool, - TP_PROTO(const char *pool_name, int xfer_bits, int request_bits, - int pool_entropy, int input_entropy), - - TP_ARGS(pool_name, xfer_bits, request_bits, pool_entropy, - input_entropy), - - TP_STRUCT__entry( - __field( const char *, pool_name ) - __field( int, xfer_bits ) - __field( int, request_bits ) - __field( int, pool_entropy ) - __field( int, input_entropy ) - ), - - TP_fast_assign( - __entry->pool_name = pool_name; - __entry->xfer_bits = xfer_bits; - __entry->request_bits = request_bits; - __entry->pool_entropy = pool_entropy; - __entry->input_entropy = input_entropy; - ), - - TP_printk("pool %s xfer_bits %d request_bits %d pool_entropy %d " - "input_entropy %d", __entry->pool_name, __entry->xfer_bits, - __entry->request_bits, __entry->pool_entropy, - __entry->input_entropy) -); - DECLARE_EVENT_CLASS(random__get_random_bytes, TP_PROTO(int nbytes, unsigned long IP), @@ -253,38 +202,6 @@ DEFINE_EVENT(random__extract_entropy, extract_entropy, TP_ARGS(pool_name, nbytes, entropy_count, IP) ); -DEFINE_EVENT(random__extract_entropy, extract_entropy_user, - TP_PROTO(const char *pool_name, int nbytes, int entropy_count, - unsigned long IP), - - TP_ARGS(pool_name, nbytes, entropy_count, IP) -); - -TRACE_EVENT(random_read, - TP_PROTO(int got_bits, int need_bits, int pool_left, int input_left), - - TP_ARGS(got_bits, need_bits, pool_left, input_left), - - TP_STRUCT__entry( - __field( int, got_bits ) - __field( int, need_bits ) - __field( int, pool_left ) - __field( int, input_left ) - ), - - TP_fast_assign( - __entry->got_bits = got_bits; - __entry->need_bits = need_bits; - __entry->pool_left = pool_left; - __entry->input_left = input_left; - ), - - TP_printk("got_bits %d still_needed_bits %d " - "blocking_pool_entropy_left %d input_entropy_left %d", - __entry->got_bits, __entry->got_bits, __entry->pool_left, - __entry->input_left) -); - TRACE_EVENT(urandom_read, TP_PROTO(int got_bits, int pool_left, int input_left), -- 2.31.0