In the Linux kernel, the following vulnerability has been resolved:
btrfs: fix information leak in btrfsioctllogicaltoino()
Syzbot reported the following information leak for in btrfsioctllogicaltoino():
BUG: KMSAN: kernel-infoleak in instrumentcopytouser include/linux/instrumented.h:114 [inline] BUG: KMSAN: kernel-infoleak in _copytouser+0xbc/0x110 lib/usercopy.c:40 instrumentcopytouser include/linux/instrumented.h:114 [inline] copytouser+0xbc/0x110 lib/usercopy.c:40 copytouser include/linux/uaccess.h:191 [inline] btrfsioctllogicaltoino+0x440/0x750 fs/btrfs/ioctl.c:3499 btrfsioctl+0x714/0x1260 vfsioctl fs/ioctl.c:51 [inline] _dosysioctl fs/ioctl.c:904 [inline] _sesysioctl+0x261/0x450 fs/ioctl.c:890 _x64sysioctl+0x96/0xe0 fs/ioctl.c:890 x64syscall+0x1883/0x3b50 arch/x86/include/generated/asm/syscalls64.h:17 dosyscallx64 arch/x86/entry/common.c:52 [inline] dosyscall64+0xcf/0x1e0 arch/x86/entry/common.c:83 entrySYSCALL64after_hwframe+0x77/0x7f
Uninit was created at: _kmalloclargenode+0x231/0x370 mm/slub.c:3921 _dokmallocnode mm/slub.c:3954 [inline] _kmallocnode+0xb07/0x1060 mm/slub.c:3973 kmallocnode include/linux/slab.h:648 [inline] kvmallocnode+0xc0/0x2d0 mm/util.c:634 kvmalloc include/linux/slab.h:766 [inline] initdatacontainer+0x49/0x1e0 fs/btrfs/backref.c:2779 btrfsioctllogicaltoino+0x17c/0x750 fs/btrfs/ioctl.c:3480 btrfsioctl+0x714/0x1260 vfsioctl fs/ioctl.c:51 [inline] _dosysioctl fs/ioctl.c:904 [inline] _sesysioctl+0x261/0x450 fs/ioctl.c:890 _x64sysioctl+0x96/0xe0 fs/ioctl.c:890 x64syscall+0x1883/0x3b50 arch/x86/include/generated/asm/syscalls64.h:17 dosyscallx64 arch/x86/entry/common.c:52 [inline] dosyscall64+0xcf/0x1e0 arch/x86/entry/common.c:83 entrySYSCALL64afterhwframe+0x77/0x7f
Bytes 40-65535 of 65536 are uninitialized Memory access of size 65536 starts at ffff888045a40000
This happens, because we're copying a 'struct btrfsdatacontainer' back to user-space. This btrfsdatacontainer is allocated in 'initdatacontainer()' via kvmalloc(), which does not zero-fill the memory.
Fix this by using kvzalloc() which zeroes out the memory on allocation.
[
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"222531883521513975074184505019391149783",
"78856505757216148206946434150954900889",
"310894085437583047203084904093216167000",
"233918825257384197991802583923898292796",
"233413888213148014688392696416776081750",
"209398977243835406258642163650517253373",
"329345562551677261807847465741778362169",
"158296845217279642106297372959942736719",
"75854432035192245410843232486066601050",
"315097348335097288192776859398897374774",
"85068056000526380288863066905573425633",
"70146863136366015431986502105854248204",
"238117260473333470060269558991330402890",
"148427348393219585137863743535037573633",
"151990273803750662672177448392004879403"
]
},
"signature_type": "Line",
"target": {
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@30189e54ba80e3209d34cfeea87b848f6ae025e6",
"id": "CVE-2024-35849-15e2a697"
},
{
"digest": {
"length": 452.0,
"function_hash": "68950686154632702585909531101423564441"
},
"signature_type": "Function",
"target": {
"function": "init_data_container",
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@fddc19631c51d9c17d43e9f822a7bc403af88d54",
"id": "CVE-2024-35849-335640f7"
},
{
"digest": {
"length": 452.0,
"function_hash": "68950686154632702585909531101423564441"
},
"signature_type": "Function",
"target": {
"function": "init_data_container",
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@689efe22e9b5b7d9d523119a9a5c3c17107a0772",
"id": "CVE-2024-35849-35b08e7b"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"222531883521513975074184505019391149783",
"78856505757216148206946434150954900889",
"310894085437583047203084904093216167000",
"233918825257384197991802583923898292796",
"233413888213148014688392696416776081750",
"209398977243835406258642163650517253373",
"329345562551677261807847465741778362169",
"158296845217279642106297372959942736719",
"75854432035192245410843232486066601050",
"315097348335097288192776859398897374774",
"85068056000526380288863066905573425633",
"70146863136366015431986502105854248204",
"238117260473333470060269558991330402890",
"148427348393219585137863743535037573633",
"151990273803750662672177448392004879403"
]
},
"signature_type": "Line",
"target": {
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@689efe22e9b5b7d9d523119a9a5c3c17107a0772",
"id": "CVE-2024-35849-46257fb2"
},
{
"digest": {
"length": 452.0,
"function_hash": "68950686154632702585909531101423564441"
},
"signature_type": "Function",
"target": {
"function": "init_data_container",
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@73db209dcd4ae026021234d40cfcb2fb5b564b86",
"id": "CVE-2024-35849-4861098f"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"222531883521513975074184505019391149783",
"78856505757216148206946434150954900889",
"310894085437583047203084904093216167000",
"233918825257384197991802583923898292796",
"233413888213148014688392696416776081750",
"209398977243835406258642163650517253373",
"329345562551677261807847465741778362169",
"158296845217279642106297372959942736719",
"75854432035192245410843232486066601050",
"315097348335097288192776859398897374774",
"85068056000526380288863066905573425633",
"70146863136366015431986502105854248204",
"238117260473333470060269558991330402890",
"148427348393219585137863743535037573633",
"151990273803750662672177448392004879403"
]
},
"signature_type": "Line",
"target": {
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@8bdbcfaf3eac42f98e5486b3d7e130fa287811f6",
"id": "CVE-2024-35849-4faddf28"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"222531883521513975074184505019391149783",
"78856505757216148206946434150954900889",
"310894085437583047203084904093216167000",
"233918825257384197991802583923898292796",
"233413888213148014688392696416776081750",
"209398977243835406258642163650517253373",
"329345562551677261807847465741778362169",
"158296845217279642106297372959942736719",
"75854432035192245410843232486066601050",
"315097348335097288192776859398897374774",
"85068056000526380288863066905573425633",
"70146863136366015431986502105854248204",
"238117260473333470060269558991330402890",
"148427348393219585137863743535037573633",
"151990273803750662672177448392004879403"
]
},
"signature_type": "Line",
"target": {
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@2f7ef5bb4a2f3e481ef05fab946edb97c84f67cf",
"id": "CVE-2024-35849-5b978867"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"222531883521513975074184505019391149783",
"78856505757216148206946434150954900889",
"310894085437583047203084904093216167000",
"233918825257384197991802583923898292796",
"233413888213148014688392696416776081750",
"209398977243835406258642163650517253373",
"329345562551677261807847465741778362169",
"158296845217279642106297372959942736719",
"75854432035192245410843232486066601050",
"315097348335097288192776859398897374774",
"85068056000526380288863066905573425633",
"70146863136366015431986502105854248204",
"238117260473333470060269558991330402890",
"148427348393219585137863743535037573633",
"151990273803750662672177448392004879403"
]
},
"signature_type": "Line",
"target": {
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@fddc19631c51d9c17d43e9f822a7bc403af88d54",
"id": "CVE-2024-35849-61a47366"
},
{
"digest": {
"length": 452.0,
"function_hash": "68950686154632702585909531101423564441"
},
"signature_type": "Function",
"target": {
"function": "init_data_container",
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@30189e54ba80e3209d34cfeea87b848f6ae025e6",
"id": "CVE-2024-35849-7f267b56"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"222531883521513975074184505019391149783",
"78856505757216148206946434150954900889",
"310894085437583047203084904093216167000",
"233918825257384197991802583923898292796",
"233413888213148014688392696416776081750",
"209398977243835406258642163650517253373",
"329345562551677261807847465741778362169",
"158296845217279642106297372959942736719",
"75854432035192245410843232486066601050",
"315097348335097288192776859398897374774",
"85068056000526380288863066905573425633",
"70146863136366015431986502105854248204",
"238117260473333470060269558991330402890",
"148427348393219585137863743535037573633",
"151990273803750662672177448392004879403"
]
},
"signature_type": "Line",
"target": {
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@e58047553a4e859dafc8d1d901e1de77c9dd922d",
"id": "CVE-2024-35849-a19adc3c"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"222531883521513975074184505019391149783",
"78856505757216148206946434150954900889",
"310894085437583047203084904093216167000",
"233918825257384197991802583923898292796",
"233413888213148014688392696416776081750",
"209398977243835406258642163650517253373",
"329345562551677261807847465741778362169",
"158296845217279642106297372959942736719",
"75854432035192245410843232486066601050",
"315097348335097288192776859398897374774",
"85068056000526380288863066905573425633",
"70146863136366015431986502105854248204",
"238117260473333470060269558991330402890",
"148427348393219585137863743535037573633",
"151990273803750662672177448392004879403"
]
},
"signature_type": "Line",
"target": {
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@3a63cee1a5e14a3e52c19142c61dd5fcb524f6dc",
"id": "CVE-2024-35849-aa247fdb"
},
{
"digest": {
"length": 452.0,
"function_hash": "68950686154632702585909531101423564441"
},
"signature_type": "Function",
"target": {
"function": "init_data_container",
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@e58047553a4e859dafc8d1d901e1de77c9dd922d",
"id": "CVE-2024-35849-c3a3c566"
},
{
"digest": {
"length": 452.0,
"function_hash": "68950686154632702585909531101423564441"
},
"signature_type": "Function",
"target": {
"function": "init_data_container",
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@3a63cee1a5e14a3e52c19142c61dd5fcb524f6dc",
"id": "CVE-2024-35849-d5c57fdd"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"222531883521513975074184505019391149783",
"78856505757216148206946434150954900889",
"310894085437583047203084904093216167000",
"233918825257384197991802583923898292796",
"233413888213148014688392696416776081750",
"209398977243835406258642163650517253373",
"329345562551677261807847465741778362169",
"158296845217279642106297372959942736719",
"75854432035192245410843232486066601050",
"315097348335097288192776859398897374774",
"85068056000526380288863066905573425633",
"70146863136366015431986502105854248204",
"238117260473333470060269558991330402890",
"148427348393219585137863743535037573633",
"151990273803750662672177448392004879403"
]
},
"signature_type": "Line",
"target": {
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@73db209dcd4ae026021234d40cfcb2fb5b564b86",
"id": "CVE-2024-35849-e0613a18"
},
{
"digest": {
"length": 452.0,
"function_hash": "68950686154632702585909531101423564441"
},
"signature_type": "Function",
"target": {
"function": "init_data_container",
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@8bdbcfaf3eac42f98e5486b3d7e130fa287811f6",
"id": "CVE-2024-35849-f60f39b8"
},
{
"digest": {
"length": 452.0,
"function_hash": "68950686154632702585909531101423564441"
},
"signature_type": "Function",
"target": {
"function": "init_data_container",
"file": "fs/btrfs/backref.c"
},
"deprecated": false,
"signature_version": "v1",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@2f7ef5bb4a2f3e481ef05fab946edb97c84f67cf",
"id": "CVE-2024-35849-fa43cee2"
}
]