2 * Copyright (c) 2004-2007 Marcus Overhagen <marcus@overhagen.de>
4 * Permission is hereby granted, free of charge, to any person
5 * obtaining a copy of this software and associated documentation
6 * files (the "Software"), to deal in the Software without restriction,
7 * including without limitation the rights to use, copy, modify,
8 * merge, publish, distribute, sublicense, and/or sell copies of
9 * the Software, and to permit persons to whom the Software is
10 * furnished to do so, subject to the following conditions:
12 * The above copyright notice and this permission notice shall be
13 * included in all copies or substantial portions of the Software.
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
17 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
19 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
20 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22 * OTHER DEALINGS IN THE SOFTWARE.
25 #include "cx23882_i2c.h"
30 set_scl(void *cookie
, int state
)
32 cx23882_device
* device
= cookie
;
34 device
->i2c_reg
|= I2C_SCL
;
36 device
->i2c_reg
&= ~I2C_SCL
;
37 reg_write32(REG_I2C_CONTROL
, device
->i2c_reg
);
38 reg_read32(REG_I2C_CONTROL
); // PCI bridge flush
43 set_sda(void *cookie
, int state
)
45 cx23882_device
* device
= cookie
;
47 device
->i2c_reg
|= I2C_SDA
;
49 device
->i2c_reg
&= ~I2C_SDA
;
50 reg_write32(REG_I2C_CONTROL
, device
->i2c_reg
);
51 reg_read32(REG_I2C_CONTROL
); // PCI bridge flush
58 cx23882_device
* device
= cookie
;
59 return (reg_read32(REG_I2C_CONTROL
) & I2C_SCL
) >> 1; // I2C_SCL is 0x02
66 cx23882_device
* device
= cookie
;
67 return reg_read32(REG_I2C_CONTROL
) & I2C_SDA
; // I2C_SDA is 0x01
72 i2c_init(cx23882_device
*device
)
74 device
->i2c_bus
= i2c_create_bus(device
, 80000, 2000000, set_scl
, set_sda
, get_scl
, get_sda
);
75 device
->i2c_reg
= reg_read32(REG_I2C_CONTROL
);
76 device
->i2c_reg
&= ~I2C_HW_MODE
;
77 device
->i2c_reg
|= I2C_SCL
| I2C_SDA
;
78 reg_write32(REG_I2C_CONTROL
, device
->i2c_reg
);
79 reg_read32(REG_I2C_CONTROL
); // PCI bridge flush
80 return device
->i2c_bus
? B_OK
: B_ERROR
;
85 i2c_terminate(cx23882_device
*device
)
87 i2c_delete_bus(device
->i2c_bus
);