/* * Copyright (c) 2013-2020, NVIDIA CORPORATION. All rights reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef __OV5693_H__ #define __OV5693_H__ #include #include #include #define OV5693_INVALID_COARSE_TIME -1 #define OV5693_EEPROM_ADDRESS 0x54 #define OV5693_EEPROM_SIZE 1024 #define OV5693_EEPROM_STR_SIZE (OV5693_EEPROM_SIZE * 2) #define OV5693_EEPROM_BLOCK_SIZE (1 << 8) #define OV5693_EEPROM_NUM_BLOCKS \ (OV5693_EEPROM_SIZE / OV5693_EEPROM_BLOCK_SIZE) #define OV5693_OTP_LOAD_CTRL_ADDR 0x3D81 #define OV5693_OTP_BANK_SELECT_ADDR 0x3D84 #define OV5693_OTP_BANK_START_ADDR 0x3D00 #define OV5693_OTP_BANK_END_ADDR 0x3D0F #define OV5693_OTP_NUM_BANKS (32) #define OV5693_OTP_BANK_SIZE \ (OV5693_OTP_BANK_END_ADDR - OV5693_OTP_BANK_START_ADDR + 1) #define OV5693_OTP_SIZE \ (OV5693_OTP_BANK_SIZE * OV5693_OTP_NUM_BANKS) #define OV5693_OTP_STR_SIZE (OV5693_OTP_SIZE * 2) /* See notes in the nvc.h file on the GPIO usage */ enum ov5693_gpio_type { OV5693_GPIO_TYPE_PWRDN = 0, OV5693_GPIO_TYPE_RESET, }; struct ov5693_eeprom_data { struct i2c_client *i2c_client; struct i2c_adapter *adap; struct i2c_board_info brd; struct regmap *regmap; }; struct ov5693_power_rail { struct regulator *dvdd; struct regulator *avdd; struct regulator *dovdd; }; struct ov5693_regulators { const char *avdd; const char *dvdd; const char *dovdd; }; struct ov5693_platform_data { unsigned cfg; unsigned num; const char *dev_name; unsigned gpio_count; /* see nvc.h GPIO notes */ struct nvc_gpio_pdata *gpio; /* see nvc.h GPIO notes */ struct nvc_imager_static_nvc *static_info; bool use_vcm_vdd; int (*probe_clock)(unsigned long); int (*power_on)(struct ov5693_power_rail *); int (*power_off)(struct ov5693_power_rail *); const char *mclk_name; struct nvc_imager_cap *cap; struct ov5693_regulators regulators; bool has_eeprom; bool use_cam_gpio; }; #endif /* __OV5693_H__ */