From: Alexei Starovoitov Date: Thu, 20 Apr 2023 23:49:17 +0000 (-0700) Subject: Merge branch 'fix __retval() being always ignored' X-Git-Tag: nvme-6.4-2023-05-26~147^2~25^2~30 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=267a6e4e7870beb8896c192da175800e47c82407;p=nvme.git Merge branch 'fix __retval() being always ignored' Eduard Zingerman says: ==================== Florian Westphal found a bug in test_loader.c processing of __retval tag. Because of this bug the function test_loader.c:do_prog_test_run() never executed and all __retval test tags were ignored. See [1]. Fix for this bug uncovers two additional bugs: - During test_verifier tests migration to inline assembly (see [2]) I missed the fact that some tests require maps to contain mock values; - Some issue with a new refcounted_kptr test, which causes kernel to produce dead lock and refcount saturation warnings when subject to libbpf's bpf_test_run_opts(). This series fixes the bug in __retval() processing, and address the issue with test maps not being populated. The issue in refcounted_kptr is not addressed, __retval tags in those tests are commented out. I found that the following tests depend on test maps being populated: - progs/verifier_array_access.c - verifier/value_ptr_arith.c (planned for migration to inline assembly) Given the small amount of these tests I decided to opt for simple non-generic solution (see patch #4). [1] https://lore.kernel.org/bpf/f4c4aee644425842ee6aa8edf1da68f0a8260e7c.camel@gmail.com/T/ [2] https://lore.kernel.org/bpf/20230325025524.144043-1-eddyz87@gmail.com/ ==================== Signed-off-by: Alexei Starovoitov --- 267a6e4e7870beb8896c192da175800e47c82407