]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - drivers/media/i2c/smiapp/smiapp-regs.h
Merge tag 'devicetree-for-linus' of git://git.secretlab.ca/git/linux
[mirror_ubuntu-artful-kernel.git] / drivers / media / i2c / smiapp / smiapp-regs.h
CommitLineData
ccfc97bd
SA
1/*
2 * include/media/smiapp/smiapp-regs.h
3 *
4 * Generic driver for SMIA/SMIA++ compliant camera modules
5 *
6 * Copyright (C) 2011--2012 Nokia Corporation
8c5dff90 7 * Contact: Sakari Ailus <sakari.ailus@iki.fi>
ccfc97bd
SA
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * version 2 as published by the Free Software Foundation.
12 *
13 * This program is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
21 * 02110-1301 USA
22 *
23 */
24
25#ifndef SMIAPP_REGS_H
26#define SMIAPP_REGS_H
27
28#include <linux/i2c.h>
29#include <linux/types.h>
30
f5d65070
SA
31#define SMIAPP_REG_ADDR(reg) ((u16)reg)
32#define SMIAPP_REG_WIDTH(reg) ((u8)(reg >> 16))
33#define SMIAPP_REG_FLAGS(reg) ((u8)(reg >> 24))
34
ccfc97bd 35/* Use upper 8 bits of the type field for flags */
6fcc7a52 36#define SMIAPP_REG_FLAG_FLOAT (1 << 24)
ccfc97bd 37
6fcc7a52
SA
38#define SMIAPP_REG_8BIT 1
39#define SMIAPP_REG_16BIT 2
40#define SMIAPP_REG_32BIT 4
ccfc97bd 41
1e73eea7
SA
42struct smiapp_sensor;
43
6f7481b6 44int smiapp_read_no_quirk(struct smiapp_sensor *sensor, u32 reg, u32 *val);
1e73eea7 45int smiapp_read(struct smiapp_sensor *sensor, u32 reg, u32 *val);
ceb9e30e 46int smiapp_read_8only(struct smiapp_sensor *sensor, u32 reg, u32 *val);
6f7481b6 47int smiapp_write_no_quirk(struct smiapp_sensor *sensor, u32 reg, u32 val);
1e73eea7 48int smiapp_write(struct smiapp_sensor *sensor, u32 reg, u32 val);
ccfc97bd
SA
49
50#endif