]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/blame - drivers/media/dvb-frontends/drx39xyj/bsp_i2c.h
Merge remote-tracking branches 'spi/fix/armada', 'spi/fix/atmel', 'spi/fix/doc',...
[mirror_ubuntu-hirsute-kernel.git] / drivers / media / dvb-frontends / drx39xyj / bsp_i2c.h
CommitLineData
ca3355a9 1/*
4a8a8694
MCC
2 I2C API, implementation depends on board specifics
3
ca3355a9
DH
4 Copyright (c), 2004-2005,2007-2010 Trident Microsystems, Inc.
5 All rights reserved.
6
7 Redistribution and use in source and binary forms, with or without
8 modification, are permitted provided that the following conditions are met:
9
10 * Redistributions of source code must retain the above copyright notice,
11 this list of conditions and the following disclaimer.
12 * Redistributions in binary form must reproduce the above copyright notice,
13 this list of conditions and the following disclaimer in the documentation
14 and/or other materials provided with the distribution.
15 * Neither the name of Trident Microsystems nor Hauppauge Computer Works
16 nor the names of its contributors may be used to endorse or promote
17 products derived from this software without specific prior written
18 permission.
19
20 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
24 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 POSSIBILITY OF SUCH DAMAGE.
ca3355a9 31
4a8a8694
MCC
32 This module encapsulates I2C access.In some applications several devices
33 share one I2C bus. If these devices have the same I2C address some kind
34 off "switch" must be implemented to ensure error free communication with
35 one device. In case such a "switch" is used, the device ID can be used
36 to implement control over this "switch".
38b2df95
DH
37*/
38
38b2df95
DH
39#ifndef __BSPI2C_H__
40#define __BSPI2C_H__
38b2df95 41
5b223b39 42#include "bsp_types.h"
38b2df95 43
5b223b39 44/*
57afe2f0
MCC
45 * This structure contains the I2C address, the device ID and a user_data pointer.
46 * The user_data pointer can be used for application specific purposes.
5b223b39
MCC
47 */
48struct i2c_device_addr {
57afe2f0
MCC
49 u16 i2c_addr; /* The I2C address of the device. */
50 u16 i2c_dev_id; /* The device identifier. */
51 void *user_data; /* User data pointer */
5b223b39 52};
38b2df95 53
38b2df95 54
b95b0c98 55/*
38b2df95
DH
56* \def IS_I2C_10BIT( addr )
57* \brief Determine if I2C address 'addr' is a 10 bits address or not.
58* \param addr The I2C address.
59* \return int.
60* \retval 0 if address is not a 10 bits I2C address.
61* \retval 1 if address is a 10 bits I2C address.
62*/
63#define IS_I2C_10BIT(addr) \
64 (((addr) & 0xF8) == 0xF0)
65
38b2df95
DH
66/*------------------------------------------------------------------------------
67Exported FUNCTIONS
68------------------------------------------------------------------------------*/
69
b95b0c98 70/*
57afe2f0 71* \fn drxbsp_i2c_init()
38b2df95 72* \brief Initialize I2C communication module.
57afe2f0 73* \return drx_status_t Return status.
9482354f
MCC
74* \retval 0 Initialization successful.
75* \retval -EIO Initialization failed.
38b2df95 76*/
57afe2f0 77 drx_status_t drxbsp_i2c_init(void);
38b2df95 78
b95b0c98 79/*
57afe2f0 80* \fn drxbsp_i2c_term()
38b2df95 81* \brief Terminate I2C communication module.
57afe2f0 82* \return drx_status_t Return status.
9482354f
MCC
83* \retval 0 Termination successful.
84* \retval -EIO Termination failed.
38b2df95 85*/
57afe2f0 86 drx_status_t drxbsp_i2c_term(void);
38b2df95 87
b95b0c98 88/*
57afe2f0
MCC
89* \fn drx_status_t drxbsp_i2c_write_read( struct i2c_device_addr *w_dev_addr,
90* u16 w_count,
43a431e4 91* u8 *wData,
57afe2f0
MCC
92* struct i2c_device_addr *r_dev_addr,
93* u16 r_count,
94* u8 *r_data)
38b2df95 95* \brief Read and/or write count bytes from I2C bus, store them in data[].
57afe2f0
MCC
96* \param w_dev_addr The device i2c address and the device ID to write to
97* \param w_count The number of bytes to write
38b2df95 98* \param wData The array to write the data to
57afe2f0
MCC
99* \param r_dev_addr The device i2c address and the device ID to read from
100* \param r_count The number of bytes to read
101* \param r_data The array to read the data from
102* \return drx_status_t Return status.
9482354f
MCC
103* \retval 0 Succes.
104* \retval -EIO Failure.
105* \retval -EINVAL Parameter 'wcount' is not zero but parameter
38b2df95
DH
106* 'wdata' contains NULL.
107* Idem for 'rcount' and 'rdata'.
57afe2f0 108* Both w_dev_addr and r_dev_addr are NULL.
38b2df95
DH
109*
110* This function must implement an atomic write and/or read action on the I2C bus
111* No other process may use the I2C bus when this function is executing.
112* The critical section of this function runs from and including the I2C
113* write, up to and including the I2C read action.
114*
115* The device ID can be useful if several devices share an I2C address.
116* It can be used to control a "switch" on the I2C bus to the correct device.
117*/
57afe2f0
MCC
118 drx_status_t drxbsp_i2c_write_read(struct i2c_device_addr *w_dev_addr,
119 u16 w_count,
4a8a8694 120 u8 *w_data,
57afe2f0
MCC
121 struct i2c_device_addr *r_dev_addr,
122 u16 r_count, u8 *r_data);
38b2df95 123
b95b0c98 124/*
57afe2f0 125* \fn drxbsp_i2c_error_text()
38b2df95 126* \brief Returns a human readable error.
57afe2f0 127* Counter part of numerical drx_i2c_error_g.
38b2df95
DH
128*
129* \return char* Pointer to human readable error text.
130*/
57afe2f0 131 char *drxbsp_i2c_error_text(void);
38b2df95 132
b95b0c98 133/*
57afe2f0 134* \var drx_i2c_error_g;
38b2df95
DH
135* \brief I2C specific error codes, platform dependent.
136*/
57afe2f0 137 extern int drx_i2c_error_g;
38b2df95 138
443f18d0 139#endif /* __BSPI2C_H__ */