android13/external/camera_engine_rkaiq/rk_stream/stream_cfg/RawStreamProcUnit.h

206 lines
6.5 KiB
C++
Executable File

/*
* Copyright (c) 2021 Rockchip Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
#ifndef _RAW_STREAM_PROC_UNIT_H_
#define _RAW_STREAM_PROC_UNIT_H_
#include <v4l2_device.h>
#include "poll_thread.h"
#include "xcam_mutex.h"
#include "Stream.h"
#include "rk_aiq_offline_raw.h"
#include "rk_vi_user_api2_stream_cfg.h"
#include <map>
using namespace XCam;
namespace RkRawStream {
typedef void (*isp_trigger_readback_callback)(void *tg);
#ifndef ANDROID_OS
typedef void (*user_isp_process_done_callback)(int dev_index);
#else
typedef std::function<void(int dev_index)> user_isp_process_done_callback;
#endif
int _parse_rk_rawdata(void *rawdata, rkrawstream_rkraw2_t *rkraw2);
class CamHwIsp20;
class EmptyClass;
class RawProcThread;
class SimpleFdBuf
{
public:
int _fd{-1};
int _index{-1};
int _seq{-1};
uint64_t _ts{0};
uint8_t *_userptr{NULL};
SimpleFdBuf(int fd, int index) {_fd = fd; _index = index;}
SimpleFdBuf() {_fd = 0; _userptr = NULL;}
// ~EmptyClass() {}
};
class RawStreamProcUnit : public PollCallback
{
public:
//explicit RawStreamProcUnit (char *ispdev, char *dev0, char *dev1, char *dev2, bool linked_to_isp);
explicit RawStreamProcUnit (const rk_sensor_full_info_t *s_info, uint8_t is_offline);
virtual ~RawStreamProcUnit ();
virtual XCamReturn start ();
virtual XCamReturn stop ();
XCamReturn prepare(int idx, uint8_t buf_memory_type, uint8_t buf_cnt);
void set_working_mode (int mode);
void set_rx_format(uint32_t width, uint32_t height, uint32_t pix_fmt, int mode);
void setup_pipeline_fmt(uint32_t width, uint32_t height);
void set_rx_devices();
SmartPtr<V4l2Device> _mipi_rx_devs[3];
/*
SmartPtr<V4l2Device> get_rx_device (int index);
void set_rx_format (const struct v4l2_subdev_format& sns_sd_fmt, uint32_t sns_v4l_pix_fmt);
void set_rx_format (const struct v4l2_subdev_selection& sns_sd_sel, uint32_t sns_v4l_pix_fmt);
void set_devices (SmartPtr<V4l2SubDevice> ispdev, CamHwIsp20* handle);
void set_hdr_frame_readback_infos(int frame_id, int times);
void set_hdr_global_tmo_mode(int frame_id, bool mode);
void notify_sof(uint64_t time, int frameid);
*/
void send_sync_buf(SmartPtr<V4l2BufferProxy> &buf_s, SmartPtr<V4l2BufferProxy> &buf_m, SmartPtr<V4l2BufferProxy> &buf_l);
void send_sync_buf2(uint8_t *rkraw_data);
void _send_sync_buf(rkrawstream_rkraw2_t *rkraw2);
bool raw_buffer_proc();
void setMulCamConc(bool cc) {
_is_multi_cam_conc = cc;
}
enum {
ISP_MIPI_HDR_S = 0,
ISP_MIPI_HDR_M,
ISP_MIPI_HDR_L,
ISP_MIPI_HDR_MAX,
};
// notify CamHwIsp one frame has been processed
void setPollCallback(PollCallback* cb) { _PollCallback = cb; }
// from PollCallback
virtual XCamReturn poll_buffer_ready (SmartPtr<VideoBuffer> &buf, int type) { return XCAM_RETURN_ERROR_FAILED; }
virtual XCamReturn poll_buffer_failed (int64_t timestamp, const char *msg) { return XCAM_RETURN_ERROR_FAILED; }
virtual XCamReturn poll_buffer_ready (SmartPtr<VideoBuffer> &buf) { return XCAM_RETURN_ERROR_FAILED; }
virtual XCamReturn poll_buffer_ready (SmartPtr<V4l2BufferProxy> &buf, int dev_index);
virtual XCamReturn poll_event_ready (uint32_t sequence, int type) { return XCAM_RETURN_ERROR_FAILED; }
virtual XCamReturn poll_event_failed (int64_t timestamp, const char *msg) { return XCAM_RETURN_ERROR_FAILED; }
void setCamPhyId(int phyId) {
mCamPhyId = phyId;
}
user_isp_process_done_callback user_isp_process_done_cb;
/*
XCamReturn capture_raw_ctl(capture_raw_t type, int count = 0, const char* capture_dir = nullptr, char* output_dir = nullptr) {
if (!_rawCap)
return XCAM_RETURN_ERROR_FAILED;
return _rawCap->capture_raw_ctl(type, count, capture_dir, output_dir);
}
XCamReturn notify_capture_raw() {
if (!_rawCap)
return XCAM_RETURN_ERROR_FAILED;
return _rawCap->notify_capture_raw();
}
*/
//isp_trigger_readback_callback isp_trigger_readback_cb;
//void set_isp_trigger_readback_callback(isp_trigger_readback_callback cb) {
// isp_trigger_readback_cb = cb;
//}
//SmartPtr<V4l2Device> _return_dev[3];
protected:
XCAM_DEAD_COPY (RawStreamProcUnit);
void trigger_isp_readback ();
void match_lumadetect_map (uint32_t sequence, sint32_t &additional_times);
void match_globaltmostate_map(uint32_t sequence, bool &isHdrGlobalTmo);
XCamReturn match_sof_timestamp_map(sint32_t sequence, uint64_t &timestamp);
int mCamPhyId;
char _sns_name[32];
protected:
SmartPtr<V4l2Device> _dev[3];
int _dev_index[3];
SmartPtr<RKStream> _stream[3];
int _working_mode;
int _mipi_dev_max;
bool _is_multi_cam_conc;
Mutex _buf_mutex;
std::map<uint32_t, int> _isp_hdr_fid2times_map;
std::map<uint32_t, bool> _isp_hdr_fid2ready_map;
std::map<uint32_t, bool> _hdr_global_tmo_state_map;
std::map<sint32_t, uint64_t> _sof_timestamp_map;
SafeList<V4l2BufferProxy> buf_list[3];
SafeList<V4l2BufferProxy> cache_list[3];
SafeList<SimpleFdBuf> cache_list2[3];
SmartPtr<RawProcThread> _raw_proc_thread;
//CamHwIsp20* _camHw;
SmartPtr<V4l2SubDevice> _isp_core_dev;
SmartPtr<V4l2Device> dummy_dev;
bool _first_trigger;
Mutex _mipi_trigger_mutex;
SafeList<EmptyClass> _msg_queue;
PollCallback* _PollCallback;
enum v4l2_memory _memory_type;
int _offline_index;
int _offline_seq;
//CaptureRawData* _rawCap;
bool is_multi_isp_mode;
uint8_t _is_offline_mode;
int _width;
int _height;
uint8_t *_rawbuffer[3];
};
class RawProcThread
: public Thread
{
public:
RawProcThread (RawStreamProcUnit *handle)
: Thread ("RawProcThread")
, _handle (handle)
{}
protected:
virtual bool loop () {
return _handle->raw_buffer_proc ();
}
private:
RawStreamProcUnit *_handle;
};
class EmptyClass
{
public:
EmptyClass() {}
~EmptyClass() {}
};
}
#endif