c45fea96e3
Compound patch carrying the fork's pre-Step-1 substrate, originally authored by Jernej Škrabec / fourier on top of bootlin'sa3c2476: - src/h264.c + src/picture.c: V4L2_CID_MPEG_VIDEO_H264_* renamed to V4L2_CID_STATELESS_H264_*, struct shapes tracked to mainline (V4L2_CID_STATELESS_H264_DECODE_MODE/_START_CODE added to the passthrough shim). - include/hevc-ctrls.h: redirect shim to <linux/v4l2-controls.h> (kernel-side HEVC controls now live in the canonical UAPI header). - src/meson.build: src/h265.c / src/h265.h commented out — HEVC build path is excluded from this fork (RK3568 hantro G1/G2 has no HEVC, and the kernel-side HEVC controls have a separate rework in flight upstream). - src/tiled_yuv.S: aarch64 stub for tiled_to_planar (assembly source was sunxi-cedrus armv7-only; aarch64 needs a stub to keep the build linking). - include/h264-ctrls.h: removed (dead post-fourier — no source includes it; the passthrough shim's CID aliases live in the kernel header now). Functionally equivalent to the prior fork master commits:c1f5108V4L2_PIX_FMT_H264_SLICE rename4ccbfe9Strip HEVC build pathda9f2a5include/h264-ctrls.h passthrough + CID aliasesfc4bb10src/h264.c track upstream UAPI shape13e9b64src/h264.c drop num_slices field4d14ffbsrc/tiled_yuv.S aarch64 stub1b02c9bsrc/h264.c include utils.h Folded into one commit during 2026-05-04 Step 1 reconciliation (see ../phase0_evidence/2026-05-04/findings.md). Per-patch history of the early fork commits preserved on the pre-step1 branch. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
68 lines
3.1 KiB
C
68 lines
3.1 KiB
C
/*
|
|
* Copyright (C) 2018 Paul Kocialkowski <paul.kocialkowski@bootlin.com>
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
* copy of this software and associated documentation files (the
|
|
* "Software"), to deal in the Software without restriction, including
|
|
* without limitation the rights to use, copy, modify, merge, publish,
|
|
* distribute, sub license, and/or sell copies of the Software, and to
|
|
* permit persons to whom the Software is furnished to do so, subject to
|
|
* the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice (including the
|
|
* next paragraph) shall be included in all copies or substantial portions
|
|
* of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
|
|
* IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR
|
|
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
#ifndef _V4L2_H_
|
|
#define _V4L2_H_
|
|
|
|
#include <stdbool.h>
|
|
|
|
#define SOURCE_SIZE_MAX (1024 * 1024)
|
|
|
|
unsigned int v4l2_type_video_output(bool mplane);
|
|
unsigned int v4l2_type_video_capture(bool mplane);
|
|
int v4l2_query_capabilities(int video_fd, unsigned int *capabilities);
|
|
bool v4l2_find_format(int video_fd, unsigned int type,
|
|
unsigned int pixelformat);
|
|
int v4l2_set_format(int video_fd, unsigned int type, unsigned int pixelformat,
|
|
unsigned int width, unsigned int height);
|
|
int v4l2_get_format(int video_fd, unsigned int type, unsigned int *width,
|
|
unsigned int *height, unsigned int *bytesperline,
|
|
unsigned int *sizes, unsigned int *planes_count);
|
|
int v4l2_create_buffers(int video_fd, unsigned int type,
|
|
unsigned int buffers_count, unsigned int *index_base);
|
|
int v4l2_query_buffer(int video_fd, unsigned int type, unsigned int index,
|
|
unsigned int *lengths, unsigned int *offsets,
|
|
unsigned int buffers_count);
|
|
int v4l2_request_buffers(int video_fd, unsigned int type,
|
|
unsigned int buffers_count);
|
|
int v4l2_queue_buffer(int video_fd, int request_fd, unsigned int type,
|
|
struct timeval *timestamp, unsigned int index,
|
|
unsigned int size, unsigned int buffers_count);
|
|
int v4l2_dequeue_buffer(int video_fd, int request_fd, unsigned int type,
|
|
unsigned int index, unsigned int buffers_count);
|
|
int v4l2_export_buffer(int video_fd, unsigned int type, unsigned int index,
|
|
unsigned int flags, int *export_fds,
|
|
unsigned int export_fds_count);
|
|
int v4l2_get_controls(int video_fd, int request_fd,
|
|
struct v4l2_ext_control *controls,
|
|
unsigned int num_controls);
|
|
int v4l2_set_controls(int video_fd, int request_fd,
|
|
struct v4l2_ext_control *controls,
|
|
unsigned int num_controls);
|
|
int v4l2_set_control(int video_fd, int request_fd, unsigned int id, void *data,
|
|
unsigned int size);
|
|
int v4l2_set_stream(int video_fd, unsigned int type, bool enable);
|
|
|
|
#endif
|