https://github.com/torvalds/linux
Revision f8bbc07ac535593139c875ffa19af924b1084540 authored by Lei Chen on 15 April 2024, 02:02:46 UTC, committed by Jakub Kicinski on 17 April 2024, 00:13:23 UTC
vhost_worker will call tun call backs to receive packets. If too many illegal packets arrives, tun_do_read will keep dumping packet contents. When console is enabled, it will costs much more cpu time to dump packet and soft lockup will be detected. net_ratelimit mechanism can be used to limit the dumping rate. PID: 33036 TASK: ffff949da6f20000 CPU: 23 COMMAND: "vhost-32980" #0 [fffffe00003fce50] crash_nmi_callback at ffffffff89249253 #1 [fffffe00003fce58] nmi_handle at ffffffff89225fa3 #2 [fffffe00003fceb0] default_do_nmi at ffffffff8922642e #3 [fffffe00003fced0] do_nmi at ffffffff8922660d #4 [fffffe00003fcef0] end_repeat_nmi at ffffffff89c01663 [exception RIP: io_serial_in+20] RIP: ffffffff89792594 RSP: ffffa655314979e8 RFLAGS: 00000002 RAX: ffffffff89792500 RBX: ffffffff8af428a0 RCX: 0000000000000000 RDX: 00000000000003fd RSI: 0000000000000005 RDI: ffffffff8af428a0 RBP: 0000000000002710 R8: 0000000000000004 R9: 000000000000000f R10: 0000000000000000 R11: ffffffff8acbf64f R12: 0000000000000020 R13: ffffffff8acbf698 R14: 0000000000000058 R15: 0000000000000000 ORIG_RAX: ffffffffffffffff CS: 0010 SS: 0018 #5 [ffffa655314979e8] io_serial_in at ffffffff89792594 #6 [ffffa655314979e8] wait_for_xmitr at ffffffff89793470 #7 [ffffa65531497a08] serial8250_console_putchar at ffffffff897934f6 #8 [ffffa65531497a20] uart_console_write at ffffffff8978b605 #9 [ffffa65531497a48] serial8250_console_write at ffffffff89796558 #10 [ffffa65531497ac8] console_unlock at ffffffff89316124 #11 [ffffa65531497b10] vprintk_emit at ffffffff89317c07 #12 [ffffa65531497b68] printk at ffffffff89318306 #13 [ffffa65531497bc8] print_hex_dump at ffffffff89650765 #14 [ffffa65531497ca8] tun_do_read at ffffffffc0b06c27 [tun] #15 [ffffa65531497d38] tun_recvmsg at ffffffffc0b06e34 [tun] #16 [ffffa65531497d68] handle_rx at ffffffffc0c5d682 [vhost_net] #17 [ffffa65531497ed0] vhost_worker at ffffffffc0c644dc [vhost] #18 [ffffa65531497f10] kthread at ffffffff892d2e72 #19 [ffffa65531497f50] ret_from_fork at ffffffff89c0022f Fixes: ef3db4a59542 ("tun: avoid BUG, dump packet on GSO errors") Signed-off-by: Lei Chen <lei.chen@smartx.com> Reviewed-by: Willem de Bruijn <willemb@google.com> Acked-by: Jason Wang <jasowang@redhat.com> Reviewed-by: Eric Dumazet <edumazet@google.com> Acked-by: Michael S. Tsirkin <mst@redhat.com> Link: https://lore.kernel.org/r/20240415020247.2207781-1-lei.chen@smartx.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
1 parent e226ead
Tip revision: f8bbc07ac535593139c875ffa19af924b1084540 authored by Lei Chen on 15 April 2024, 02:02:46 UTC
tun: limit printing rate when illegal packet received by tun dev
tun: limit printing rate when illegal packet received by tun dev
Tip revision: f8bbc07
File | Mode | Size |
---|---|---|
damon | ||
kasan | ||
kfence | ||
kmsan | ||
Kconfig | -rw-r--r-- | 38.6 KB |
Kconfig.debug | -rw-r--r-- | 9.9 KB |
Makefile | -rw-r--r-- | 4.9 KB |
backing-dev.c | -rw-r--r-- | 26.6 KB |
balloon_compaction.c | -rw-r--r-- | 8.2 KB |
bootmem_info.c | -rw-r--r-- | 3.4 KB |
cma.c | -rw-r--r-- | 15.6 KB |
cma.h | -rw-r--r-- | 1.6 KB |
cma_debug.c | -rw-r--r-- | 4.5 KB |
cma_sysfs.c | -rw-r--r-- | 2.9 KB |
compaction.c | -rw-r--r-- | 92.7 KB |
debug.c | -rw-r--r-- | 7.3 KB |
debug_page_alloc.c | -rw-r--r-- | 1.6 KB |
debug_page_ref.c | -rw-r--r-- | 1.4 KB |
debug_vm_pgtable.c | -rw-r--r-- | 40.4 KB |
dmapool.c | -rw-r--r-- | 13.1 KB |
dmapool_test.c | -rw-r--r-- | 2.9 KB |
early_ioremap.c | -rw-r--r-- | 6.7 KB |
fadvise.c | -rw-r--r-- | 5.5 KB |
fail_page_alloc.c | -rw-r--r-- | 1.6 KB |
failslab.c | -rw-r--r-- | 1.6 KB |
filemap.c | -rw-r--r-- | 121.7 KB |
folio-compat.c | -rw-r--r-- | 2.8 KB |
gup.c | -rw-r--r-- | 96.5 KB |
gup_test.c | -rw-r--r-- | 9.0 KB |
gup_test.h | -rw-r--r-- | 1.2 KB |
highmem.c | -rw-r--r-- | 20.2 KB |
hmm.c | -rw-r--r-- | 17.1 KB |
huge_memory.c | -rw-r--r-- | 100.7 KB |
hugetlb.c | -rw-r--r-- | 218.7 KB |
hugetlb_cgroup.c | -rw-r--r-- | 24.2 KB |
hugetlb_vmemmap.c | -rw-r--r-- | 20.7 KB |
hugetlb_vmemmap.h | -rw-r--r-- | 2.3 KB |
hwpoison-inject.c | -rw-r--r-- | 2.8 KB |
init-mm.c | -rw-r--r-- | 1.7 KB |
internal.h | -rw-r--r-- | 42.0 KB |
interval_tree.c | -rw-r--r-- | 3.1 KB |
io-mapping.c | -rw-r--r-- | 993 bytes |
ioremap.c | -rw-r--r-- | 1.7 KB |
khugepaged.c | -rw-r--r-- | 71.8 KB |
kmemleak.c | -rw-r--r-- | 62.8 KB |
ksm.c | -rw-r--r-- | 107.9 KB |
list_lru.c | -rw-r--r-- | 13.8 KB |
maccess.c | -rw-r--r-- | 5.9 KB |
madvise.c | -rw-r--r-- | 38.7 KB |
mapping_dirty_helpers.c | -rw-r--r-- | 10.4 KB |
memblock.c | -rw-r--r-- | 64.9 KB |
memcontrol.c | -rw-r--r-- | 215.4 KB |
memfd.c | -rw-r--r-- | 9.3 KB |
memory-failure.c | -rw-r--r-- | 73.6 KB |
memory-tiers.c | -rw-r--r-- | 24.2 KB |
memory.c | -rw-r--r-- | 175.6 KB |
memory_hotplug.c | -rw-r--r-- | 68.1 KB |
mempolicy.c | -rw-r--r-- | 89.2 KB |
mempool.c | -rw-r--r-- | 17.6 KB |
memremap.c | -rw-r--r-- | 14.4 KB |
memtest.c | -rw-r--r-- | 3.5 KB |
migrate.c | -rw-r--r-- | 69.5 KB |
migrate_device.c | -rw-r--r-- | 27.0 KB |
mincore.c | -rw-r--r-- | 7.1 KB |
mlock.c | -rw-r--r-- | 20.7 KB |
mm_init.c | -rw-r--r-- | 78.4 KB |
mm_slot.h | -rw-r--r-- | 1.4 KB |
mmap.c | -rw-r--r-- | 105.3 KB |
mmap_lock.c | -rw-r--r-- | 6.2 KB |
mmu_gather.c | -rw-r--r-- | 12.3 KB |
mmu_notifier.c | -rw-r--r-- | 34.5 KB |
mmzone.c | -rw-r--r-- | 2.6 KB |
mprotect.c | -rw-r--r-- | 22.4 KB |
mremap.c | -rw-r--r-- | 31.1 KB |
msync.c | -rw-r--r-- | 2.9 KB |
nommu.c | -rw-r--r-- | 44.3 KB |
oom_kill.c | -rw-r--r-- | 33.4 KB |
page-writeback.c | -rw-r--r-- | 94.6 KB |
page_alloc.c | -rw-r--r-- | 192.2 KB |
page_counter.c | -rw-r--r-- | 6.8 KB |
page_ext.c | -rw-r--r-- | 13.6 KB |
page_idle.c | -rw-r--r-- | 5.3 KB |
page_io.c | -rw-r--r-- | 13.7 KB |
page_isolation.c | -rw-r--r-- | 21.5 KB |
page_owner.c | -rw-r--r-- | 23.7 KB |
page_poison.c | -rw-r--r-- | 2.5 KB |
page_reporting.c | -rw-r--r-- | 11.7 KB |
page_reporting.h | -rw-r--r-- | 1.6 KB |
page_table_check.c | -rw-r--r-- | 5.8 KB |
page_vma_mapped.c | -rw-r--r-- | 9.2 KB |
pagewalk.c | -rw-r--r-- | 18.7 KB |
percpu-internal.h | -rw-r--r-- | 7.3 KB |
percpu-km.c | -rw-r--r-- | 3.2 KB |
percpu-stats.c | -rw-r--r-- | 5.8 KB |
percpu-vm.c | -rw-r--r-- | 11.7 KB |
percpu.c | -rw-r--r-- | 102.6 KB |
pgalloc-track.h | -rw-r--r-- | 1.3 KB |
pgtable-generic.c | -rw-r--r-- | 11.1 KB |
process_vm_access.c | -rw-r--r-- | 8.3 KB |
ptdump.c | -rw-r--r-- | 4.6 KB |
readahead.c | -rw-r--r-- | 25.4 KB |
rmap.c | -rw-r--r-- | 78.6 KB |
rodata_test.c | -rw-r--r-- | 1.2 KB |
secretmem.c | -rw-r--r-- | 6.4 KB |
shmem.c | -rw-r--r-- | 130.7 KB |
shmem_quota.c | -rw-r--r-- | 9.5 KB |
show_mem.c | -rw-r--r-- | 11.8 KB |
shrinker.c | -rw-r--r-- | 21.3 KB |
shrinker_debug.c | -rw-r--r-- | 6.1 KB |
shuffle.c | -rw-r--r-- | 4.6 KB |
shuffle.h | -rw-r--r-- | 1.2 KB |
slab.h | -rw-r--r-- | 18.3 KB |
slab_common.c | -rw-r--r-- | 33.7 KB |
slub.c | -rw-r--r-- | 177.2 KB |
sparse-vmemmap.c | -rw-r--r-- | 11.9 KB |
sparse.c | -rw-r--r-- | 25.6 KB |
swap.c | -rw-r--r-- | 31.8 KB |
swap.h | -rw-r--r-- | 4.1 KB |
swap_cgroup.c | -rw-r--r-- | 5.2 KB |
swap_slots.c | -rw-r--r-- | 9.3 KB |
swap_state.c | -rw-r--r-- | 25.7 KB |
swapfile.c | -rw-r--r-- | 92.8 KB |
truncate.c | -rw-r--r-- | 25.6 KB |
usercopy.c | -rw-r--r-- | 8.1 KB |
userfaultfd.c | -rw-r--r-- | 45.0 KB |
util.c | -rw-r--r-- | 29.6 KB |
vmalloc.c | -rw-r--r-- | 131.0 KB |
vmpressure.c | -rw-r--r-- | 14.1 KB |
vmscan.c | -rw-r--r-- | 207.3 KB |
vmstat.c | -rw-r--r-- | 55.6 KB |
workingset.c | -rw-r--r-- | 27.1 KB |
z3fold.c | -rw-r--r-- | 36.8 KB |
zbud.c | -rw-r--r-- | 12.8 KB |
zpool.c | -rw-r--r-- | 9.9 KB |
zsmalloc.c | -rw-r--r-- | 54.1 KB |
zswap.c | -rw-r--r-- | 50.6 KB |
Computing file changes ...