• Joanne Koong's avatar
    bpf: Dynptr support for ring buffers · bc34dee6
    Joanne Koong authored
    Currently, our only way of writing dynamically-sized data into a ring
    buffer is through bpf_ringbuf_output but this incurs an extra memcpy
    cost. bpf_ringbuf_reserve + bpf_ringbuf_commit avoids this extra
    memcpy, but it can only safely support reservation sizes that are
    statically known since the verifier cannot guarantee that the bpf
    program won’t access memory outside the reserved space.
    
    The bpf_dynptr abstraction allows for dynamically-sized ring buffer
    reservations without the extra memcpy.
    
    There are 3 new APIs:
    
    long bpf_ringbuf_reserve_dynptr(void *ringbuf, u32 size, u64 flags, struct bpf_dynptr *ptr);
    void bpf_ringbuf_submit_dynptr(struct bpf_dynptr *ptr, u64 flags);
    void bpf_ringbuf_discard_dynptr(struct bpf_dynptr *ptr, u64 flags);
    
    These closely follow the functionalities of the original ringbuf APIs.
    For example, all ringbuffer dynptrs that have been reserved must be
    either submitted or discarded before the program exits.
    Signed-off-by: default avatarJoanne Koong <joannelkoong@gmail.com>
    Signed-off-by: default avatarAndrii Nakryiko <andrii@kernel.org>
    Acked-by: default avatarAndrii Nakryiko <andrii@kernel.org>
    Acked-by: default avatarDavid Vernet <void@manifault.com>
    Link: https://lore.kernel.org/bpf/20220523210712.3641569-4-joannelkoong@gmail.com
    bc34dee6
ringbuf.c 14.5 KB