]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
tee: sandbox: check for buffer size
authorIgor Opaniuk <igor.opaniuk@gmail.com>
Sun, 21 Apr 2024 20:48:39 +0000 (22:48 +0200)
committerIlias Apalodimas <ilias.apalodimas@linaro.org>
Fri, 26 Apr 2024 05:28:35 +0000 (08:28 +0300)
Add additional check for buffer size when reading out persistent
storage value and provide back actual value size.

Signed-off-by: Igor Opaniuk <igor.opaniuk@gmail.com>
Reviewed-by: Oleksandr Suvorov <cryosay@gmail.com>
Reviewed-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
Signed-off-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
drivers/tee/sandbox.c

index 8ad7c09efdd858039e0107023f45ebfdb0a4e824..86b16a3bb8d46cb43ed1d70b28c567c88448df73 100644 (file)
@@ -174,7 +174,7 @@ static u32 ta_avb_invoke_func(struct udevice *dev, u32 func, uint num_params,
        uint slot;
        u64 val;
        char *value;
-       u32 value_sz;
+       u32 value_sz, tmp_sz;
 
        switch (func) {
        case TA_AVB_CMD_READ_ROLLBACK_INDEX:
@@ -267,8 +267,12 @@ static u32 ta_avb_invoke_func(struct udevice *dev, u32 func, uint num_params,
                if (!ep)
                        return TEE_ERROR_ITEM_NOT_FOUND;
 
-               value_sz = strlen(ep->data) + 1;
-               memcpy(value, ep->data, value_sz);
+               tmp_sz = strlen(ep->data) + 1;
+               if (value_sz < tmp_sz)
+                       return TEE_ERROR_SHORT_BUFFER;
+
+               memcpy(value, ep->data, tmp_sz);
+               params[1].u.memref.size = tmp_sz;
 
                return TEE_SUCCESS;
        case TA_AVB_CMD_WRITE_PERSIST_VALUE: