hc
2023-12-11 d2ccde1c8e90d38cee87a1b0309ad2827f3fd30d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/* SPDX-License-Identifier: GPL-2.0+ */
/*
 * vimc-streamer.h Virtual Media Controller Driver
 *
 * Copyright (C) 2018 Lucas A. M. Magalhães <lucmaga@gmail.com>
 *
 */
 
#ifndef _VIMC_STREAMER_H_
#define _VIMC_STREAMER_H_
 
#include <media/media-device.h>
 
#include "vimc-common.h"
 
#define VIMC_STREAMER_PIPELINE_MAX_SIZE 16
 
/**
 * struct vimc_stream - struct that represents a stream in the pipeline
 *
 * @pipe:        the media pipeline object associated with this stream
 * @ved_pipeline:    array containing all the entities participating in the
 *             stream. The order is from a video device (usually a
 *            capture device) where stream_on was called, to the
 *            entity generating the first base image to be
 *            processed in the pipeline.
 * @pipe_size:        size of @ved_pipeline
 * @kthread:        thread that generates the frames of the stream.
 *
 * When the user call stream_on in a video device, struct vimc_stream is
 * used to keep track of all entities and subdevices that generates and
 * process frames for the stream.
 */
struct vimc_stream {
   struct media_pipeline pipe;
   struct vimc_ent_device *ved_pipeline[VIMC_STREAMER_PIPELINE_MAX_SIZE];
   unsigned int pipe_size;
   struct task_struct *kthread;
};
 
int vimc_streamer_s_stream(struct vimc_stream *stream,
              struct vimc_ent_device *ved,
              int enable);
 
#endif  //_VIMC_STREAMER_H_