blob: aa10fc73cd7ef9961057652c9b6f788c4ee48e5f [file] [log] [blame]
Rajeshwari Shinde8df74312012-07-23 21:23:52 +00001/*
2 * Copyright (C) 2012 Samsung Electronics
3 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02004 * SPDX-License-Identifier: GPL-2.0+
Rajeshwari Shinde8df74312012-07-23 21:23:52 +00005 */
6
7#ifndef _S3C24X0_I2C_H
8#define _S3C24X0_I2C_H
9
10struct s3c24x0_i2c {
11 u32 iiccon;
12 u32 iicstat;
13 u32 iicadd;
14 u32 iicds;
15 u32 iiclc;
16};
Rajeshwari Shinde53cfac52012-12-26 20:03:12 +000017
Naveen Krishna Ch64a191f2013-10-15 16:02:44 +053018struct exynos5_hsi2c {
19 u32 usi_ctl;
20 u32 usi_fifo_ctl;
21 u32 usi_trailing_ctl;
22 u32 usi_clk_ctl;
23 u32 usi_clk_slot;
24 u32 spi_ctl;
25 u32 uart_ctl;
26 u32 res1;
27 u32 usi_int_en;
28 u32 usi_int_stat;
29 u32 usi_modem_stat;
30 u32 usi_error_stat;
31 u32 usi_fifo_stat;
32 u32 usi_txdata;
33 u32 usi_rxdata;
34 u32 res2;
35 u32 usi_conf;
36 u32 usi_auto_conf;
37 u32 usi_timeout;
38 u32 usi_manual_cmd;
39 u32 usi_trans_status;
40 u32 usi_timing_hs1;
41 u32 usi_timing_hs2;
42 u32 usi_timing_hs3;
43 u32 usi_timing_fs1;
44 u32 usi_timing_fs2;
45 u32 usi_timing_fs3;
46 u32 usi_timing_sla;
47 u32 i2c_addr;
48};
49
Rajeshwari Shinde53cfac52012-12-26 20:03:12 +000050struct s3c24x0_i2c_bus {
Simon Glass2ccb6f42013-10-15 16:02:10 +053051 bool active; /* port is active and available */
Rajeshwari Shinde53cfac52012-12-26 20:03:12 +000052 int node; /* device tree node */
53 int bus_num; /* i2c bus number */
54 struct s3c24x0_i2c *regs;
Naveen Krishna Ch64a191f2013-10-15 16:02:44 +053055 struct exynos5_hsi2c *hsregs;
56 int is_highspeed; /* High speed type, rather than I2C */
57 unsigned clock_frequency;
Rajeshwari Shinde9a611f62013-01-13 19:49:36 +000058 int id;
Naveen Krishna Ch64a191f2013-10-15 16:02:44 +053059 unsigned clk_cycle;
60 unsigned clk_div;
Rajeshwari Shinde53cfac52012-12-26 20:03:12 +000061};
Simon Glassb9d7f992016-11-23 06:34:43 -070062
63#define I2C_WRITE 0
64#define I2C_READ 1
65
66#define I2C_OK 0
67#define I2C_NOK 1
68#define I2C_NACK 2
69#define I2C_NOK_LA 3 /* Lost arbitration */
70#define I2C_NOK_TOUT 4 /* time out */
71
72/* S3C I2C Controller bits */
73#define I2CSTAT_BSY 0x20 /* Busy bit */
74#define I2CSTAT_NACK 0x01 /* Nack bit */
75#define I2CCON_ACKGEN 0x80 /* Acknowledge generation */
76#define I2CCON_IRPND 0x10 /* Interrupt pending bit */
77#define I2C_MODE_MT 0xC0 /* Master Transmit Mode */
78#define I2C_MODE_MR 0x80 /* Master Receive Mode */
79#define I2C_START_STOP 0x20 /* START / STOP */
80#define I2C_TXRX_ENA 0x10 /* I2C Tx/Rx enable */
81
82#define I2C_TIMEOUT_MS 10 /* 10 ms */
83
Rajeshwari Shinde8df74312012-07-23 21:23:52 +000084#endif /* _S3C24X0_I2C_H */