mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-22 09:55:10 +00:00
83d290c56f
When U-Boot started using SPDX tags we were among the early adopters and there weren't a lot of other examples to borrow from. So we picked the area of the file that usually had a full license text and replaced it with an appropriate SPDX-License-Identifier: entry. Since then, the Linux Kernel has adopted SPDX tags and they place it as the very first line in a file (except where shebangs are used, then it's second line) and with slightly different comment styles than us. In part due to community overlap, in part due to better tag visibility and in part for other minor reasons, switch over to that style. This commit changes all instances where we have a single declared license in the tag as both the before and after are identical in tag contents. There's also a few places where I found we did not have a tag and have introduced one. Signed-off-by: Tom Rini <trini@konsulko.com>
99 lines
2.7 KiB
C
99 lines
2.7 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* Copyright (C) 2011 Freescale Semiconductor, Inc. All Rights Reserved.
|
|
*/
|
|
#ifndef __ASM_ARCH_MXC_MXC_I2C_H__
|
|
#define __ASM_ARCH_MXC_MXC_I2C_H__
|
|
#include <asm-generic/gpio.h>
|
|
#include <asm/mach-imx/iomux-v3.h>
|
|
|
|
struct i2c_pin_ctrl {
|
|
iomux_v3_cfg_t i2c_mode;
|
|
iomux_v3_cfg_t gpio_mode;
|
|
unsigned char gp;
|
|
unsigned char spare;
|
|
};
|
|
|
|
struct i2c_pads_info {
|
|
struct i2c_pin_ctrl scl;
|
|
struct i2c_pin_ctrl sda;
|
|
};
|
|
|
|
/*
|
|
* Information about i2c controller
|
|
* struct mxc_i2c_bus - information about the i2c[x] bus
|
|
* @index: i2c bus index
|
|
* @base: Address of I2C bus controller
|
|
* @driver_data: Flags for different platforms, such as I2C_QUIRK_FLAG.
|
|
* @speed: Speed of I2C bus
|
|
* @pads_info: pinctrl info for this i2c bus, will be used when pinctrl is ok.
|
|
* The following two is only to be compatible with non-DM part.
|
|
* @idle_bus_fn: function to force bus idle
|
|
* @idle_bus_data: parameter for idle_bus_fun
|
|
* For DM:
|
|
* bus: The device structure for i2c bus controller
|
|
* scl-gpio: specify the gpio related to SCL pin
|
|
* sda-gpio: specify the gpio related to SDA pin
|
|
*/
|
|
struct mxc_i2c_bus {
|
|
/*
|
|
* board file can use this index to locate which i2c_pads_info is for
|
|
* i2c_idle_bus. When pinmux is implement, this entry can be
|
|
* discarded. Here we do not use dev->seq, because we do not want to
|
|
* export device to board file.
|
|
*/
|
|
int index;
|
|
ulong base;
|
|
ulong driver_data;
|
|
int speed;
|
|
struct i2c_pads_info *pads_info;
|
|
#ifndef CONFIG_DM_I2C
|
|
int (*idle_bus_fn)(void *p);
|
|
void *idle_bus_data;
|
|
#else
|
|
struct udevice *bus;
|
|
/* Use gpio to force bus idle when bus state is abnormal */
|
|
struct gpio_desc scl_gpio;
|
|
struct gpio_desc sda_gpio;
|
|
#endif
|
|
};
|
|
|
|
#if defined(CONFIG_MX6QDL)
|
|
#define I2C_PADS(name, scl_i2c, scl_gpio, scl_gp, sda_i2c, sda_gpio, sda_gp) \
|
|
struct i2c_pads_info mx6q_##name = { \
|
|
.scl = { \
|
|
.i2c_mode = MX6Q_##scl_i2c, \
|
|
.gpio_mode = MX6Q_##scl_gpio, \
|
|
.gp = scl_gp, \
|
|
}, \
|
|
.sda = { \
|
|
.i2c_mode = MX6Q_##sda_i2c, \
|
|
.gpio_mode = MX6Q_##sda_gpio, \
|
|
.gp = sda_gp, \
|
|
} \
|
|
}; \
|
|
struct i2c_pads_info mx6s_##name = { \
|
|
.scl = { \
|
|
.i2c_mode = MX6DL_##scl_i2c, \
|
|
.gpio_mode = MX6DL_##scl_gpio, \
|
|
.gp = scl_gp, \
|
|
}, \
|
|
.sda = { \
|
|
.i2c_mode = MX6DL_##sda_i2c, \
|
|
.gpio_mode = MX6DL_##sda_gpio, \
|
|
.gp = sda_gp, \
|
|
} \
|
|
};
|
|
|
|
|
|
#define I2C_PADS_INFO(name) \
|
|
(is_mx6dq() || is_mx6dqp()) ? &mx6q_##name : &mx6s_##name
|
|
#endif
|
|
|
|
int setup_i2c(unsigned i2c_index, int speed, int slave_addr,
|
|
struct i2c_pads_info *p);
|
|
void bus_i2c_init(int index, int speed, int slave_addr,
|
|
int (*idle_bus_fn)(void *p), void *p);
|
|
int force_idle_bus(void *priv);
|
|
int i2c_idle_bus(struct mxc_i2c_bus *i2c_bus);
|
|
#endif
|