On Wed, Jul 16, 2025 at 06:10:09PM -0700, Tiffany Yang wrote: > Each case tested by the binder allocator test is defined by 3 parameters: > the end alignment type of each requested buffer allocation, whether those > buffers share the front or back pages of the allotted address space, and > the order in which those buffers should be released. The alignment type > represents how a binder buffer may be laid out within or across page > boundaries and relative to other buffers, and it's used along with > whether the buffers cover part (sharing the front pages) of or all > (sharing the back pages) of the vma to calculate the sizes passed into > each test. > > binder_alloc_test_alloc recursively generates each possible arrangement > of alignment types and then tests that the binder_alloc code tracks pages > correctly when those buffers are allocated and then freed in every > possible order at both ends of the address space. While they provide > comprehensive coverage, they are poor candidates to be represented as > KUnit test cases, which must be statically enumerated. For 5 buffers and > 5 end alignment types, the test case array would have 750,000 entries. > This change structures the recursive calls into meaningful test cases so > that failures are easier to interpret. > > Cc: Kees Cook <k...@kernel.org> > Acked-by: Carlos Llamas <cmlla...@google.com> > Signed-off-by: Tiffany Yang <ynaf...@google.com> > [...] > +struct binder_alloc_test_case_info { > + char alignments[ALIGNMENTS_BUFLEN]; > + struct seq_buf alignments_sb;
This really screams for a struct-based way to in-place declare a seq_buf. The current macro only works on the stack. I think this will work; I'll send a patch once I get it tested: #define DECLARE_SEQ_BUF(NAME, SIZE) \ char NAME##_buffer[size]; \ struct seq_buf NAME = { \ .buffer = &NAME##_buffer, \ .size = SIZE, \ } But yes, this and the seq_buf_init below is correct. Reviewed-by: Kees Cook <k...@kernel.org> -- Kees Cook