diff options
| author | Mario Limonciello <[email protected]> | 2025-04-23 13:18:44 +0000 |
|---|---|---|
| committer | Ilpo Järvinen <[email protected]> | 2025-04-29 14:47:41 +0000 |
| commit | 690d722e02819ef978f90cd7553973eba1007e6c (patch) | |
| tree | 414597ff882e5cc52ece7e9a67f4bad271e26fbc | |
| parent | platform/x86: ideapad-laptop: add support for some new buttons (diff) | |
| download | kernel-690d722e02819ef978f90cd7553973eba1007e6c.tar.gz kernel-690d722e02819ef978f90cd7553973eba1007e6c.zip | |
drivers/platform/x86/amd: pmf: Check for invalid sideloaded Smart PC Policies
If a policy is passed into amd_pmf_get_pb_data() that causes the engine
to fail to start there is a memory leak. Free the memory in this failure
path.
Fixes: 10817f28e5337 ("platform/x86/amd/pmf: Add capability to sideload of policy binary")
Signed-off-by: Mario Limonciello <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Reviewed-by: Ilpo Järvinen <[email protected]>
Signed-off-by: Ilpo Järvinen <[email protected]>
| -rw-r--r-- | drivers/platform/x86/amd/pmf/tee-if.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/platform/x86/amd/pmf/tee-if.c b/drivers/platform/x86/amd/pmf/tee-if.c index 14b99d8b63d2..e008ac079fad 100644 --- a/drivers/platform/x86/amd/pmf/tee-if.c +++ b/drivers/platform/x86/amd/pmf/tee-if.c @@ -364,9 +364,14 @@ static ssize_t amd_pmf_get_pb_data(struct file *filp, const char __user *buf, amd_pmf_hex_dump_pb(dev); ret = amd_pmf_start_policy_engine(dev); if (ret < 0) - return ret; + goto cleanup; return length; + +cleanup: + kfree(dev->policy_buf); + dev->policy_buf = NULL; + return ret; } static const struct file_operations pb_fops = { |
