ALASKERNEL-5.4-2024-062


Amazon Linux 2 Security Advisory: ALASKERNEL-5.4-2024-062
Advisory Release Date: 2024-03-27 21:47 Pacific
Advisory Updated Date: 2024-12-05 01:00 Pacific
Severity: Important

Issue Overview:

2024-12-05: CVE-2023-52637 was added to this advisory.

2024-12-05: CVE-2024-26697 was added to this advisory.

2024-12-05: CVE-2024-26704 was added to this advisory.

2024-12-05: CVE-2024-35835 was added to this advisory.

2024-12-05: CVE-2024-26685 was added to this advisory.

2024-12-05: CVE-2024-26696 was added to this advisory.

2024-08-27: CVE-2024-26679 was added to this advisory.

2024-08-27: CVE-2023-52623 was added to this advisory.

2024-08-27: CVE-2024-26663 was added to this advisory.

2024-08-27: CVE-2024-26673 was added to this advisory.

2024-08-27: CVE-2023-52622 was added to this advisory.

2024-08-27: CVE-2024-26917 was added to this advisory.

2024-08-27: CVE-2024-26910 was added to this advisory.

2024-08-27: CVE-2024-26720 was added to this advisory.

2024-08-27: CVE-2024-26920 was added to this advisory.

2024-08-27: CVE-2024-26675 was added to this advisory.

2024-08-27: CVE-2024-26671 was added to this advisory.

2024-08-01: CVE-2024-26972 was added to this advisory.

2024-08-01: CVE-2023-52587 was added to this advisory.

2024-07-03: CVE-2024-23851 was added to this advisory.

2024-07-03: CVE-2024-26635 was added to this advisory.

2024-07-03: CVE-2023-52619 was added to this advisory.

2024-07-03: CVE-2023-52583 was added to this advisory.

2024-07-03: CVE-2023-52615 was added to this advisory.

2024-06-06: CVE-2023-52486 was added to this advisory.

2024-05-23: CVE-2024-26625 was added to this advisory.

2024-04-25: CVE-2024-26602 was added to this advisory.

2024-04-10: CVE-2024-26598 was added to this advisory.

2024-04-10: CVE-2023-52429 was added to this advisory.

2024-04-10: CVE-2024-0340 was added to this advisory.

2024-04-10: CVE-2023-52435 was added to this advisory.

2024-04-10: CVE-2024-1151 was added to this advisory.

dm_table_create in drivers/md/dm-table.c in the Linux kernel through 6.7.4 can attempt to (in alloc_targets) allocate more than INT_MAX bytes, and crash, because of a missing check for struct dm_ioctl.target_count. (CVE-2023-52429)

In the Linux kernel, the following vulnerability has been resolved:

net: prevent mss overflow in skb_segment()

Once again syzbot is able to crash the kernel in skb_segment() [1]

GSO_BY_FRAGS is a forbidden value, but unfortunately the following
computation in skb_segment() can reach it quite easily :

mss = mss * partial_segs;

65535 = 3 * 5 * 17 * 257, so many initial values of mss can lead to
a bad final result.

Make sure to limit segmentation so that the new mss value is smaller
than GSO_BY_FRAGS.

[1]

general protection fault, probably for non-canonical address 0xdffffc000000000e: 0000 [#1] PREEMPT SMP KASAN
KASAN: null-ptr-deref in range [0x0000000000000070-0x0000000000000077]
CPU: 1 PID: 5079 Comm: syz-executor993 Not tainted 6.7.0-rc4-syzkaller-00141-g1ae4cd3cbdd0 #0
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 11/10/2023
RIP: 0010:skb_segment+0x181d/0x3f30 net/core/skbuff.c:4551
Code: 83 e3 02 e9 fb ed ff ff e8 90 68 1c f9 48 8b 84 24 f8 00 00 00 48 8d 78 70 48 b8 00 00 00 00 00 fc ff df 48 89 fa 48 c1 ea 03 <0f> b6 04 02 84 c0 74 08 3c 03 0f 8e 8a 21 00 00 48 8b 84 24 f8 00
RSP: 0018:ffffc900043473d0 EFLAGS: 00010202
RAX: dffffc0000000000 RBX: 0000000000010046 RCX: ffffffff886b1597
RDX: 000000000000000e RSI: ffffffff886b2520 RDI: 0000000000000070
RBP: ffffc90004347578 R08: 0000000000000005 R09: 000000000000ffff
R10: 000000000000ffff R11: 0000000000000002 R12: ffff888063202ac0
R13: 0000000000010000 R14: 000000000000ffff R15: 0000000000000046
FS: 0000555556e7e380(0000) GS:ffff8880b9900000(0000) knlGS:0000000000000000
CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
CR2: 0000000020010000 CR3: 0000000027ee2000 CR4: 00000000003506f0
DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
Call Trace:
<TASK>
udp6_ufo_fragment+0xa0e/0xd00 net/ipv6/udp_offload.c:109
ipv6_gso_segment+0x534/0x17e0 net/ipv6/ip6_offload.c:120
skb_mac_gso_segment+0x290/0x610 net/core/gso.c:53
__skb_gso_segment+0x339/0x710 net/core/gso.c:124
skb_gso_segment include/net/gso.h:83 [inline]
validate_xmit_skb+0x36c/0xeb0 net/core/dev.c:3626
__dev_queue_xmit+0x6f3/0x3d60 net/core/dev.c:4338
dev_queue_xmit include/linux/netdevice.h:3134 [inline]
packet_xmit+0x257/0x380 net/packet/af_packet.c:276
packet_snd net/packet/af_packet.c:3087 [inline]
packet_sendmsg+0x24c6/0x5220 net/packet/af_packet.c:3119
sock_sendmsg_nosec net/socket.c:730 [inline]
__sock_sendmsg+0xd5/0x180 net/socket.c:745
__sys_sendto+0x255/0x340 net/socket.c:2190
__do_sys_sendto net/socket.c:2202 [inline]
__se_sys_sendto net/socket.c:2198 [inline]
__x64_sys_sendto+0xe0/0x1b0 net/socket.c:2198
do_syscall_x64 arch/x86/entry/common.c:52 [inline]
do_syscall_64+0x40/0x110 arch/x86/entry/common.c:83
entry_SYSCALL_64_after_hwframe+0x63/0x6b
RIP: 0033:0x7f8692032aa9
Code: 28 00 00 00 75 05 48 83 c4 28 c3 e8 d1 19 00 00 90 48 89 f8 48 89 f7 48 89 d6 48 89 ca 4d 89 c2 4d 89 c8 4c 8b 4c 24 08 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 c7 c1 b8 ff ff ff f7 d8 64 89 01 48
RSP: 002b:00007fff8d685418 EFLAGS: 00000246 ORIG_RAX: 000000000000002c
RAX: ffffffffffffffda RBX: 0000000000000003 RCX: 00007f8692032aa9
RDX: 0000000000010048 RSI: 00000000200000c0 RDI: 0000000000000003
RBP: 00000000000f4240 R08: 0000000020000540 R09: 0000000000000014
R10: 0000000000000000 R11: 0000000000000246 R12: 00007fff8d685480
R13: 0000000000000001 R14: 00007fff8d685480 R15: 0000000000000003
</TASK>
Modules linked in:
---[ end trace 0000000000000000 ]---
RIP: 0010:skb_segment+0x181d/0x3f30 net/core/skbuff.c:4551
Code: 83 e3 02 e9 fb ed ff ff e8 90 68 1c f9 48 8b 84 24 f8 00 00 00 48 8d 78 70 48 b8 00 00 00 00 00 fc ff df 48 89 fa 48 c1 ea 03 <0f> b6 04 02 84 c0 74 08 3c 03 0f 8e 8a 21 00 00 48 8b 84 24 f8 00
RSP: 0018:ffffc900043473d0 EFLAGS: 00010202
RAX: dffffc0000000000 RBX: 0000000000010046 RCX: ffffffff886b1597
RDX: 000000000000000e RSI: ffffffff886b2520 RDI: 0000000000000070
RBP: ffffc90004347578 R0
---truncated--- (CVE-2023-52435)

In the Linux kernel, the following vulnerability has been resolved:

drm: Don't unref the same fb many times by mistake due to deadlock handling (CVE-2023-52486)

In the Linux kernel, the following vulnerability has been resolved:

ceph: fix deadlock or deadcode of misusing dget() (CVE-2023-52583)

In the Linux kernel, the following vulnerability has been resolved:

IB/ipoib: Fix mcast list locking (CVE-2023-52587)

In the Linux kernel, the following vulnerability has been resolved:

hwrng: core - Fix page fault dead lock on mmap-ed hwrng (CVE-2023-52615)

In the Linux kernel, the following vulnerability has been resolved:

pstore/ram: Fix crash when setting number of cpus to an odd number (CVE-2023-52619)

In the Linux kernel, the following vulnerability has been resolved:

ext4: avoid online resizing failures due to oversized flex bg (CVE-2023-52622)

In the Linux kernel, the following vulnerability has been resolved:

SUNRPC: Fix a suspicious RCU usage warning (CVE-2023-52623)

In the Linux kernel, the following vulnerability has been resolved:

can: j1939: Fix UAF in j1939_sk_match_filter during setsockopt(SO_J1939_FILTER) (CVE-2023-52637)

A flaw was found in the ATA over Ethernet (AoE) driver in the Linux kernel. The aoecmd_cfg_pkts() function improperly updates the refcnt on `struct net_device`, and a use-after-free can be triggered by racing between the free on the struct and the access through the `skbtxq` global queue. This could lead to a denial of service condition or potential code execution. (CVE-2023-6270)

A vulnerability was found in vhost_new_msg in drivers/vhost/vhost.c in the Linux kernel, which does not properly initialize memory in messages passed between virtual guests and the host operating system in the vhost/vhost.c:vhost_new_msg() function. This issue can allow local privileged users to read some kernel memory contents when reading from the /dev/vhost-net device file. (CVE-2024-0340)

A vulnerability was reported in the Open vSwitch sub-component in the Linux Kernel. The flaw occurs when a recursive operation of code push recursively calls into the code block. The OVS module does not validate the stack depth, pushing too many frames and causing a stack overflow. As a result, this can lead to a crash or other related issues. (CVE-2024-1151)

A Speculative Race Condition (SRC) vulnerability that impacts modern CPU architectures supporting speculative execution (related to Spectre V1) has been disclosed. An unauthenticated attacker can exploit this vulnerability to disclose arbitrary data from the CPU using race conditions to access the speculative executable code paths. (CVE-2024-2193)

copy_params in drivers/md/dm-ioctl.c in the Linux kernel through 6.7.1 can attempt to allocate more than INT_MAX bytes, and crash, because of a missing param_kernel->data_size check. This is related to ctl_ioctl. (CVE-2024-23851)

In the Linux kernel, the following vulnerability has been resolved:

netfilter: nft_set_rbtree: skip end interval element from gc

rbtree lazy gc on insert might collect an end interval element that has
been just added in this transactions, skip end interval elements that
are not yet active. (CVE-2024-26581)

In the Linux kernel, the following vulnerability has been resolved:

KVM: arm64: vgic-its: Avoid potential UAF in LPI translation cache (CVE-2024-26598)

In the Linux kernel, the following vulnerability has been resolved:

sched/membarrier: reduce the ability to hammer on sys_membarrier

On some systems, sys_membarrier can be very expensive, causing overall
slowdowns for everything. So put a lock on the path in order to
serialize the accesses to prevent the ability for this to be called at
too high of a frequency and saturate the machine. (CVE-2024-26602)

In the Linux kernel, the following vulnerability has been resolved:

llc: call sock_orphan() at release time (CVE-2024-26625)

In the Linux kernel, the following vulnerability has been resolved:

llc: Drop support for ETH_P_TR_802_2. (CVE-2024-26635)

In the Linux kernel, the following vulnerability has been resolved:

tipc: Check the bearer type before calling tipc_udp_nl_bearer_add() (CVE-2024-26663)

In the Linux kernel, the following vulnerability has been resolved:

blk-mq: fix IO hang from sbitmap wakeup race (CVE-2024-26671)

In the Linux kernel, the following vulnerability has been resolved:

netfilter: nft_ct: sanitize layer 3 and 4 protocol number in custom expectations (CVE-2024-26673)

In the Linux kernel, the following vulnerability has been resolved:

ppp_async: limit MRU to 64K (CVE-2024-26675)

In the Linux kernel, the following vulnerability has been resolved:

inet: read sk->sk_family once in inet_recv_error() (CVE-2024-26679)

In the Linux kernel, the following vulnerability has been resolved:

nilfs2: fix potential bug in end_buffer_async_write (CVE-2024-26685)

In the Linux kernel, the following vulnerability has been resolved:

nilfs2: fix hang in nilfs_lookup_dirty_data_buffers() (CVE-2024-26696)

In the Linux kernel, the following vulnerability has been resolved:

nilfs2: fix data corruption in dsync block recovery for small block sizes (CVE-2024-26697)

In the Linux kernel, the following vulnerability has been resolved:

ext4: fix double-free of blocks due to wrong extents moved_len (CVE-2024-26704)

In the Linux kernel, the following vulnerability has been resolved:

mm/writeback: fix possible divide-by-zero in wb_dirty_limits(), again (CVE-2024-26720)

In the Linux kernel, the following vulnerability has been resolved:

netfilter: ipset: fix performance regression in swap operation (CVE-2024-26910)

In the Linux kernel, the following vulnerability has been resolved:

scsi: Revert "scsi: fcoe: Fix potential deadlock on &fip->ctlr_lock" (CVE-2024-26917)

In the Linux kernel, the following vulnerability has been resolved:

tracing/trigger: Fix to return error if failed to alloc snapshot (CVE-2024-26920)

In the Linux kernel, the following vulnerability has been resolved:

ubifs: ubifs_symlink: Fix memleak of inode->i_link in error path (CVE-2024-26972)

In the Linux kernel, the following vulnerability has been resolved:

net/mlx5e: fix a double-free in arfs_create_groups (CVE-2024-35835)


Affected Packages:

kernel


Note:

This advisory is applicable to Amazon Linux 2 - Kernel-5.4 Extra. Visit this page to learn more about Amazon Linux 2 (AL2) Extras and this FAQ section for the difference between AL2 Core and AL2 Extras advisories.


Issue Correction:
Run yum update kernel to update your system.

New Packages:
aarch64:
    kernel-5.4.269-183.369.amzn2.aarch64
    kernel-headers-5.4.269-183.369.amzn2.aarch64
    kernel-debuginfo-common-aarch64-5.4.269-183.369.amzn2.aarch64
    perf-5.4.269-183.369.amzn2.aarch64
    perf-debuginfo-5.4.269-183.369.amzn2.aarch64
    python-perf-5.4.269-183.369.amzn2.aarch64
    python-perf-debuginfo-5.4.269-183.369.amzn2.aarch64
    kernel-tools-5.4.269-183.369.amzn2.aarch64
    kernel-tools-devel-5.4.269-183.369.amzn2.aarch64
    kernel-tools-debuginfo-5.4.269-183.369.amzn2.aarch64
    bpftool-5.4.269-183.369.amzn2.aarch64
    bpftool-debuginfo-5.4.269-183.369.amzn2.aarch64
    kernel-devel-5.4.269-183.369.amzn2.aarch64
    kernel-debuginfo-5.4.269-183.369.amzn2.aarch64

i686:
    kernel-headers-5.4.269-183.369.amzn2.i686

src:
    kernel-5.4.269-183.369.amzn2.src

x86_64:
    kernel-5.4.269-183.369.amzn2.x86_64
    kernel-headers-5.4.269-183.369.amzn2.x86_64
    kernel-debuginfo-common-x86_64-5.4.269-183.369.amzn2.x86_64
    perf-5.4.269-183.369.amzn2.x86_64
    perf-debuginfo-5.4.269-183.369.amzn2.x86_64
    python-perf-5.4.269-183.369.amzn2.x86_64
    python-perf-debuginfo-5.4.269-183.369.amzn2.x86_64
    kernel-tools-5.4.269-183.369.amzn2.x86_64
    kernel-tools-devel-5.4.269-183.369.amzn2.x86_64
    kernel-tools-debuginfo-5.4.269-183.369.amzn2.x86_64
    bpftool-5.4.269-183.369.amzn2.x86_64
    bpftool-debuginfo-5.4.269-183.369.amzn2.x86_64
    kernel-devel-5.4.269-183.369.amzn2.x86_64
    kernel-debuginfo-5.4.269-183.369.amzn2.x86_64