21#include "libcamera/internal/global_configuration.h"
24#include "swstats_cpu.h"
35 const std::vector<std::reference_wrapper<StreamConfiguration>> &outputCfgs,
39 std::tuple<unsigned int, unsigned int>
56 unsigned int frameSize() {
return outputConfig_.frameSize; }
87 using debayerFn = void (
DebayerCpu::*)(uint8_t *dst,
const uint8_t *src[]);
90 template<
bool addAlphaByte,
bool ccmEnabled>
91 void debayer8_BGBG_BGR888(uint8_t *dst,
const uint8_t *src[]);
92 template<
bool addAlphaByte,
bool ccmEnabled>
93 void debayer8_GRGR_BGR888(uint8_t *dst,
const uint8_t *src[]);
95 template<
bool addAlphaByte,
bool ccmEnabled>
96 void debayer10_BGBG_BGR888(uint8_t *dst,
const uint8_t *src[]);
97 template<
bool addAlphaByte,
bool ccmEnabled>
98 void debayer10_GRGR_BGR888(uint8_t *dst,
const uint8_t *src[]);
100 template<
bool addAlphaByte,
bool ccmEnabled>
101 void debayer12_BGBG_BGR888(uint8_t *dst,
const uint8_t *src[]);
102 template<
bool addAlphaByte,
bool ccmEnabled>
103 void debayer12_GRGR_BGR888(uint8_t *dst,
const uint8_t *src[]);
105 template<
bool addAlphaByte,
bool ccmEnabled>
106 void debayer10P_BGBG_BGR888(uint8_t *dst,
const uint8_t *src[]);
107 template<
bool addAlphaByte,
bool ccmEnabled>
108 void debayer10P_GRGR_BGR888(uint8_t *dst,
const uint8_t *src[]);
109 template<
bool addAlphaByte,
bool ccmEnabled>
110 void debayer10P_GBGB_BGR888(uint8_t *dst,
const uint8_t *src[]);
111 template<
bool addAlphaByte,
bool ccmEnabled>
112 void debayer10P_RGRG_BGR888(uint8_t *dst,
const uint8_t *src[]);
114 struct DebayerInputConfig {
118 std::vector<PixelFormat> outputFormats;
121 struct DebayerOutputConfig {
127 int getInputConfig(PixelFormat inputFormat, DebayerInputConfig &config);
128 int getOutputConfig(PixelFormat outputFormat, DebayerOutputConfig &config);
130 int setDebayerFunctions(PixelFormat inputFormat,
131 PixelFormat outputFormat,
133 void setupInputMemcpy(
const uint8_t *linePointers[]);
134 void shiftLinePointers(
const uint8_t *linePointers[],
const uint8_t *src);
135 void memcpyNextLine(
const uint8_t *linePointers[]);
136 void process2(uint32_t frame,
const uint8_t *src, uint8_t *dst);
137 void process4(uint32_t frame,
const uint8_t *src, uint8_t *dst);
140 static constexpr unsigned int kMaxLineBuffers = 5;
154 DebayerInputConfig inputConfig_;
155 DebayerOutputConfig outputConfig_;
156 std::unique_ptr<SwStatsCpu> stats_;
157 std::vector<uint8_t> lineBuffers_[kMaxLineBuffers];
158 unsigned int lineBufferLength_;
159 unsigned int lineBufferPadding_;
160 unsigned int lineBufferIndex_;
161 unsigned int xShift_;
162 bool enableInputMemcpy_;
163 bool swapRedBlueGains_;
164 unsigned int encounteredFrames_;
165 int64_t frameProcessTime_;
166 unsigned int skipBeforeMeasure_ = 30;
167 unsigned int framesToMeasure_ = 30;
Class for debayering on the CPU.
Definition debayer_cpu.h:29
void process(uint32_t frame, FrameBuffer *input, FrameBuffer *output, DebayerParams params)
Process the bayer data into the requested format.
Definition debayer_cpu.cpp:778
Size patternSize(PixelFormat inputFormat)
Get the width and height at which the bayer pattern repeats.
Definition debayer_cpu.cpp:584
SizeRange sizes(PixelFormat inputFormat, const Size &inputSize)
Get the supported output sizes for the given input format and size.
Definition debayer_cpu.cpp:866
unsigned int frameSize()
Get the output frame size.
Definition debayer_cpu.h:56
int configure(const StreamConfiguration &inputCfg, const std::vector< std::reference_wrapper< StreamConfiguration > > &outputCfgs, bool ccmEnabled)
Configure the debayer object according to the passed in parameters.
Definition debayer_cpu.cpp:503
DebayerCpu(std::unique_ptr< SwStatsCpu > stats, const GlobalConfiguration &configuration)
Constructs a DebayerCpu object.
Definition debayer_cpu.cpp:44
std::vector< PixelFormat > formats(PixelFormat input)
Get the supported output formats.
Definition debayer_cpu.cpp:594
std::tuple< unsigned int, unsigned int > strideAndFrameSize(const PixelFormat &outputFormat, const Size &size)
Get the stride and the frame size.
Definition debayer_cpu.cpp:605
const SharedFD & getStatsFD()
Get the file descriptor for the statistics.
Definition debayer_cpu.h:49
Base debayering class.
Definition debayer.h:31
Frame buffer data and its associated dynamic metadata.
Definition framebuffer.h:50
Support for global libcamera configuration.
Definition global_configuration.h:22
Object(Object *parent=nullptr)
Construct an Object instance.
Definition object.cpp:69
RAII-style wrapper for file descriptors.
Definition shared_fd.h:17
Describe a range of sizes.
Definition geometry.h:205
Describe a two-dimensional size.
Definition geometry.h:51
Top-level libcamera namespace.
Definition backtrace.h:17
Base object to support automatic signal disconnection.
Struct to hold the debayer parameters.
Definition debayer_params.h:18
std::array< CcmColumn, kRGBLookupSize > CcmLookupTable
Type of the CCM lookup tables for red, green, blue values.
Definition debayer_params.h:28
std::array< uint8_t, kRGBLookupSize > LookupTable
Type of the lookup tables for single lookup values.
Definition debayer_params.h:27
Configuration parameters for a stream.
Definition stream.h:40