Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp3709470ybl; Mon, 27 Jan 2020 08:58:50 -0800 (PST) X-Google-Smtp-Source: APXvYqwUUIzYypAhfbcoLU1GqqlJcYQEHyrVvNeaggmujODq14nbpupWNu0lLZlzUTi3s3g38Wz8 X-Received: by 2002:aca:32c3:: with SMTP id y186mr10490oiy.114.1580144330110; Mon, 27 Jan 2020 08:58:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580144330; cv=none; d=google.com; s=arc-20160816; b=lPbmK7ItqXsg2Rzm5TeypQTjsyZlwfC1XPT4HYu96dLUtqz3rYckbr3+peyObCxixM v52tgdyccpdMIchD4rVHuuePqINY2eb8JSzkeHBbo9FvWN69MeBMrnB6Oq3olV/RJJ2O prlIWLg8k2DK3yPq5qnGHDcxt8M2LfHkiLJWaYJf6cShnIv/ky6UFYTPFWzL6ZYpJJ+9 r8Cp5TlffPY3CWplXBrEctbo4maT4hvLD1m4GvXs6Bh//u0g9lap6T/b99JSEaY3p+8g 0tyPtp920EzGPHRIVYfdjBQ71BEu6qWn+rLOpPV9z1RIAuM1C1qDviNJsJZmv78FwTZd GVew== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=TcjeClmRH5R/km2Nzp0idBoWoVhmeZ5+erKgXpUxBBo=; b=Bm8Df95C8AXDuZN2ZTs2n1TGMjYHyyZOSdO6vX/4GA2TNLXvWaEfog0QBtRF7JoMLB yTUqvIXygDzXbGsKHjFn2/J9Y/wnpZKXTzpTbF01234MaOH24IqeBClf/RTej7wZgHti vzeEKgu7wSOAOqsToTAgg+BYaf2O3h3jfmIVjEc96qJPuMfqCFLyoQbUYvZH4XkSp1C+ LI17tgufEKMsTgTbxmfgo1MkSHLJK/z7ptl8t4/MwTnSrdINx8keZoqyybwWazyqNZUN drj01cGLGQaBTZrOg56pygmDejbymyS+aDfhpKSOo3D6eAUGuAVJV+DQ4I6Xi7f5/d/C 9D6A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Q1Mtlft6; spf=pass (google.com: best guess record for domain of linux-crypto-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l21si277094otd.1.2020.01.27.08.58.38; Mon, 27 Jan 2020 08:58:50 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-crypto-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Q1Mtlft6; spf=pass (google.com: best guess record for domain of linux-crypto-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726565AbgA0Q5k (ORCPT + 99 others); Mon, 27 Jan 2020 11:57:40 -0500 Received: from mail-pl1-f196.google.com ([209.85.214.196]:36305 "EHLO mail-pl1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726428AbgA0Q5I (ORCPT ); Mon, 27 Jan 2020 11:57:08 -0500 Received: by mail-pl1-f196.google.com with SMTP id a6so3964531plm.3; Mon, 27 Jan 2020 08:57:08 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=TcjeClmRH5R/km2Nzp0idBoWoVhmeZ5+erKgXpUxBBo=; b=Q1Mtlft6a4GSlcQtk4C4LnJ99CA+QFsHXr5JBozHH5iFzbtVMefOlsAH5dmjNQdK4o PQadM0OxOiJXWgs9yy0RXFeYcGfDroruZDrkxtR8K5Kio5OANuPCeu+ph8Foq/B+osG5 TWVeDkU9d2CsVaX14ZAmUzt39n4uCsnWKQ5dTxfXVWQeHNq5GRy6XlvH2nal1g2dDMFz OvbwJbfkfMY1QWXA/q5juX8BBRO71y7WiFnUl3tcUbu0Fj/09Mq/5y7yv7q2oX+jmYS4 6JXpFz45+UpQeq70Ltgz8ZmyBWFf1vYwLx6ymWRhe5aXXMsxNWaL7FWQc9sOrLkcRG3y WukA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=TcjeClmRH5R/km2Nzp0idBoWoVhmeZ5+erKgXpUxBBo=; b=Sq5513e64hEmvWCqd7aUT7LMupt0MtNCLAvofIdmIgXWFbvaKEBxiONp2R14DSiAEG eFHB5ksCJGayGA+Y6BvaOT8rCYG/944yvmF5C57w2kDLs7yzOVpT4tUSI6VwH1Z00Rh/ bYttsjXxM4GKW6D3TtfFKDra09Z0yEdzI7QLCQc5H5Sj1Ob5p1JqBnZEOe9o+X2aVAgO um8uJVACGrvgbfkMvvGG2tVLPLlF0+6/J5LjTsZqkQnPlJTO90Wc7UUfSeu79gzcC1Z1 wV0ym8WsA0VZABtZn4+DOxyZJxvk6tYHvX5nIh9XrxsUW2Cjbbba5siwoLrX+E/dvban ah3g== X-Gm-Message-State: APjAAAW3LIOp+fqTUFEys7FDkAmVYOnPwXU+1ycjz09hb8LgvRyV3vFA ujTtcaWb3ir7cHQ2kqxCuz4iB2aO X-Received: by 2002:a17:902:8495:: with SMTP id c21mr18782308plo.279.1580144227787; Mon, 27 Jan 2020 08:57:07 -0800 (PST) Received: from localhost.localdomain (c-67-165-113-11.hsd1.wa.comcast.net. [67.165.113.11]) by smtp.gmail.com with ESMTPSA id u23sm16368642pfm.29.2020.01.27.08.57.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 27 Jan 2020 08:57:06 -0800 (PST) From: Andrey Smirnov To: linux-crypto@vger.kernel.org Cc: Andrey Smirnov , Chris Healy , Lucas Stach , =?UTF-8?q?Horia=20Geant=C4=83?= , Herbert Xu , Iuliana Prodan , linux-kernel@vger.kernel.org, linux-imx@nxp.com Subject: [PATCH v7 2/9] crypto: caam - use struct hwrng's .init for initialization Date: Mon, 27 Jan 2020 08:56:39 -0800 Message-Id: <20200127165646.19806-3-andrew.smirnov@gmail.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20200127165646.19806-1-andrew.smirnov@gmail.com> References: <20200127165646.19806-1-andrew.smirnov@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-crypto-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org Make caamrng code a bit more symmetric by moving initialization code to .init hook of struct hwrng. Signed-off-by: Andrey Smirnov Cc: Chris Healy Cc: Lucas Stach Cc: Horia Geantă Cc: Herbert Xu Cc: Iuliana Prodan Cc: linux-crypto@vger.kernel.org Cc: linux-kernel@vger.kernel.org Cc: linux-imx@nxp.com --- drivers/crypto/caam/caamrng.c | 47 ++++++++++++++++++----------------- 1 file changed, 24 insertions(+), 23 deletions(-) diff --git a/drivers/crypto/caam/caamrng.c b/drivers/crypto/caam/caamrng.c index e8baacaabe07..1ce7fbd29e85 100644 --- a/drivers/crypto/caam/caamrng.c +++ b/drivers/crypto/caam/caamrng.c @@ -256,6 +256,7 @@ static void caam_cleanup(struct hwrng *rng) } rng_unmap_ctx(rng_ctx); + caam_jr_free(rng_ctx->jrdev); } static int caam_init_buf(struct caam_rng_ctx *ctx, int buf_id) @@ -274,28 +275,43 @@ static int caam_init_buf(struct caam_rng_ctx *ctx, int buf_id) return 0; } -static int caam_init_rng(struct caam_rng_ctx *ctx, struct device *jrdev) +static int caam_init(struct hwrng *rng) { + struct caam_rng_ctx *ctx = rng_ctx; int err; - ctx->jrdev = jrdev; + ctx->jrdev = caam_jr_alloc(); + err = PTR_ERR_OR_ZERO(ctx->jrdev); + if (err) { + pr_err("Job Ring Device allocation for transform failed\n"); + return err; + } err = rng_create_sh_desc(ctx); if (err) - return err; + goto free_jrdev; ctx->current_buf = 0; ctx->cur_buf_idx = 0; err = caam_init_buf(ctx, 0); if (err) - return err; + goto free_jrdev; + + err = caam_init_buf(ctx, 1); + if (err) + goto free_jrdev; - return caam_init_buf(ctx, 1); + return 0; + +free_jrdev: + caam_jr_free(ctx->jrdev); + return err; } static struct hwrng caam_rng = { .name = "rng-caam", + .init = caam_init, .cleanup = caam_cleanup, .read = caam_read, }; @@ -305,14 +321,12 @@ void caam_rng_exit(void) if (!init_done) return; - caam_jr_free(rng_ctx->jrdev); hwrng_unregister(&caam_rng); kfree(rng_ctx); } int caam_rng_init(struct device *ctrldev) { - struct device *dev; u32 rng_inst; struct caam_drv_private *priv = dev_get_drvdata(ctrldev); int err; @@ -328,21 +342,11 @@ int caam_rng_init(struct device *ctrldev) if (!rng_inst) return 0; - dev = caam_jr_alloc(); - if (IS_ERR(dev)) { - pr_err("Job Ring Device allocation for transform failed\n"); - return PTR_ERR(dev); - } rng_ctx = kmalloc(sizeof(*rng_ctx), GFP_DMA | GFP_KERNEL); - if (!rng_ctx) { - err = -ENOMEM; - goto free_caam_alloc; - } - err = caam_init_rng(rng_ctx, dev); - if (err) - goto free_rng_ctx; + if (!rng_ctx) + return -ENOMEM; - dev_info(dev, "registering rng-caam\n"); + dev_info(ctrldev, "registering rng-caam\n"); err = hwrng_register(&caam_rng); if (!err) { @@ -350,9 +354,6 @@ int caam_rng_init(struct device *ctrldev) return err; } -free_rng_ctx: kfree(rng_ctx); -free_caam_alloc: - caam_jr_free(dev); return err; } -- 2.21.0