• W
    scsi: 3w-9xxx: fix a missing-check bug · c9318a3e
    Wenwen Wang 提交于
    In twa_chrdev_ioctl(), the ioctl driver command is firstly copied from
    the userspace pointer 'argp' and saved to the kernel object
    'driver_command'.  Then a security check is performed on the data buffer
    size indicated by 'driver_command', which is
    'driver_command.buffer_length'. If the security check is passed, the
    entire ioctl command is copied again from the 'argp' pointer and saved
    to the kernel object 'tw_ioctl'. Then, various operations are performed
    on 'tw_ioctl' according to the 'cmd'. Given that the 'argp' pointer
    resides in userspace, a malicious userspace process can race to change
    the buffer size between the two copies. This way, the user can bypass
    the security check and inject invalid data buffer size. This can cause
    potential security issues in the following execution.
    
    This patch checks for capable(CAP_SYS_ADMIN) in twa_chrdev_open()t o
    avoid the above issues.
    Signed-off-by: NWenwen Wang <wang6495@umn.edu>
    Acked-by: NAdam Radford <aradford@gmail.com>
    Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
    c9318a3e
3w-9xxx.c 75.2 KB