401 Star 1.4K Fork 1.3K

GVPopenEuler / kernel

 / 详情

修补CVE-2022-40768

已完成
CVE和安全问题 成员
创建于  
2022-11-08 14:44

一、漏洞信息
漏洞编号:
CVE-2022-40768
漏洞归属组件:
驱动
漏洞归属的版本:

CVSS V3.0分值:
5.5
漏洞简述:
drivers/scsi/stex.c in the Linux kernel through 5.19.9 allows local users to obtain sensitive information from kernel memory because stex_queuecommand_lck lacks a memset for the PASSTHRU_CMD case.
漏洞公开时间:
2022-09-22
漏洞创建时间:
2022-09-29
漏洞详情参考链接:
https://github.com/nluedtke/linux_kernel_cves/blob/master/data/5.10/5.10_CVEs.txt
漏洞分析指导链接:
https://gitee.com/openeuler/cve-manager/blob/master/doc/md/manual.md
二、漏洞分析结构反馈
影响性分析说明:
此漏洞可被用于泄露内核信息,影响数据机密性。
openEuler评分:

受影响版本排查(受影响/不受影响):
受影响

评论 (2)

lujialin 创建了CVE和安全问题

Hi lujialin2, welcome to the openEuler Community.
I'm the Bot here serving you. You can find the instructions on how to interact with me at Here.
If you have any questions, please contact the SIG: Kernel, and any of the maintainers: @YangYingliang , @成坚 (CHENG Jian) , @jiaoff , @zhengzengkai , @刘勇强 , @wangxiongfeng , @朱科潜 , @WangShaoBo , @lujialin , @wuxu_buque , @Xu Kuohai , @冷嘲啊 , @Lingmingqiang , @yuzenghui , @juntian , @OSSIM , @陈结松 , @whoisxxx , @koulihong , @刘恺 , @hanjun-guo , @woqidaideshi , @Chiqijun , @Kefeng , @ThunderTown , @AlexGuo , @kylin-mayukun , @Zheng Zucheng , @柳歆 , @Jackie Liu , @zhujianwei001 , @郑振鹏 , @SuperSix173 , @colyli , @Zhang Yi , @htforge , @Qiuuuuu , @Yuehaibing , @xiehaocheng , @guzitao , @CTC-Xibo.Wang , @zhanghongchen , @chen wei , @Jason Zeng , @Xie XiuQi

openeuler-ci-bot 添加了
 
sig/Kernel
标签

影响和风险: 此漏洞可被用于泄露内核信息,影响数据机密性。
利用条件: 对stex驱动对应盘下发PASSTHRU_CMD命令子命令为PASSTHRU_GET_DRVVER获取驱动的信息,有18个字节是没有初始化的,内核的内存数据会泄露给用户态。
技术原因: Stex驱动在下发PASSTHRU_CMD命令子命令PASSTHRU_GET_DRVVER获取驱动信息时其中有18个字节没有初始化就把数据拷贝给用户,导致用户态可以获取到内核的内存信息。
stex_queuecommand_lck:
case PASSTHRU_CMD:
if (cmd->cmnd[1] == PASSTHRU_GET_DRVVER) {
struct st_drvver ver;
size_t cp_len = sizeof(ver);

            ver.major = ST_VER_MAJOR;
            ver.minor = ST_VER_MINOR;
            ver.oem = ST_OEM;
            ver.build = ST_BUILD_VER;
            ver.signature[0] = PASSTHRU_SIGNATURE;
            ver.console_id = host->max_id - 1;
            ver.host_no = hba->host->host_no;
            cp_len = scsi_sg_copy_from_buffer(cmd, &ver, cp_len);  ->拷贝数据到结果返回内存
            cmd->result = sizeof(ver) == cp_len ?
                    DID_OK << 16 | COMMAND_COMPLETE << 8 :
                    DID_ERROR << 16 | COMMAND_COMPLETE << 8;
            done(cmd);
            return 0;
    }

struct st_drvver {
u32 major;
u32 minor;
u32 oem;
u32 build;
u32 signature[2]; -> signature[1]未初始化
u8 console_id;
u8 host_no;
u8 reserved0[2]; ->未初始化
u32 reserved[3]; ->未初始化
};
判断方法: 1、CONFIG依赖:CONFIG_SCSI_STEX=y || CONFIG_SCSI_STEX=m 则涉及;
2、对stex驱动对应盘下发PASSTHRU_CMD命令子命令为PASSTHRU_GET_DRVVER获取驱动的信息则涉及;

zhengzengkai 通过src-openeuler/kernel Pull Request !801任务状态待办的 修改为已完成
openeuler-ci-bot 计划开始日期设置为2022-11-08
openeuler-ci-bot 计划截止日期设置为2022-12-08
openeuler-ci-bot 优先级设置为次要

登录 后才可以发表评论

状态
负责人
项目
里程碑
Pull Requests
关联的 Pull Requests 被合并后可能会关闭此 issue
分支
开始日期   -   截止日期
-
置顶选项
优先级
预计工期 (小时)
参与者(2)
5329419 openeuler ci bot 1632792936
C
1
https://gitee.com/openeuler/kernel.git
git@gitee.com:openeuler/kernel.git
openeuler
kernel
kernel

搜索帮助

344bd9b3 5694891 D2dac590 5694891