From patchwork Tue Jan 14 12:36:33 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 13938738 Received: from mail-wr1-f52.google.com (mail-wr1-f52.google.com [209.85.221.52]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 42B3E1C2337; Tue, 14 Jan 2025 12:41:57 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.52 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736858519; cv=none; b=QND/dgbOh/MFdCL+GA37DPgSZcVDAtQzq2uY+3VqVmsOop8mX9Yx8z+WvXxv1oz8b0Vx63RG/kY3fqsJvFiKVovi7etR2ufjSGFIo9Jgk9dT+/ToSuFIRviKp55YK1wX7kvcDgHsuAaGEst4ss/YM/HQqo9hUOgQX4jnV0fNZms= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736858519; c=relaxed/simple; bh=PwVHIqhZkU7VSiKTgzgFML3bKwvEqDKfozFrlDyLep0=; h=From:To:Subject:Date:Message-ID:MIME-Version; b=AXvYGoKySsqM3TrFZs0YF+LKAyhzSXBva5laCON8rwoBnWEQNM2be2L6MdcSETHKDe8n0VPW2+R3oIP765g9jAXjcsUppfo+wVYec6IDuoANO9qoFKFoYCXvN97Pb7fRlHA/IfTL0w+y4vTY3rlY06TisQ2O6fdqndKWX/SHw0s= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=EMwiMd8A; arc=none smtp.client-ip=209.85.221.52 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="EMwiMd8A" Received: by mail-wr1-f52.google.com with SMTP id ffacd0b85a97d-385e0e224cbso2839426f8f.2; Tue, 14 Jan 2025 04:41:57 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1736858515; x=1737463315; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:from:to:cc:subject:date:message-id:reply-to; bh=bxKHNbldLr2KPjRhb+DsTvrYykc7jhuWUFNqFwWd4MI=; b=EMwiMd8ApF0iZ7UxrX/J8vj9VrSYkfn2axz2MjKHM9GfSzzz7lyaDUd/juUmXvrf/t 448/jsbk/oxDorVc9Bbo7NRtFVaQT0zv6gH+bhY4xeTYpwRxrYzzO51VnyHb71ugnjOd UQApwJo4dImu4IUAmvxbWoefvFY1djYnxkeCJAGXrdfGqISrHfQTrvFlB8ZxUG8tiSfC BrtV8FzBb+HhUM2XYDpGv5HPFJikjNtyA/E67MX/d65SMC0+utZwhTLUX2mGCgJsMDfj fKks1hL7BSmX6JASmX7BPYRNTgGCy8naeMmtRx/VeLHuXcP+LJCHcA3wYtgxVQRj6638 KIwQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1736858515; x=1737463315; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=bxKHNbldLr2KPjRhb+DsTvrYykc7jhuWUFNqFwWd4MI=; b=YGvfQK2OdhkUHu7vig6O/daIpCilpft9lTjQ+ssXzNmRWlcdYCfz2vWsrsnPYXDM4x ft6klp+YcdPezc+b48arAlJoyyl6B70kVfjwYkriRFajLIOppjTvvBL0qXoCIPLseMio KwFWyXGxDnoZMqKP2g2c34BQyllVH0QnLgrGEra732CTMfggNIzfsN7frM87f/5mrDkT QfpizK4lpwyGBjYTbCgi2UNTmPvVD7Go5OoWzv7Pf2k27gSxQq/67LJjMweIJb6C1RWl cZi/aPdjRg7NPr1hHrLvP8uk9swArLpJxB995Yl3oxWr42DOq6jFQA9sbGK1bxEDZQ4k tWTQ== X-Forwarded-Encrypted: i=1; AJvYcCWjA8UeW4KgxYAN7DaeaP+VChej2XV5q4bVdTdBVjVRjq2xu57nY28lqi42DdbRqeJCtLnCk3F3zGfPvm7v@vger.kernel.org, AJvYcCXPNmca7voQnsW3Z2y5aa/Iuh1bHl9vKbQmBob1a/VXi8IrGI3o2848Hv1Qw8R372X2NZZoco2SZWE9@vger.kernel.org, AJvYcCXZj20TBQC2MRJNM65il8IWOk90nz2kQaZjEnwGYN2ttuhqilsHe54/qZzK+HUTKwUBfZMAjoiPxM87QSoo@vger.kernel.org X-Gm-Message-State: AOJu0Ywo7McxHm5OrHqqs3cSilufoi8Zzr4OpZTsqmN5A3v66RolM3qB 0hcO9qgskOpaV1R2QlNwejCwdLn7aAmyH1S8tbyf74AqBZ+ZhQdk X-Gm-Gg: ASbGnctD/NN0STn5yGSj1jq1D9Rhhy5+HOq2NliesQ2ZtAjJWhvqt3H++pVTc9UOK7v HIFDLtYD6ho8qysbbxqPsk8/sYHAlHV6qsX1iqXRJ0p3ZNn1uC7MEgpgnV0ljZ4d72hmgdwuR+L g42RewKw7qICRwisconOQsU+hgeucNiFnOfUoS1Zqyyd9JFNfCRaJaHVboHfb5EqGLUicnCvtF6 bzQjMnLlrnT4Ap4fUBvh9evRBkbDC8utGjfllbCoYn6PbI4KurAoQ5YhmOSJhDO54afAPLL87kO qAwq7F0wnKsJhWBikXmlUSUFVw== X-Google-Smtp-Source: AGHT+IFqsYA3x5QlY9vO8Znk97lUtOQbkl8bJPQAZxX2XqUU5HAXMx0jymkTJDCc6PnFJiYiF+/hPQ== X-Received: by 2002:a5d:6d0d:0:b0:385:f1df:2502 with SMTP id ffacd0b85a97d-38a87308abemr19025172f8f.36.1736858515343; Tue, 14 Jan 2025 04:41:55 -0800 (PST) Received: from localhost.localdomain (93-34-91-161.ip49.fastwebnet.it. [93.34.91.161]) by smtp.googlemail.com with ESMTPSA id ffacd0b85a97d-38a8e38c6a2sm14798771f8f.54.2025.01.14.04.41.53 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Jan 2025 04:41:54 -0800 (PST) From: Christian Marangi To: Christian Marangi , Herbert Xu , "David S. Miller" , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Antoine Tenart , Peter Zijlstra , Ingo Molnar , Will Deacon , Waiman Long , Boqun Feng , Nathan Chancellor , Nick Desaulniers , Bill Wendling , Justin Stitt , linux-crypto@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, llvm@lists.linux.dev, upstream@airoha.com Subject: [PATCH v11 0/3] crypto: Add EIP-93 crypto engine support Date: Tue, 14 Jan 2025 13:36:33 +0100 Message-ID: <20250114123935.18346-1-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.45.2 Precedence: bulk X-Mailing-List: linux-crypto@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 This small series add support for the Inside Secure EIP-93. This is a predecessor of the current supported EIP197. It doesn't require a firmware but instead it's embedded in the SoC. First patch extend guard for spinlock_bh. The other actually implement Documentation and Driver. The Driver pass all the normal selft test for the supported algo and also pass the EXTRA test with fuzz_iterations set to 10000. Changes v11: - Drop any mtk variable reference and use eip93 instead - Mute smatch warning for context unbalance by using scoped_guard instead of guard cleanup API Changes v10: - Use CRYPTO_ALG_ASYNC for eip93_hmac_setkey Changes v9: - Rework hash code to alloc DMA only when needed - Rework hash code to only alloc needed blocks and use local struct in req for everything else - Rework hash code to use GFP_ATOMIC - Simplify hash update function - Generalize hmac key set function Changes v8: - Rework export and update to not sleep on exporting state (consume pending packet in update and return -EINPROGRESS) Changes v7: - Fix copypaste error in __eip93_hash_init - Rework import/export to actually export the partial hash (we actually unmap DMA on export) - Rename no_finalize variable to better partial_hash - Rename 3rd commit title and drop Mediatek from title. - Add Cover Letter - Add Reviewed-by to DT commit (cumulative changes from old series that had changelog in each patch) Changes v6: - Add SoC specific compatible - Add now supported entry for compatible with no user Changes v5: - Add Ack tag to guard patch - Comment out compatible with no current user - Fix smatch warning (reported by Dan Carpenter) Changes v4: - Out of RFC - Add missing bitfield.h - Drop useless header Changes v3: - Mute warning from Clang about C23 - Fix not inizialized err - Drop unused variable - Add SoC compatible with generic one Changes v2: - Rename all variables from mtk to eip93 - Move to inside-secure directory - Check DMA map errors - Use guard API for spinlock - Minor improvements to code - Add guard patch - Change to better compatible - Add description for EIP93 models Christian Marangi (3): spinlock: extend guard with spinlock_bh variants dt-bindings: crypto: Add Inside Secure SafeXcel EIP-93 crypto engine crypto: Add Inside Secure SafeXcel EIP-93 crypto engine support .../crypto/inside-secure,safexcel-eip93.yaml | 67 ++ MAINTAINERS | 7 + drivers/crypto/Kconfig | 1 + drivers/crypto/Makefile | 1 + drivers/crypto/inside-secure/eip93/Kconfig | 20 + drivers/crypto/inside-secure/eip93/Makefile | 5 + .../crypto/inside-secure/eip93/eip93-aead.c | 711 ++++++++++++++ .../crypto/inside-secure/eip93/eip93-aead.h | 38 + .../crypto/inside-secure/eip93/eip93-aes.h | 16 + .../crypto/inside-secure/eip93/eip93-cipher.c | 413 +++++++++ .../crypto/inside-secure/eip93/eip93-cipher.h | 60 ++ .../crypto/inside-secure/eip93/eip93-common.c | 809 ++++++++++++++++ .../crypto/inside-secure/eip93/eip93-common.h | 24 + .../crypto/inside-secure/eip93/eip93-des.h | 16 + .../crypto/inside-secure/eip93/eip93-hash.c | 866 ++++++++++++++++++ .../crypto/inside-secure/eip93/eip93-hash.h | 82 ++ .../crypto/inside-secure/eip93/eip93-main.c | 501 ++++++++++ .../crypto/inside-secure/eip93/eip93-main.h | 151 +++ .../crypto/inside-secure/eip93/eip93-regs.h | 335 +++++++ include/linux/spinlock.h | 13 + 20 files changed, 4136 insertions(+) create mode 100644 Documentation/devicetree/bindings/crypto/inside-secure,safexcel-eip93.yaml create mode 100644 drivers/crypto/inside-secure/eip93/Kconfig create mode 100644 drivers/crypto/inside-secure/eip93/Makefile create mode 100644 drivers/crypto/inside-secure/eip93/eip93-aead.c create mode 100644 drivers/crypto/inside-secure/eip93/eip93-aead.h create mode 100644 drivers/crypto/inside-secure/eip93/eip93-aes.h create mode 100644 drivers/crypto/inside-secure/eip93/eip93-cipher.c create mode 100644 drivers/crypto/inside-secure/eip93/eip93-cipher.h create mode 100644 drivers/crypto/inside-secure/eip93/eip93-common.c create mode 100644 drivers/crypto/inside-secure/eip93/eip93-common.h create mode 100644 drivers/crypto/inside-secure/eip93/eip93-des.h create mode 100644 drivers/crypto/inside-secure/eip93/eip93-hash.c create mode 100644 drivers/crypto/inside-secure/eip93/eip93-hash.h create mode 100644 drivers/crypto/inside-secure/eip93/eip93-main.c create mode 100644 drivers/crypto/inside-secure/eip93/eip93-main.h create mode 100644 drivers/crypto/inside-secure/eip93/eip93-regs.h