Files
linux-nv-oot/include/media/tegracam_utils.h
Frank Chen 92ac7bc35a media: camera: Build tegra-camera as OOT module
Port camera drivers below from /kenrel/nvidia to
/kernel/nvidia-oot as OOT modules:
- Fusa-capture driver
- Tegra V4L2 framework driver
- vi/csi driver
- tegra camera platform driver

Change-Id: I390af27096425bb11e0934201dd1a90f001bb3fa
Signed-off-by: Frank Chen <frankc@nvidia.com>
Reviewed-on: https://git-master.nvidia.com/r/c/linux-nv-oot/+/2780698
Reviewed-by: FNU Raunak <fraunak@nvidia.com>
Reviewed-by: Ankur Pawar <ankurp@nvidia.com>
Reviewed-by: Shiva Dubey <sdubey@nvidia.com>
GVS: Gerrit_Virtual_Submit <buildbot_gerritrpt@nvidia.com>
2022-12-13 06:15:42 -08:00

40 lines
1.1 KiB
C

/* SPDX-License-Identifier: GPL-2.0-only */
/**
* tegracam_utils.h - tegra camera framework core utilities
*
* Copyright (c) 2018-2022, NVIDIA Corporation. All rights reserved.
*/
#ifndef __TEGRACAM_UTILS_H__
#define __TEGRACAM_UTILS_H__
#include <media/camera_common.h>
enum sensor_opcode {
SENSOR_OPCODE_DONE = 0,
SENSOR_OPCODE_READ = 1,
SENSOR_OPCODE_WRITE = 2,
SENSOR_OPCODE_SLEEP = 3,
};
int convert_table_to_blob(struct sensor_blob *pkt,
const struct reg_8 table[],
u16 wait_ms_addr, u16 end_addr);
int write_sensor_blob(struct regmap *regmap, struct sensor_blob *blob);
int tegracam_write_blobs(struct tegracam_ctrl_handler *hdl);
bool is_tvcf_supported(u32 version);
int format_tvcf_version(u32 version, char *buff, size_t size);
void conv_u32_u8arr(u32 val, u8 *buf);
void conv_u16_u8arr(u16 val, u8 *buf);
int prepare_write_cmd(struct sensor_blob *pkt,
u32 size, u32 addr, u8 *buf);
int prepare_read_cmd(struct sensor_blob *pkt,
u32 size, u32 addr);
int prepare_sleep_cmd(struct sensor_blob *pkt, u32 time_in_us);
int prepare_done_cmd(struct sensor_blob *pkt);
#endif