With the internal headers now in include/libcamera/internal/, we may have identically named headers in include/libcamera/. Their header guards would clash. Rename the header guards of internal headers to prevent any issue. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
62 lines
1.2 KiB
C++
62 lines
1.2 KiB
C++
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
|
/*
|
|
* Copyright (C) 2019, Google Inc.
|
|
*
|
|
* ipa_module.h - Image Processing Algorithm module
|
|
*/
|
|
#ifndef __LIBCAMERA_INTERNAL_IPA_MODULE_H__
|
|
#define __LIBCAMERA_INTERNAL_IPA_MODULE_H__
|
|
|
|
#include <stdint.h>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include <libcamera/ipa/ipa_interface.h>
|
|
#include <libcamera/ipa/ipa_module_info.h>
|
|
|
|
#include "libcamera/internal/log.h"
|
|
#include "libcamera/internal/pipeline_handler.h"
|
|
|
|
namespace libcamera {
|
|
|
|
class IPAModule : public Loggable
|
|
{
|
|
public:
|
|
explicit IPAModule(const std::string &libPath);
|
|
~IPAModule();
|
|
|
|
bool isValid() const;
|
|
|
|
const struct IPAModuleInfo &info() const;
|
|
const std::vector<uint8_t> signature() const;
|
|
const std::string &path() const;
|
|
|
|
bool load();
|
|
|
|
struct ipa_context *createContext();
|
|
|
|
bool match(PipelineHandler *pipe,
|
|
uint32_t minVersion, uint32_t maxVersion) const;
|
|
|
|
protected:
|
|
std::string logPrefix() const override;
|
|
|
|
private:
|
|
int loadIPAModuleInfo();
|
|
|
|
struct IPAModuleInfo info_;
|
|
std::vector<uint8_t> signature_;
|
|
|
|
std::string libPath_;
|
|
bool valid_;
|
|
bool loaded_;
|
|
|
|
void *dlHandle_;
|
|
typedef struct ipa_context *(*IPAIntfFactory)(void);
|
|
IPAIntfFactory ipaCreate_;
|
|
};
|
|
|
|
} /* namespace libcamera */
|
|
|
|
#endif /* __LIBCAMERA_INTERNAL_IPA_MODULE_H__ */
|