[PATCH v3.1 09/17] fixup! libcamera: converter: Add functions to adjust config
Jacopo Mondi
jacopo.mondi at ideasonboard.com
Thu Dec 12 18:56:35 CET 2024
Signed-off-by: Jacopo Mondi <jacopo.mondi at ideasonboard.com>
---
include/libcamera/internal/converter.h | 10 ++++------
.../libcamera/internal/converter/converter_v4l2_m2m.h | 8 ++++----
src/libcamera/converter.cpp | 11 ++++-------
src/libcamera/converter/converter_v4l2_m2m.cpp | 10 +++++-----
4 files changed, 17 insertions(+), 22 deletions(-)
diff --git a/include/libcamera/internal/converter.h b/include/libcamera/internal/converter.h
index 9213ae5b9c33..12de6aef0e40 100644
--- a/include/libcamera/internal/converter.h
+++ b/include/libcamera/internal/converter.h
@@ -43,11 +43,9 @@ public:
enum class Alignment {
Down = 0,
- Up = (1 << 0),
+ Up,
};
- using Alignments = Flags<Alignment>;
-
Converter(MediaDevice *media, Features features = Feature::None);
virtual ~Converter();
@@ -60,16 +58,16 @@ public:
virtual Size adjustInputSize(const PixelFormat &pixFmt,
const Size &size,
- Alignments align = Alignment::Down) = 0;
+ Alignment align = Alignment::Down) = 0;
virtual Size adjustOutputSize(const PixelFormat &pixFmt,
const Size &size,
- Alignments align = Alignment::Down) = 0;
+ Alignment align = Alignment::Down) = 0;
virtual std::tuple<unsigned int, unsigned int>
strideAndFrameSize(const PixelFormat &pixelFormat, const Size &size) = 0;
virtual int validateOutput(StreamConfiguration *cfg, bool *adjusted,
- Alignments align = Alignment::Down) = 0;
+ Alignment align = Alignment::Down) = 0;
virtual int configure(const StreamConfiguration &inputCfg,
const std::vector<std::reference_wrapper<StreamConfiguration>> &outputCfgs) = 0;
diff --git a/include/libcamera/internal/converter/converter_v4l2_m2m.h b/include/libcamera/internal/converter/converter_v4l2_m2m.h
index 89bd2878b190..89c398614006 100644
--- a/include/libcamera/internal/converter/converter_v4l2_m2m.h
+++ b/include/libcamera/internal/converter/converter_v4l2_m2m.h
@@ -48,9 +48,9 @@ public:
strideAndFrameSize(const PixelFormat &pixelFormat, const Size &size);
Size adjustInputSize(const PixelFormat &pixFmt,
- const Size &size, Alignments align = Alignment::Down) override;
+ const Size &size, Alignment align = Alignment::Down) override;
Size adjustOutputSize(const PixelFormat &pixFmt,
- const Size &size, Alignments align = Alignment::Down) override;
+ const Size &size, Alignment align = Alignment::Down) override;
int configure(const StreamConfiguration &inputCfg,
const std::vector<std::reference_wrapper<StreamConfiguration>> &outputCfg);
@@ -61,7 +61,7 @@ public:
void stop();
int validateOutput(StreamConfiguration *cfg, bool *adjusted,
- Alignments align = Alignment::Down) override;
+ Alignment align = Alignment::Down) override;
int queueBuffers(FrameBuffer *input,
const std::map<const Stream *, FrameBuffer *> &outputs);
@@ -110,7 +110,7 @@ private:
};
Size adjustSizes(const Size &size, const std::vector<SizeRange> &ranges,
- Alignments align);
+ Alignment align);
std::unique_ptr<V4L2M2MDevice> m2m_;
diff --git a/src/libcamera/converter.cpp b/src/libcamera/converter.cpp
index c3da162b7de7..c373564d6007 100644
--- a/src/libcamera/converter.cpp
+++ b/src/libcamera/converter.cpp
@@ -60,11 +60,6 @@ LOG_DEFINE_CATEGORY(Converter)
* \brief Adjust the Converter sizes to a larger valid size
*/
-/**
- * \typedef Converter::Alignments
- * \brief A bitwise combination of alignments supported by the converter
- */
-
/**
* \brief Construct a Converter instance
* \param[in] media The media device implementing the converter
@@ -131,7 +126,8 @@ Converter::~Converter()
* \param[in] pixFmt The pixel format of the converter input stream
* \param[in] size The converter input size to adjust to a valid value
* \param[in] align The desired alignment
- * \return The adjusted converter input size
+ * \return The adjusted converter input size or a null Size if \a size cannot
+ * be adjusted
*/
/**
@@ -140,7 +136,8 @@ Converter::~Converter()
* \param[in] pixFmt The pixel format of the converter output stream
* \param[in] size The converter output size to adjust to a valid value
* \param[in] align The desired alignment
- * \return The adjusted converter output size
+ * \return The adjusted converter output size or a null Size if \a size cannot
+ * be adjusted
*/
/**
diff --git a/src/libcamera/converter/converter_v4l2_m2m.cpp b/src/libcamera/converter/converter_v4l2_m2m.cpp
index 6857472b29f2..17098f69c934 100644
--- a/src/libcamera/converter/converter_v4l2_m2m.cpp
+++ b/src/libcamera/converter/converter_v4l2_m2m.cpp
@@ -405,7 +405,7 @@ V4L2M2MConverter::strideAndFrameSize(const PixelFormat &pixelFormat,
* \copydoc libcamera::Converter::adjustInputSize
*/
Size V4L2M2MConverter::adjustInputSize(const PixelFormat &pixFmt,
- const Size &size, Alignments align)
+ const Size &size, Alignment align)
{
auto formats = m2m_->output()->formats();
V4L2PixelFormat v4l2PixFmt = m2m_->output()->toV4L2PixelFormat(pixFmt);
@@ -424,7 +424,7 @@ Size V4L2M2MConverter::adjustInputSize(const PixelFormat &pixFmt,
* \copydoc libcamera::Converter::adjustOutputSize
*/
Size V4L2M2MConverter::adjustOutputSize(const PixelFormat &pixFmt,
- const Size &size, Alignments align)
+ const Size &size, Alignment align)
{
auto formats = m2m_->capture()->formats();
V4L2PixelFormat v4l2PixFmt = m2m_->capture()->toV4L2PixelFormat(pixFmt);
@@ -441,7 +441,7 @@ Size V4L2M2MConverter::adjustOutputSize(const PixelFormat &pixFmt,
Size V4L2M2MConverter::adjustSizes(const Size &cfgSize,
const std::vector<SizeRange> &ranges,
- Alignments align)
+ Alignment align)
{
Size size = cfgSize;
@@ -495,7 +495,7 @@ Size V4L2M2MConverter::adjustSizes(const Size &cfgSize,
* alignment: smaller than s1 if we align down, larger than s1
* if we align up.
*/
- auto nextSizeValid = [](const Size &s1, const Size &s2, Alignments a) {
+ auto nextSizeValid = [](const Size &s1, const Size &s2, Alignment a) {
return a == Alignment::Down
? (s1.width > s2.width && s1.height > s2.height)
: (s1.width < s2.width && s1.height < s2.height);
@@ -633,7 +633,7 @@ void V4L2M2MConverter::stop()
* \copydoc libcamera::Converter::validateOutput
*/
int V4L2M2MConverter::validateOutput(StreamConfiguration *cfg, bool *adjusted,
- Alignments align)
+ Alignment align)
{
V4L2VideoDevice *capture = m2m_->capture();
V4L2VideoDevice::Formats fmts = capture->formats();
--
2.47.1
More information about the libcamera-devel
mailing list