/* SPDX-License-Identifier: LGPL-2.1-or-later */ /* * Copyright (C) 2024, Ideas On Board Oy * * lsc.h - Mali-C55 Lens shading correction algorithm */ #include <map> #include <tuple> #include "algorithm.h" namespace libcamera { namespace ipa::mali_c55::algorithms { class Lsc : public Algorithm { public: Lsc() = default; ~Lsc() = default; int init(IPAContext &context, const YamlObject &tuningData) override; void prepare(IPAContext &context, const uint32_t frame, IPAFrameContext &frameContext, mali_c55_params_buffer *params) override; private: static constexpr unsigned int kRedOffset = 0; static constexpr unsigned int kGreenOffset = 1024; static constexpr unsigned int kBlueOffset = 2048; size_t fillConfigParamsBlock(mali_c55_params_block block) const; size_t fillSelectionParamsBlock(mali_c55_params_block block, uint8_t bank, uint8_t alpha) const; std::tuple<uint8_t, uint8_t> findBankAndAlpha(uint32_t ct) const; std::vector<uint32_t> mesh_ = std::vector<uint32_t>(3072); std::vector<uint32_t> colourTemperatures_; uint32_t meshScale_; uint32_t meshSize_; }; } /* namespace ipa::mali_c55::algorithms */ } /* namespace libcamera */