Revert "Merge pull request 'kernel + daemon: H.264 B-frame display reorder fix (closes #6)' (#7) from noether/kernel-daemon-h264-reorder-fix into main"
This reverts commit79256dc7ef, reversing changes made to7ff2d897ea.
This commit is contained in:
+22
-57
@@ -56,68 +56,33 @@ int daedalus_decoder_init(struct daedalus_decoder *dec,
|
||||
void daedalus_decoder_cleanup(struct daedalus_decoder *dec);
|
||||
|
||||
/**
|
||||
* daedalus_decoder_submit - send one REQ_DECODE's bitstream into libavcodec
|
||||
* daedalus_decoder_run_request - decode one REQ_DECODE payload
|
||||
* @dec: initialised decoder
|
||||
* @req: REQ_DECODE prefix (from the wire); src_pts is stamped on
|
||||
* the AVPacket so libavcodec returns frame->pts == src_pts
|
||||
* when it eventually outputs the matching frame in display
|
||||
* order (daedalus-v4l2#6).
|
||||
* @req: REQ_DECODE prefix (from the wire)
|
||||
* @bitstream: bitstream blob (req->bitstream_len bytes)
|
||||
* @h264_meta: optional H.264 SPS/PPS metadata; non-NULL only when
|
||||
* codec_id == H264 and the kernel set DAEDALUS_REQ_FLAG_
|
||||
* H264_META. See decoder.c for the AnnexB synthesis.
|
||||
* H264_META. Used to synthesise the AnnexB SPS+PPS NALs
|
||||
* libavcodec needs before any slice (libva-v4l2-request
|
||||
* passes only the slice in @bitstream per the V4L2
|
||||
* stateless API contract). NULL for VP9/AV1 paths.
|
||||
* @resp: caller-allocated RESP_FRAME output (zeroed by callee)
|
||||
* @planes: mapped CAPTURE planes (Phase 8.6 dmabuf path). If
|
||||
* NULL or planes->nr == 0, the decoder runs but
|
||||
* writes no pixels — caller still gets dims + digest.
|
||||
*
|
||||
* Calls avcodec_send_packet on the codec's per-codec AVCodecContext.
|
||||
* Returns 0 on success; one of DAEDALUS_DECODE_ERR_* on failure
|
||||
* (which the caller should propagate as the RESP_FRAME status for
|
||||
* the cookie of this REQ). Does NOT call avcodec_receive_frame —
|
||||
* use daedalus_decoder_drain_one for that.
|
||||
* Populates @resp with the decode outcome and writes decoded
|
||||
* pixels (NV12 layout: Y to plane 0, interleaved CbCr to plane
|
||||
* 1) directly into the mapped dmabuf planes. Always returns
|
||||
* 0; decode-level failures are reported via @resp->status so
|
||||
* the kernel sees a structured response rather than a dropped
|
||||
* request.
|
||||
*/
|
||||
int daedalus_decoder_submit(struct daedalus_decoder *dec,
|
||||
const struct daedalus_req_decode *req,
|
||||
const uint8_t *bitstream,
|
||||
const struct daedalus_h264_meta *h264_meta);
|
||||
|
||||
/**
|
||||
* daedalus_decoder_drain_one - pop the next display-ordered frame, if any
|
||||
* @dec: initialised decoder
|
||||
* @codec_id: which codec context to drain (matches the REQ that just
|
||||
* called submit). VP9/AV1/H264 use independent contexts.
|
||||
* @resp: caller-allocated RESP_FRAME output (zeroed by callee).
|
||||
* On a successful drain (return 0), resp's status / width /
|
||||
* height / pix_fmt / luma_len / chroma_len / fnv1a_yuv /
|
||||
* output_src_pts are populated; flags is left at 0 (caller
|
||||
* adds HAS_PIXELS / SRC_CONSUMED). On EAGAIN, resp is
|
||||
* zeroed.
|
||||
*
|
||||
* Return: 0 on a frame returned, -EAGAIN if libavcodec needs more
|
||||
* input (display-order frame held inside DPB), <0 on a hard codec
|
||||
* error (resp->status set).
|
||||
*
|
||||
* After a successful drain, the dec's internal AVFrame holds the
|
||||
* decoded picture. Caller may immediately call
|
||||
* daedalus_decoder_pack_current(planes) to write that picture into
|
||||
* a CAPTURE buffer's dmabuf-mapped planes. Subsequent calls to
|
||||
* drain_one (without another submit) try to pull additional frames
|
||||
* from libavcodec's DPB.
|
||||
*/
|
||||
int daedalus_decoder_drain_one(struct daedalus_decoder *dec,
|
||||
uint32_t codec_id,
|
||||
struct daedalus_resp_frame *resp);
|
||||
|
||||
/**
|
||||
* daedalus_decoder_pack_current - pack the last drained frame into planes
|
||||
* @dec: initialised decoder; must have a frame from drain_one
|
||||
* @planes: mapped CAPTURE planes (open via GET_DMABUF using the
|
||||
* cookie that owns the frame's output_src_pts).
|
||||
* @capture_pix_fmt: V4L2 fourcc on the CAPTURE side (NV12M, NV12,
|
||||
* P010).
|
||||
*
|
||||
* Return: 0 on success, <0 on a pack failure (kernel sees only the
|
||||
* metadata, not pixels — typical when a format isn't wired yet).
|
||||
*/
|
||||
int daedalus_decoder_pack_current(struct daedalus_decoder *dec,
|
||||
const struct daedalus_capture_planes *planes,
|
||||
uint32_t capture_pix_fmt);
|
||||
int daedalus_decoder_run_request(struct daedalus_decoder *dec,
|
||||
const struct daedalus_req_decode *req,
|
||||
const uint8_t *bitstream,
|
||||
const struct daedalus_h264_meta *h264_meta,
|
||||
struct daedalus_resp_frame *resp,
|
||||
const struct daedalus_capture_planes *planes);
|
||||
|
||||
#endif /* DAEDALUS_V4L2_DECODER_H */
|
||||
|
||||
Reference in New Issue
Block a user