1*67ee5ad2SAlexei Starovoitov // SPDX-License-Identifier: GPL-2.0 2*67ee5ad2SAlexei Starovoitov /* Copyright (c) 2026 Meta Platforms, Inc. and affiliates. */ 3*67ee5ad2SAlexei Starovoitov #include <test_progs.h> 4*67ee5ad2SAlexei Starovoitov #include "timer_start_deadlock.skel.h" 5*67ee5ad2SAlexei Starovoitov 6*67ee5ad2SAlexei Starovoitov void test_timer_start_deadlock(void) 7*67ee5ad2SAlexei Starovoitov { 8*67ee5ad2SAlexei Starovoitov struct timer_start_deadlock *skel; 9*67ee5ad2SAlexei Starovoitov int err, prog_fd; 10*67ee5ad2SAlexei Starovoitov LIBBPF_OPTS(bpf_test_run_opts, opts); 11*67ee5ad2SAlexei Starovoitov 12*67ee5ad2SAlexei Starovoitov skel = timer_start_deadlock__open_and_load(); 13*67ee5ad2SAlexei Starovoitov if (!ASSERT_OK_PTR(skel, "skel_open_and_load")) 14*67ee5ad2SAlexei Starovoitov return; 15*67ee5ad2SAlexei Starovoitov 16*67ee5ad2SAlexei Starovoitov err = timer_start_deadlock__attach(skel); 17*67ee5ad2SAlexei Starovoitov if (!ASSERT_OK(err, "skel_attach")) 18*67ee5ad2SAlexei Starovoitov goto cleanup; 19*67ee5ad2SAlexei Starovoitov 20*67ee5ad2SAlexei Starovoitov prog_fd = bpf_program__fd(skel->progs.start_timer); 21*67ee5ad2SAlexei Starovoitov 22*67ee5ad2SAlexei Starovoitov /* 23*67ee5ad2SAlexei Starovoitov * Run the syscall program that attempts to deadlock. 24*67ee5ad2SAlexei Starovoitov * If the kernel deadlocks, this call will never return. 25*67ee5ad2SAlexei Starovoitov */ 26*67ee5ad2SAlexei Starovoitov err = bpf_prog_test_run_opts(prog_fd, &opts); 27*67ee5ad2SAlexei Starovoitov ASSERT_OK(err, "prog_test_run"); 28*67ee5ad2SAlexei Starovoitov ASSERT_EQ(opts.retval, 0, "prog_retval"); 29*67ee5ad2SAlexei Starovoitov 30*67ee5ad2SAlexei Starovoitov ASSERT_EQ(skel->bss->tp_called, 1, "tp_called"); 31*67ee5ad2SAlexei Starovoitov cleanup: 32*67ee5ad2SAlexei Starovoitov timer_start_deadlock__destroy(skel); 33*67ee5ad2SAlexei Starovoitov } 34