diff options
| author | Sergey Shtylyov <[email protected]> | 2022-06-24 23:39:44 +0300 | 
|---|---|---|
| committer | Damien Le Moal <[email protected]> | 2022-06-29 10:44:48 +0900 | 
| commit | 0184898dd14d53e81cc439b6735260f19750e3c1 (patch) | |
| tree | a027194060fed5528af6ce6b098f7b4eddbeec3c /drivers/platform/surface/aggregator/ssh_request_layer.c | |
| parent | 2b5960a0e33b5449712abc9a1b144d7ac874e47c (diff) | |
ata: libata-scsi: fix result type of ata_ioc32()
While ata_ioc32() returns 'int', its result gets assigned to and compared
with the 'unsigned long' variable 'val' in ata_sas_scsi_ioctl(), its only
caller, which implies a problematic implicit cast (with sign extension).
Fix this by returning 'bool' instead -- the implicit cast then implies
zero extension which is OK.  Note that actually the object code doesn't
change because ata_ioc32() is always inlined -- I can see the expected
code changes with 'noinline'...
Found by Linux Verification Center (linuxtesting.org) with the SVACE
static analysis tool.
Signed-off-by: Sergey Shtylyov <[email protected]>
Signed-off-by: Damien Le Moal <[email protected]>
Diffstat (limited to 'drivers/platform/surface/aggregator/ssh_request_layer.c')
0 files changed, 0 insertions, 0 deletions