Hi Manuel, On Tue, May 14, 2024 at 5:28 PM Manuel Traut <manut@xxxxxxxxx> wrote: > > Hi Jens, > > thank you very much for v6! It took me some time to figure out why it is > not working.. However it seems to be on the OP-TEE side and not related > to this kernel series. > > I need this change: > > @@ -1214,12 +1225,13 @@ static TEE_Result tee_rpmb_init(void) > } > > if (rpmb_ctx->reinit) { > if (rpmb_ctx->legacy_operation || !rpmb_ctx->key_verified) { > rpmb_ctx->wr_cnt_synced = false; > rpmb_ctx->key_derived = false; > rpmb_ctx->dev_info_synced = false; > rpmb_ctx->reinit = false; > - goto next; > } > res = rpmb_probe_reset(); > if (res) { > > @@ -1236,17 +1248,23 @@ static TEE_Result tee_rpmb_init(void) > if (!memcmp(rpmb_ctx->cid, dev_info.cid, > RPMB_EMMC_CID_SIZE)) { > rpmb_ctx->reinit = false; > + rpmb_ctx->legacy_operation = false; > return TEE_SUCCESS; > } > } > } > > to ensure that the non legacy mode is selected, even if the first RPMB > request comes from a compiled in TA. That patch didn't quite work in my case, but I think I understand what's needed at your end. I've prepared patches at https://github.com/OP-TEE/optee_os/pull/6852 can you try those, please? > > Thanks for your work, it makes it really easy now to implement ARM > System Ready IR with an fTPM and continue the boot measurements in the > initrd with the new tpm2.target in systemd v256. Thanks, much appreciated. Cheers, Jens > > Regards > Manuel > > On Tue, May 07, 2024 at 11:16:16AM +0200, Jens Wiklander wrote: > > Hi, > > > > This patch set introduces a new RPMB subsystem, based on patches from [1], > > [2], and [3]. The RPMB subsystem aims at providing access to RPMB > > partitions to other kernel drivers, in particular the OP-TEE driver. A new > > user space ABI isn't needed, we can instead continue using the already > > present ABI when writing the RPMB key during production. > > > > I've added and removed things to keep only what is needed by the OP-TEE > > driver. Since the posting of [3], there has been major changes in the MMC > > subsystem so "mmc: block: register RPMB partition with the RPMB subsystem" > > is in practice completely rewritten. > > > > With this OP-TEE can access RPMB during early boot instead of having to > > wait for user space to become available as in the current design [4]. > > This will benefit the efi variables [5] since we wont rely on userspace as > > well as some TPM issues [6] that were solved. > > > > The OP-TEE driver finds the correct RPMB device to interact with by > > iterating over available devices until one is found with a programmed > > authentication matching the one OP-TEE is using. This enables coexisting > > users of other RPMBs since the owner can be determined by who knows the > > authentication key. > > > > The corresponding secure world OP-TEE patches are available at [7]. > > > > I've put myself as a maintainer for the RPMB subsystem as I have an > > interest in the OP-TEE driver to keep this in good shape. However, if you'd > > rather see someone else taking the maintainership that's fine too. I'll > > help keep the subsystem updated regardless. > > > > [1] https://lore.kernel.org/lkml/20230722014037.42647-1-shyamsaini@xxxxxxxxxxxxxxxxxxx/ > > [2] https://lore.kernel.org/lkml/20220405093759.1126835-2-alex.bennee@xxxxxxxxxx/ > > [3] https://lore.kernel.org/linux-mmc/1478548394-8184-2-git-send-email-tomas.winkler@xxxxxxxxx/ > > [4] https://optee.readthedocs.io/en/latest/architecture/secure_storage.html#rpmb-secure-storage > > [5] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=c44b6be62e8dd4ee0a308c36a70620613e6fc55f > > [6] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=7269cba53d906cf257c139d3b3a53ad272176bca > > [7] https://github.com/jenswi-linaro/optee_os/tree/rpmb_probe_v6 > > > > Thanks, > > Jens > > > > Changes since v5: > > Manuel Traut reported and investigated an error on an i.MX8MM, the root > > cause was identified as insufficient alignment on frames sent to the RPMB > > device. Fixed in the OP-TEE driver as described below. > > * "rpmb: add Replay Protected Memory Block (RPMB) subsystem" > > - Adding a missing EXPORT_SYMBOL_GPL() > > * "optee: probe RPMB device using RPMB subsystem" > > - Replacing the old OPTEE_RPC_CMD_RPMB ABI with OPTEE_RPC_CMD_RPMB_FRAMES > > to get rid of the small header struct rpmb_req (now removed) causing > > the problem. > > - Matching changes on the secure side + support for re-initializing > > RPMB in case a boot stage has used RPMB, the latter also reported by > > Manuel Traut. > > > > Changes since v4: > > * "rpmb: add Replay Protected Memory Block (RPMB) subsystem" > > - Describing struct rpmb_descr as RPMB description instead of descriptor > > * "mmc: block: register RPMB partition with the RPMB subsystem" > > - Addressing review comments > > - Adding more comments for struct rpmb_frame > > - Fixing assignment of reliable_wr_count and capacity in mmc_blk_rpmb_add() > > * "optee: probe RPMB device using RPMB subsystem" > > - Updating struct rpmb_dev_info to match changes in "rpmb: add Replay > > Protected Memory Block (RPMB) subsystem" > > > > Changes since v3: > > * Move struct rpmb_frame into the MMC driver since the format of the RPMB > > frames depend on the implementation, one format for eMMC, another for > > UFS, and so on > > * "rpmb: add Replay Protected Memory Block (RPMB) subsystem" > > - Adding Reviewed-by: Linus Walleij <linus.walleij@xxxxxxxxxx> > > - Adding more description of the API functions > > - Removing the set_dev_info() op from struct rpmb_ops, the needed information > > is supplied in the arguments to rpmb_dev_register() instead. > > - Getting rid of struct rpmb_ops since only the route_frames() op was > > remaining, store that op directly in struct rpmb_dev > > - Changed rpmb_interface_register() and rpmb_interface_unregister() to use > > notifier_block instead of implementing the same thing ourselves > > * "mmc: block: register RPMB partition with the RPMB subsystem" > > - Moving the call to rpmb_dev_register() to be done at the end of > > mmc_blk_probe() when the device is fully available > > * "optee: probe RPMB device using RPMB subsystem" > > - Use IS_REACHABLE(CONFIG_RPMB) to determine if the RPMB subsystem is > > available > > - Translate TEE_ERROR_STORAGE_NOT_AVAILABLE if encountered in get_devices() > > to recognize the error in optee_rpmb_scan() > > - Simplified optee_rpmb_scan() and optee_rpmb_intf_rdev() > > > > Changes since v2: > > * "rpmb: add Replay Protected Memory Block (RPMB) subsystem" > > - Fixing documentation issues > > - Adding a "depends on MMC" in the Kconfig > > - Removed the class-device and the embedded device, struct rpmb_dev now > > relies on the parent device for reference counting as requested > > - Removed the now unneeded rpmb_ops get_resources() and put_resources() > > since references are already taken in mmc_blk_alloc_rpmb_part() before > > rpmb_dev_register() is called > > - Added rpmb_interface_{,un}register() now that > > class_interface_{,un}register() can't be used ay longer > > * "mmc: block: register RPMB partition with the RPMB subsystem" > > - Adding the missing error cleanup in alloc_idata() > > - Taking the needed reference to md->disk in mmc_blk_alloc_rpmb_part() > > instead of in mmc_rpmb_chrdev_open() and rpmb_op_mmc_get_resources() > > * "optee: probe RPMB device using RPMB subsystem" > > - Registering to get a notification when an RPMB device comes online > > - Probes for RPMB devices each time an RPMB device comes online, until > > a usable device is found > > - When a usable RPMB device is found, call > > optee_enumerate_devices(PTA_CMD_GET_DEVICES_RPMB) > > - Pass type of rpmb in return value from OPTEE_RPC_CMD_RPMB_PROBE_NEXT > > > > Changes since Shyam's RFC: > > * Removed the remaining leftover rpmb_cdev_*() function calls > > * Refactored the struct rpmb_ops with all the previous ops replaced, in > > some sense closer to [3] with the route_frames() op > > * Added rpmb_route_frames() > > * Added struct rpmb_frame, enum rpmb_op_result, and enum rpmb_type from [3] > > * Removed all functions not needed in the OP-TEE use case > > * Added "mmc: block: register RPMB partition with the RPMB subsystem", based > > on the commit with the same name in [3] > > * Added "optee: probe RPMB device using RPMB subsystem" for integration > > with OP-TEE > > * Moved the RPMB driver into drivers/misc/rpmb-core.c > > * Added my name to MODULE_AUTHOR() in rpmb-core.c > > * Added an rpmb_mutex to serialize access to the IDA > > * Removed the target parameter from all rpmb_*() functions since it's > > currently unused > > > > Jens Wiklander (3): > > rpmb: add Replay Protected Memory Block (RPMB) subsystem > > mmc: block: register RPMB partition with the RPMB subsystem > > optee: probe RPMB device using RPMB subsystem > > > > MAINTAINERS | 7 + > > drivers/misc/Kconfig | 10 ++ > > drivers/misc/Makefile | 1 + > > drivers/misc/rpmb-core.c | 233 +++++++++++++++++++++++++++++ > > drivers/mmc/core/block.c | 241 +++++++++++++++++++++++++++++- > > drivers/tee/optee/core.c | 30 ++++ > > drivers/tee/optee/device.c | 7 + > > drivers/tee/optee/ffa_abi.c | 8 + > > drivers/tee/optee/optee_private.h | 21 ++- > > drivers/tee/optee/optee_rpc_cmd.h | 35 +++++ > > drivers/tee/optee/rpc.c | 166 ++++++++++++++++++++ > > drivers/tee/optee/smc_abi.c | 7 + > > include/linux/rpmb.h | 136 +++++++++++++++++ > > 13 files changed, 899 insertions(+), 3 deletions(-) > > create mode 100644 drivers/misc/rpmb-core.c > > create mode 100644 include/linux/rpmb.h > > > > -- > > 2.34.1 > >