| /* |
| * Copyright (C) 2016-2020 Intel 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. |
| */ |
| |
| #pragma once |
| |
| #include <queue> |
| #include <memory> |
| |
| #ifdef ENABLE_SANDBOXING |
| #include "modules/sandboxing/client/IntelLtm.h" |
| #else |
| #include "modules/algowrapper/IntelLtm.h" |
| #endif |
| |
| #include "CameraEvent.h" |
| #include "AiqSetting.h" |
| #include "AiqResult.h" |
| #include "iutils/Thread.h" |
| #include "iutils/CameraDump.h" |
| |
| namespace icamera { |
| |
| struct ltm_result_t { |
| ia_ltm_drc_params ltmDrcParams; |
| ia_ltm_results ltmResults; |
| |
| camera_resolution_t yvGridInfo; |
| |
| long sequence; |
| |
| ltm_result_t() { |
| CLEAR(ltmDrcParams); |
| CLEAR(ltmResults); |
| yvGridInfo = {0, 0}; |
| sequence = -1; |
| } |
| }; |
| |
| struct LtmInputParams { |
| ia_isp_bxt_hdr_yv_grid_t yvGrid; |
| ia_ltm_input_params ltmParams; |
| ia_ltm_gtm_input_params gtmParams; |
| long sequence; |
| |
| LtmInputParams() { |
| CLEAR(yvGrid); |
| CLEAR(ltmParams); |
| CLEAR(gtmParams); |
| sequence = -1; |
| } |
| }; |
| /** |
| * There are two SIS port, SIS_A is for preview. |
| * SIS_B is for still and capture. |
| */ |
| enum SisPort |
| { |
| SIS_A = 0, |
| SIS_B, |
| MAX_SIS_NUM |
| }; |
| |
| struct SisBuffer |
| { |
| SisPort sisPort; |
| ia_binary_data sisImage; |
| |
| SisBuffer() { |
| sisPort = SIS_A; |
| CLEAR(sisImage); |
| } |
| }; |
| |
| struct LtmStatistics { |
| LtmStatistics(ia_isp_bxt_hdr_yv_grid_t *inputYvGrid = nullptr, long seq = -1) { |
| yvGrid = inputYvGrid; |
| sequence = seq; |
| } |
| ia_isp_bxt_hdr_yv_grid_t *yvGrid; |
| long sequence; |
| }; |
| |
| /** |
| * \class Ltm |
| * This class is used to run Local tone mapping (Ltm) algorithm. |
| */ |
| class Ltm : public EventListener { |
| public: |
| Ltm(int cameraId); |
| ~Ltm(); |
| |
| int init(); |
| int deinit(); |
| int start(); |
| void stop(); |
| |
| int configure(const std::vector<ConfigMode>& configModes); |
| |
| /** |
| * \brief handle statistics event |
| */ |
| void handleEvent(EventData eventData); |
| |
| int handleLtm(ia_isp_bxt_hdr_yv_grid_t* yvGrid, |
| unsigned long long timestamp = 0, |
| long sequence = 0); |
| int handleSisLtm(const std::shared_ptr<CameraBuffer> &cameraBuffer); |
| private: |
| DISALLOW_COPY_AND_ASSIGN(Ltm); |
| |
| int runLtm(); |
| int initLtmParams(); |
| int runLtm(ia_aiq_ae_results* aeResult, ltm_result_t *ltmResult, ia_ltm_input_params *ltmParams = NULL); |
| |
| int initIaLtmHandle(TuningMode tuningMode); |
| int deinitIaLtmHandle(); |
| |
| int updateTuningData(); |
| AiqResult *getAiqResult(long sequence); |
| int updateParameter(const aiq_parameter_t ¶m, unsigned long long timestamp); |
| |
| int dumpLtmDrcParams(const ia_ltm_drc_params* ltmDrcParams); |
| int dumpLtmResultsParams(const ia_ltm_results *ltmResults); |
| |
| private: |
| /** |
| * \brief The ltm thread |
| */ |
| class LtmThread: public Thread { |
| Ltm *mLtmHandle; |
| public: |
| LtmThread(Ltm *pThis) |
| : mLtmHandle(pThis) { } |
| |
| virtual bool threadLoop() { |
| int ret = mLtmHandle->runLtm(); |
| return (ret == 0); |
| } |
| }; |
| |
| int mCameraId; |
| ia_ltm *mLtm; |
| TuningMode mTuningMode; |
| |
| enum LtmState { |
| LTM_NOT_INIT = 0, |
| LTM_INIT, |
| LTM_CONFIGURED, |
| LTM_MAX |
| } mLtmState; |
| |
| // Use it to lock mInputParamIndex and mLtmParams |
| // And use it for thread condition lock |
| Mutex mLtmLock; |
| LtmThread *mLtmThread; |
| bool mThreadRunning; |
| Condition mParamAvailableSignal; |
| static const nsecs_t kWaitDuration = 2000000000; // 2000ms |
| static const int kMaxLtmParamsNum = 2; // 2 ltm input params |
| |
| int mInputParamIndex; |
| LtmInputParams *mLtmParams[kMaxLtmParamsNum]; |
| std::queue<LtmInputParams *> mLtmParamsQ; |
| |
| SisBuffer *mSisBuffer[kMaxLtmParamsNum]; |
| BinParam_t mLtmBinParam; |
| |
| std::unique_ptr<IntelLtm> mIntelLtm; |
| }; |
| |
| } /* namespace icamera */ |
| |