Paulo Alcantara
6726429c18
smb: client: fix potential OOBs in smb2_parse_contexts()
...
commit af1689a9b7701d9907dfc84d2a4b57c4bc907144 upstream.
Validate offsets and lengths before dereferencing create contexts in
smb2_parse_contexts().
This fixes following oops when accessing invalid create contexts from
server:
BUG: unable to handle page fault for address: ffff8881178d8cc3
#PF: supervisor read access in kernel mode
#PF: error_code(0x0000) - not-present page
PGD 4a01067 P4D 4a01067 PUD 0
Oops: 0000 [#1 ] PREEMPT SMP NOPTI
CPU: 3 PID: 1736 Comm: mount.cifs Not tainted 6.7.0-rc4 #1
Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS
rel-1.16.2-3-gd478f380-rebuilt.opensuse.org 04/01/2014
RIP: 0010:smb2_parse_contexts+0xa0/0x3a0 [cifs]
Code: f8 10 75 13 48 b8 93 ad 25 50 9c b4 11 e7 49 39 06 0f 84 d2 00
00 00 8b 45 00 85 c0 74 61 41 29 c5 48 01 c5 41 83 fd 0f 76 55 <0f> b7
7d 04 0f b7 45 06 4c 8d 74 3d 00 66 83 f8 04 75 bc ba 04 00
RSP: 0018:ffffc900007939e0 EFLAGS: 00010216
RAX: ffffc90000793c78 RBX: ffff8880180cc000 RCX: ffffc90000793c90
RDX: ffffc90000793cc0 RSI: ffff8880178d8cc0 RDI: ffff8880180cc000
RBP: ffff8881178d8cbf R08: ffffc90000793c22 R09: 0000000000000000
R10: ffff8880180cc000 R11: 0000000000000024 R12: 0000000000000000
R13: 0000000000000020 R14: 0000000000000000 R15: ffffc90000793c22
FS: 00007f873753cbc0(0000) GS:ffff88806bc00000(0000)
knlGS:0000000000000000
CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
CR2: ffff8881178d8cc3 CR3: 00000000181ca000 CR4: 0000000000750ef0
PKRU: 55555554
Call Trace:
<TASK>
? __die+0x23/0x70
? page_fault_oops+0x181/0x480
? search_module_extables+0x19/0x60
? srso_alias_return_thunk+0x5/0xfbef5
? exc_page_fault+0x1b6/0x1c0
? asm_exc_page_fault+0x26/0x30
? smb2_parse_contexts+0xa0/0x3a0 [cifs]
SMB2_open+0x38d/0x5f0 [cifs]
? smb2_is_path_accessible+0x138/0x260 [cifs]
smb2_is_path_accessible+0x138/0x260 [cifs]
cifs_is_path_remote+0x8d/0x230 [cifs]
cifs_mount+0x7e/0x350 [cifs]
cifs_smb3_do_mount+0x128/0x780 [cifs]
smb3_get_tree+0xd9/0x290 [cifs]
vfs_get_tree+0x2c/0x100
? capable+0x37/0x70
path_mount+0x2d7/0xb80
? srso_alias_return_thunk+0x5/0xfbef5
? _raw_spin_unlock_irqrestore+0x44/0x60
__x64_sys_mount+0x11a/0x150
do_syscall_64+0x47/0xf0
entry_SYSCALL_64_after_hwframe+0x6f/0x77
RIP: 0033:0x7f8737657b1e
Reported-by: Robert Morris <rtm@csail.mit.edu>
Cc: stable@vger.kernel.org
Signed-off-by: Paulo Alcantara (SUSE) <pc@manguebit.com>
Signed-off-by: Steve French <stfrench@microsoft.com>
[Guru: Removed changes to cached_dir.c and checking return value
of smb2_parse_contexts in smb2ops.c]
Signed-off-by: Guruswamy Basavaiah <guruswamy.basavaiah@broadcom.com>
[v5.4: Fixed merge-conflicts in smb2_parse_contexts for
missing parameter POSIX response]
Signed-off-by: Shaoying Xu <shaoyi@amazon.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2024-05-25 16:17:17 +02:00
..
2024-05-17 11:43:53 +02:00
2023-02-06 07:52:36 +01:00
2024-03-26 18:22:24 -04:00
2023-09-23 11:00:02 +02:00
2021-01-06 14:48:39 +01:00
2024-05-17 11:43:51 +02:00
2024-03-06 14:36:10 +00:00
2024-02-23 08:25:03 +01:00
2024-05-25 16:17:17 +02:00
2023-03-11 16:43:56 +01:00
2023-01-18 11:41:09 +01:00
2019-11-23 21:44:49 -05:00
2021-09-12 08:56:38 +02:00
2023-09-23 10:59:40 +02:00
2022-02-01 17:24:34 +01:00
2023-09-23 10:59:55 +02:00
2024-02-23 08:24:56 +01:00
2020-12-02 08:49:53 +01:00
2023-09-23 10:59:36 +02:00
2019-11-10 11:56:05 -05:00
2023-09-23 11:00:04 +02:00
2024-05-25 16:17:16 +02:00
2024-02-23 08:25:00 +01:00
2024-04-13 12:51:23 +02:00
2021-09-22 12:26:25 +02:00
2024-04-13 12:51:25 +02:00
2024-05-17 11:43:50 +02:00
2023-03-11 16:43:59 +01:00
2023-06-09 10:29:01 +02:00
2021-04-14 08:24:14 +02:00
2024-03-06 14:36:10 +00:00
2024-03-01 13:13:35 +01:00
2024-04-13 12:51:38 +02:00
2024-01-25 14:34:20 -08:00
2023-07-27 08:37:25 +02:00
2024-02-23 08:24:55 +01:00
2024-02-23 08:25:03 +01:00
2023-09-23 10:59:48 +02:00
2022-04-15 14:18:35 +02:00
2024-05-17 11:43:48 +02:00
2020-12-30 11:51:22 +01:00
2023-11-28 16:50:21 +00:00
2024-05-02 16:18:32 +02:00
2023-09-23 10:59:38 +02:00
2023-07-27 08:37:26 +02:00
2022-11-25 17:42:22 +01:00
2024-02-23 08:24:49 +01:00
2023-06-09 10:29:01 +02:00
2023-01-18 11:41:39 +01:00
2023-12-08 08:44:27 +01:00
2023-09-23 10:59:55 +02:00
2024-02-23 08:24:55 +01:00
2021-09-30 10:09:26 +02:00
2024-03-26 18:22:20 -04:00
2020-10-29 09:57:53 +01:00
2023-09-23 10:59:40 +02:00
2020-08-26 10:40:51 +02:00
2023-02-22 12:50:39 +01:00
2024-05-02 16:18:32 +02:00
2024-04-13 12:51:38 +02:00
2023-09-23 11:00:06 +02:00
2024-04-13 12:51:23 +02:00
2023-09-23 10:59:56 +02:00
2020-08-21 13:05:37 +02:00
2023-09-23 10:59:55 +02:00
2023-06-28 10:18:42 +02:00
2024-04-13 12:51:29 +02:00
2023-09-23 11:00:06 +02:00
2023-01-18 11:41:46 +01:00
2023-10-10 21:46:42 +02:00
2021-10-06 15:42:35 +02:00
2023-01-18 11:41:46 +01:00
2023-01-18 11:41:33 +01:00
2024-01-08 11:29:48 +01:00
2022-11-25 17:42:22 +01:00
2023-01-18 11:41:25 +01:00
2024-02-23 08:25:15 +01:00
2020-12-11 13:23:30 +01:00
2020-10-29 09:57:45 +01:00
2022-06-14 18:11:41 +02:00
2024-02-23 08:25:00 +01:00
2021-04-14 08:24:11 +02:00
2020-01-12 12:21:37 +01:00
2023-09-23 10:59:40 +02:00
2023-06-28 10:18:35 +02:00
2024-04-13 12:51:31 +02:00
2021-09-15 09:47:28 +02:00
2024-03-26 18:22:13 -04:00
2022-05-25 09:14:34 +02:00
2023-03-17 08:32:47 +01:00
2020-04-17 10:50:21 +02:00
2023-07-27 08:37:25 +02:00
2023-05-17 11:35:58 +02:00
2024-02-23 08:24:49 +01:00
2023-07-27 08:37:26 +02:00
2024-03-26 18:22:12 -04:00
2019-12-17 19:55:30 +01:00
2023-01-18 11:40:55 +01:00
2023-09-23 11:00:02 +02:00
2023-01-18 11:41:59 +01:00
2020-01-17 19:48:21 +01:00
2024-02-23 08:24:49 +01:00
2021-08-26 08:36:22 -04:00
2024-04-13 12:51:35 +02:00
2021-08-12 13:21:02 +02:00
2023-01-18 11:41:44 +01:00
2021-03-17 17:03:33 +01:00
2020-02-11 04:35:23 -08:00
2021-04-21 12:56:16 +02:00
2024-03-26 18:22:13 -04:00
2021-07-20 16:10:54 +02:00
2022-09-05 10:27:47 +02:00
2022-10-17 17:24:32 +02:00
2022-04-27 13:50:48 +02:00
2023-05-30 12:44:07 +01:00
2023-08-11 11:53:59 +02:00
2023-12-08 08:44:27 +01:00
2022-10-26 13:22:21 +02:00
2020-02-11 04:35:12 -08:00
2023-01-18 11:40:53 +01:00