From: Sasha Levin Date: Fri, 18 Feb 2022 19:57:32 +0000 (-0500) Subject: Fixes for 5.15 X-Git-Tag: v4.9.303~42 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=55f4d9fb13c3ac9e316f1310c1c09c9e0d6cba45;p=thirdparty%2Fkernel%2Fstable-queue.git Fixes for 5.15 Signed-off-by: Sasha Levin --- diff --git a/queue-5.15/series b/queue-5.15/series index cf02577d7ea..20d37bb7fb8 100644 --- a/queue-5.15/series +++ b/queue-5.15/series @@ -66,6 +66,7 @@ drm-i915-opregion-check-port-number-bounds-for-swsci-display-power-state.patch drm-i915-fix-dbuf-slice-config-lookup.patch drm-i915-fix-mbus-join-config-lookup.patch vsock-remove-vsock-from-connected-table-when-connect-is-interrupted-by-a-signal.patch +tee-export-teedev_open-and-teedev_close_context.patch optee-use-driver-internal-tee_context-for-some-rpc.patch drm-cma-helper-set-vm_dontexpand-for-mmap.patch drm-i915-gvt-make-drm_i915_gvt-depend-on-x86.patch diff --git a/queue-5.15/tee-export-teedev_open-and-teedev_close_context.patch b/queue-5.15/tee-export-teedev_open-and-teedev_close_context.patch new file mode 100644 index 00000000000..25099ded455 --- /dev/null +++ b/queue-5.15/tee-export-teedev_open-and-teedev_close_context.patch @@ -0,0 +1,83 @@ +From a2af942bc1bd5b17171c53341907fa2bec695ebc Mon Sep 17 00:00:00 2001 +From: Sasha Levin +Date: Mon, 4 Oct 2021 16:11:52 +0200 +Subject: tee: export teedev_open() and teedev_close_context() + +From: Jens Wiklander + +[ Upstream commit 1e2c3ef0496e72ba9001da5fd1b7ed56ccb30597 ] + +Exports the two functions teedev_open() and teedev_close_context() in +order to make it easier to create a driver internal struct tee_context. + +Reviewed-by: Sumit Garg +Signed-off-by: Jens Wiklander +Signed-off-by: Sasha Levin +--- + drivers/tee/tee_core.c | 6 ++++-- + include/linux/tee_drv.h | 14 ++++++++++++++ + 2 files changed, 18 insertions(+), 2 deletions(-) + +diff --git a/drivers/tee/tee_core.c b/drivers/tee/tee_core.c +index 85102d12d7169..3fc426dad2df3 100644 +--- a/drivers/tee/tee_core.c ++++ b/drivers/tee/tee_core.c +@@ -43,7 +43,7 @@ static DEFINE_SPINLOCK(driver_lock); + static struct class *tee_class; + static dev_t tee_devt; + +-static struct tee_context *teedev_open(struct tee_device *teedev) ++struct tee_context *teedev_open(struct tee_device *teedev) + { + int rc; + struct tee_context *ctx; +@@ -70,6 +70,7 @@ static struct tee_context *teedev_open(struct tee_device *teedev) + return ERR_PTR(rc); + + } ++EXPORT_SYMBOL_GPL(teedev_open); + + void teedev_ctx_get(struct tee_context *ctx) + { +@@ -96,13 +97,14 @@ void teedev_ctx_put(struct tee_context *ctx) + kref_put(&ctx->refcount, teedev_ctx_release); + } + +-static void teedev_close_context(struct tee_context *ctx) ++void teedev_close_context(struct tee_context *ctx) + { + struct tee_device *teedev = ctx->teedev; + + teedev_ctx_put(ctx); + tee_device_put(teedev); + } ++EXPORT_SYMBOL_GPL(teedev_close_context); + + static int tee_open(struct inode *inode, struct file *filp) + { +diff --git a/include/linux/tee_drv.h b/include/linux/tee_drv.h +index feda1dc7f98ee..38b701b7af4cf 100644 +--- a/include/linux/tee_drv.h ++++ b/include/linux/tee_drv.h +@@ -582,4 +582,18 @@ struct tee_client_driver { + #define to_tee_client_driver(d) \ + container_of(d, struct tee_client_driver, driver) + ++/** ++ * teedev_open() - Open a struct tee_device ++ * @teedev: Device to open ++ * ++ * @return a pointer to struct tee_context on success or an ERR_PTR on failure. ++ */ ++struct tee_context *teedev_open(struct tee_device *teedev); ++ ++/** ++ * teedev_close_context() - closes a struct tee_context ++ * @ctx: The struct tee_context to close ++ */ ++void teedev_close_context(struct tee_context *ctx); ++ + #endif /*__TEE_DRV_H*/ +-- +2.34.1 +