Skip to content

Commit

Permalink
Merge tag 'amlogic-drivers' of git://git.kernel.org/pub/scm/linux/ker…
Browse files Browse the repository at this point in the history
…nel/git/khilman/linux-amlogic into next/drivers

Pull "Amlogic driver updates for v4.12" from Kevin Hilman:

- firmware: updates/fixes for meson-sm

* tag 'amlogic-drivers' of git://git.kernel.org/pub/scm/linux/kernel/git/khilman/linux-amlogic:
  firmware: meson-sm: Allow 0 as valid return value
  firmware: meson-sm: Check for buffer output size
  • Loading branch information
Arnd Bergmann committed Mar 30, 2017
2 parents 49240e8 + 7a9bc33 commit 99b19a1
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 7 deletions.
20 changes: 16 additions & 4 deletions drivers/firmware/meson/meson_sm.c
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,7 @@ EXPORT_SYMBOL(meson_sm_call);
* meson_sm_call_read - retrieve data from secure-monitor
*
* @buffer: Buffer to store the retrieved data
* @bsize: Size of the buffer
* @cmd_index: Index of the SMC32 function ID
* @arg0: SMC32 Argument 0
* @arg1: SMC32 Argument 1
Expand All @@ -135,28 +136,39 @@ EXPORT_SYMBOL(meson_sm_call);
* @arg4: SMC32 Argument 4
*
* Return: size of read data on success, a negative value on error
* When 0 is returned there is no guarantee about the amount of
* data read and bsize bytes are copied in buffer.
*/
int meson_sm_call_read(void *buffer, unsigned int cmd_index, u32 arg0,
u32 arg1, u32 arg2, u32 arg3, u32 arg4)
int meson_sm_call_read(void *buffer, unsigned int bsize, unsigned int cmd_index,
u32 arg0, u32 arg1, u32 arg2, u32 arg3, u32 arg4)
{
u32 size;
int ret;

if (!fw.chip)
return -ENOENT;

if (!fw.chip->cmd_shmem_out_base)
return -EINVAL;

if (bsize > fw.chip->shmem_size)
return -EINVAL;

if (meson_sm_call(cmd_index, &size, arg0, arg1, arg2, arg3, arg4) < 0)
return -EINVAL;

if (!size || size > fw.chip->shmem_size)
if (size > bsize)
return -EINVAL;

ret = size;

if (!size)
size = bsize;

if (buffer)
memcpy(buffer, fw.sm_shmem_out_base, size);

return size;
return ret;
}
EXPORT_SYMBOL(meson_sm_call_read);

Expand Down
2 changes: 1 addition & 1 deletion drivers/nvmem/meson-efuse.c
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ static int meson_efuse_read(void *context, unsigned int offset,
u8 *buf = val;
int ret;

ret = meson_sm_call_read(buf, SM_EFUSE_READ, offset,
ret = meson_sm_call_read(buf, bytes, SM_EFUSE_READ, offset,
bytes, 0, 0, 0);
if (ret < 0)
return ret;
Expand Down
4 changes: 2 additions & 2 deletions include/linux/firmware/meson/meson_sm.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ int meson_sm_call(unsigned int cmd_index, u32 *ret, u32 arg0, u32 arg1,
u32 arg2, u32 arg3, u32 arg4);
int meson_sm_call_write(void *buffer, unsigned int b_size, unsigned int cmd_index,
u32 arg0, u32 arg1, u32 arg2, u32 arg3, u32 arg4);
int meson_sm_call_read(void *buffer, unsigned int cmd_index, u32 arg0, u32 arg1,
u32 arg2, u32 arg3, u32 arg4);
int meson_sm_call_read(void *buffer, unsigned int bsize, unsigned int cmd_index,
u32 arg0, u32 arg1, u32 arg2, u32 arg3, u32 arg4);

#endif /* _MESON_SM_FW_H_ */

0 comments on commit 99b19a1

Please sign in to comment.