Received: by 2002:a05:6a10:7420:0:0:0:0 with SMTP id hk32csp386043pxb; Tue, 15 Feb 2022 16:10:00 -0800 (PST) X-Google-Smtp-Source: ABdhPJxknDrLqfRGuflaG7Uhe1g//snytX1jHIOIKHuNeJa5z37v6iIjprw/OpCEdulMzmYHSouR X-Received: by 2002:a63:6c06:0:b0:341:aa1a:28a9 with SMTP id h6-20020a636c06000000b00341aa1a28a9mr80366pgc.35.1644970200301; Tue, 15 Feb 2022 16:10:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1644970200; cv=none; d=google.com; s=arc-20160816; b=LuPmaniIjHHgRAkrLww0fRYtTvBDZoc1tLzgJ9Tb/4w9/apyaF4iTAeFw0mXK+ortB e10wzjjotvzPJ3Ozw/sjKvhoiJ+QwSd3mPGqN0Nn2lW5K2aqTLfQ/HVo6Cfyt+iEuB4z t+8oDyWA8MguNShqQuC1jmV+NkxGQbSsUobARA77VnrH4KDp2tnB/j0U3TLmV1VMC4n2 F720BM1yyHSkdH+QhrfWLa3YbxtLS3yg4Uq6WB4XMyiCbY1hn9xq+5AFmYv1c/KNnXD7 fCjYBpvzIwf9eCI1GlVsq5MT/kzn+MMXSQL5LOVF8wFHpqZXQJkmLaUMXu+VqYSZWG52 qJaA== 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:references:in-reply-to:subject:to:dkim-signature :from; bh=hy8iRKu8vOdVOpyY7EpTR3Hmqze6/ohOyAcjACdy5ZI=; b=G26GI+tMGr+cY5J1pn6Kl17iqbU4vx8Nr2OfZjW2EU7qIm1MK5fbu06GIGYtcoOUIh hpPh5TE+3b4MjPEYEyYYtLzGkO9usjAIMTUU8HNP4fzki2nnrdQY6Zc3eNXTSyjapDVz waNY0cH6tUlw7+XGyOfeqOWCg27l2Tl0zwo3f1eAayw0szFMesUBMp1BY6UeG3pjmFiF UkInAn8DImBHpOmFjOmjtP+ZLb8uj42EsSbb4kPmcVOkh/XlvTd7Yae+9Bs4VQ8XKuRg G6lvcSkcQkwSdJNDyXPgNX/EtAdZ3fD5+Ti7ll/AZ1BR0FSq1nD2KnTYSdNINd2AQoiE fkIw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@toke.dk header.s=20161023 header.b=BHhGm1iv; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=toke.dk Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id j191si4130343pgd.805.2022.02.15.16.09.42; Tue, 15 Feb 2022 16:10:00 -0800 (PST) Received-SPF: pass (google.com: domain of linux-wireless-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=@toke.dk header.s=20161023 header.b=BHhGm1iv; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=toke.dk Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244813AbiBOXb4 (ORCPT + 73 others); Tue, 15 Feb 2022 18:31:56 -0500 Received: from mxb-00190b01.gslb.pphosted.com ([23.128.96.19]:36760 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231760AbiBOXby (ORCPT ); Tue, 15 Feb 2022 18:31:54 -0500 X-Greylist: delayed 574 seconds by postgrey-1.37 at lindbergh.monkeyblade.net; Tue, 15 Feb 2022 15:31:41 PST Received: from mail.toke.dk (mail.toke.dk [IPv6:2a0c:4d80:42:2001::664]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8559B65433; Tue, 15 Feb 2022 15:31:40 -0800 (PST) From: Toke =?utf-8?Q?H=C3=B8iland-J=C3=B8rgensen?= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=toke.dk; s=20161023; t=1644967321; bh=oxkQ8fDff2RyUMjp4s/XquWC9mjWFRhyAC3CN7OibR0=; h=From:To:Subject:In-Reply-To:References:Date:From; b=BHhGm1ivKzDXxW39urxXsDcW9o58WBEd2ZtYXSLxYBzqTWqWg/o0qAcjzaBsESXCA ORStYpUObPZCcUZQnn9becjxPhyYz50ZfF0IpmjyxxV0a3iq61jj8bSUMIMwKrIrfK Zfe3GXZuihe4NZTcFvf1bplfqLMhebGQDqWpovo5X4Dx0MoL0KL4UbEkn4x2hcv0PG BIB0Hy644SZUin9TgUF8p0HLDYki6ts+APQJ0diYsbAr9CPvoCM6TAyjdx182OtatO htMO9mBpeiT8zNtYe8lHHSBE7bvn7GSWXMtt5hDdgLQRI83NuLPhviSslMfvGGGYKj jzyWMuD+cGIkw== To: "Jason A. Donenfeld" , miaoqing@codeaurora.org, Jason Cooper , "Sepehrdad, Pouyan" , ath9k-devel , "linux-wireless@vger.kernel.org" , Kalle Valo , Dominik Brodowski , Linux Crypto Mailing List , Herbert Xu , LKML , Netdev Subject: Re: [PATCH] ath9k: use hw_random API instead of directly dumping into random.c In-Reply-To: <20220215162812.195716-1-Jason@zx2c4.com> References: <20220215162812.195716-1-Jason@zx2c4.com> Date: Wed, 16 Feb 2022 00:22:00 +0100 X-Clacks-Overhead: GNU Terry Pratchett Message-ID: <87o8374sx3.fsf@toke.dk> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-2.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_LOW,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham 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-wireless@vger.kernel.org "Jason A. Donenfeld" writes: > Hardware random number generators are supposed to use the hw_random > framework. This commit turns ath9k's kthread-based design into a proper > hw_random driver. > > This compiles, but I have no hardware or other ability to determine > whether it works. I'll leave further development up to the ath9k > and hw_random maintainers. > > Cc: Toke H=C3=B8iland-J=C3=B8rgensen > Cc: Kalle Valo > Cc: Dominik Brodowski > Cc: Herbert Xu > Signed-off-by: Jason A. Donenfeld > --- > drivers/net/wireless/ath/ath9k/ath9k.h | 2 +- > drivers/net/wireless/ath/ath9k/rng.c | 62 +++++++++----------------- > 2 files changed, 23 insertions(+), 41 deletions(-) > > diff --git a/drivers/net/wireless/ath/ath9k/ath9k.h b/drivers/net/wireles= s/ath/ath9k/ath9k.h > index ef6f5ea06c1f..142f472903dc 100644 > --- a/drivers/net/wireless/ath/ath9k/ath9k.h > +++ b/drivers/net/wireless/ath/ath9k/ath9k.h > @@ -1072,7 +1072,7 @@ struct ath_softc { >=20=20 > #ifdef CONFIG_ATH9K_HWRNG > u32 rng_last; > - struct task_struct *rng_task; > + struct hwrng rng_ops; > #endif > }; >=20=20 > diff --git a/drivers/net/wireless/ath/ath9k/rng.c b/drivers/net/wireless/= ath/ath9k/rng.c > index aae2bd3cac69..369b222908ba 100644 > --- a/drivers/net/wireless/ath/ath9k/rng.c > +++ b/drivers/net/wireless/ath/ath9k/rng.c > @@ -22,9 +22,6 @@ > #include "hw.h" > #include "ar9003_phy.h" >=20=20 > -#define ATH9K_RNG_BUF_SIZE 320 > -#define ATH9K_RNG_ENTROPY(x) (((x) * 8 * 10) >> 5) /* quality: 10/32 */ So this comment says "quality: 10/32" but below you're setting "quality" as 320. No idea what the units are supposed to be, but is this right? > static DECLARE_WAIT_QUEUE_HEAD(rng_queue); >=20=20 > static int ath9k_rng_data_read(struct ath_softc *sc, u32 *buf, u32 buf_s= ize) This function takes buf as a *u32, and interprets buf_size as a number of u32s... > @@ -72,61 +69,46 @@ static u32 ath9k_rng_delay_get(u32 fail_stats) > return delay; > } >=20=20 > -static int ath9k_rng_kthread(void *data) > +static int ath9k_rng_read(struct hwrng *rng, void *buf, size_t max, bool= wait) > { > + struct ath_softc *sc =3D container_of(rng, struct ath_softc, rng_ops); > int bytes_read; > - struct ath_softc *sc =3D data; > - u32 *rng_buf; > - u32 delay, fail_stats =3D 0; > - > - rng_buf =3D kmalloc_array(ATH9K_RNG_BUF_SIZE, sizeof(u32), GFP_KERNEL); > - if (!rng_buf) > - goto out; > - > - while (!kthread_should_stop()) { > - bytes_read =3D ath9k_rng_data_read(sc, rng_buf, > - ATH9K_RNG_BUF_SIZE); > - if (unlikely(!bytes_read)) { > - delay =3D ath9k_rng_delay_get(++fail_stats); > - wait_event_interruptible_timeout(rng_queue, > - kthread_should_stop(), > - msecs_to_jiffies(delay)); > - continue; > - } > - > - fail_stats =3D 0; > - > - /* sleep until entropy bits under write_wakeup_threshold */ > - add_hwgenerator_randomness((void *)rng_buf, bytes_read, > - ATH9K_RNG_ENTROPY(bytes_read)); > - } > + u32 fail_stats =3D 0; >=20=20 > - kfree(rng_buf); > -out: > - sc->rng_task =3D NULL; > +retry: > + bytes_read =3D ath9k_rng_data_read(sc, buf, max); ... but AFAICT here you're calling it with a buffer size from hw_random that's in bytes? -Toke