2019-05-27 08:55:21 +02:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2012-03-03 17:19:52 -03:00
|
|
|
/*
|
2020-02-11 19:05:57 +01:00
|
|
|
* include/media/ccs/ccs-reg-access.h
|
2012-03-03 17:19:52 -03:00
|
|
|
*
|
2020-02-11 19:05:57 +01:00
|
|
|
* Generic driver for MIPI CCS/SMIA/SMIA++ compliant camera sensors
|
2012-03-03 17:19:52 -03:00
|
|
|
*
|
2020-02-11 19:05:57 +01:00
|
|
|
* Copyright (C) 2020 Intel Corporation
|
2012-03-03 17:19:52 -03:00
|
|
|
* Copyright (C) 2011--2012 Nokia Corporation
|
2020-06-24 23:57:46 +02:00
|
|
|
* Contact: Sakari Ailus <sakari.ailus@linux.intel.com>
|
2012-03-03 17:19:52 -03:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SMIAPP_REGS_H
|
|
|
|
#define SMIAPP_REGS_H
|
|
|
|
|
|
|
|
#include <linux/i2c.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
|
2020-02-03 12:38:42 +01:00
|
|
|
#include "ccs-regs.h"
|
2012-03-03 17:19:52 -03:00
|
|
|
|
2020-02-11 14:19:13 +01:00
|
|
|
#define CCS_REG_ADDR(reg) ((u16)reg)
|
2012-03-03 17:19:52 -03:00
|
|
|
|
2020-02-11 14:19:13 +01:00
|
|
|
struct ccs_sensor;
|
2012-04-22 08:55:10 -03:00
|
|
|
|
2020-02-11 14:19:13 +01:00
|
|
|
int ccs_read_addr_no_quirk(struct ccs_sensor *sensor, u32 reg, u32 *val);
|
|
|
|
int ccs_read_addr(struct ccs_sensor *sensor, u32 reg, u32 *val);
|
|
|
|
int ccs_read_addr_8only(struct ccs_sensor *sensor, u32 reg, u32 *val);
|
2020-09-02 12:23:40 +02:00
|
|
|
int ccs_read_addr_noconv(struct ccs_sensor *sensor, u32 reg, u32 *val);
|
2020-02-11 14:19:13 +01:00
|
|
|
int ccs_write_addr_no_quirk(struct ccs_sensor *sensor, u32 reg, u32 val);
|
|
|
|
int ccs_write_addr(struct ccs_sensor *sensor, u32 reg, u32 val);
|
2020-09-03 11:32:56 +02:00
|
|
|
int ccs_write_data_regs(struct ccs_sensor *sensor, struct ccs_reg *regs,
|
|
|
|
size_t num_regs);
|
2012-03-03 17:19:52 -03:00
|
|
|
|
2020-02-03 12:38:42 +01:00
|
|
|
unsigned int ccs_reg_width(u32 reg);
|
2020-09-02 12:23:40 +02:00
|
|
|
u32 ccs_reg_conv(struct ccs_sensor *sensor, u32 reg, u32 val);
|
2020-02-03 12:38:42 +01:00
|
|
|
|
2020-02-03 14:48:48 +01:00
|
|
|
#define ccs_read(sensor, reg_name, val) \
|
2020-02-11 12:16:14 +01:00
|
|
|
ccs_read_addr(sensor, CCS_R_##reg_name, val)
|
2020-02-03 14:48:48 +01:00
|
|
|
|
|
|
|
#define ccs_write(sensor, reg_name, val) \
|
2020-02-11 12:16:14 +01:00
|
|
|
ccs_write_addr(sensor, CCS_R_##reg_name, val)
|
2020-02-03 14:48:48 +01:00
|
|
|
|
2012-03-03 17:19:52 -03:00
|
|
|
#endif
|