162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci *  include/asm-ppc/pmac_low_i2c.h
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci *  Copyright (C) 2003 Ben. Herrenschmidt (benh@kernel.crashing.org)
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci#ifndef __PMAC_LOW_I2C_H__
862306a36Sopenharmony_ci#define __PMAC_LOW_I2C_H__
962306a36Sopenharmony_ci#ifdef __KERNEL__
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci/* i2c mode (based on the platform functions format) */
1262306a36Sopenharmony_cienum {
1362306a36Sopenharmony_ci	pmac_i2c_mode_dumb	= 1,
1462306a36Sopenharmony_ci	pmac_i2c_mode_std	= 2,
1562306a36Sopenharmony_ci	pmac_i2c_mode_stdsub	= 3,
1662306a36Sopenharmony_ci	pmac_i2c_mode_combined	= 4,
1762306a36Sopenharmony_ci};
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci/* RW bit in address */
2062306a36Sopenharmony_cienum {
2162306a36Sopenharmony_ci	pmac_i2c_read		= 0x01,
2262306a36Sopenharmony_ci	pmac_i2c_write		= 0x00
2362306a36Sopenharmony_ci};
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci/* i2c bus type */
2662306a36Sopenharmony_cienum {
2762306a36Sopenharmony_ci	pmac_i2c_bus_keywest	= 0,
2862306a36Sopenharmony_ci	pmac_i2c_bus_pmu	= 1,
2962306a36Sopenharmony_ci	pmac_i2c_bus_smu	= 2,
3062306a36Sopenharmony_ci};
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci/* i2c bus features */
3362306a36Sopenharmony_cienum {
3462306a36Sopenharmony_ci	/* can_largesub : supports >1 byte subaddresses (SMU only) */
3562306a36Sopenharmony_ci	pmac_i2c_can_largesub	= 0x00000001u,
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci	/* multibus : device node holds multiple busses, bus number is
3862306a36Sopenharmony_ci	 * encoded in bits 0xff00 of "reg" of a given device
3962306a36Sopenharmony_ci	 */
4062306a36Sopenharmony_ci	pmac_i2c_multibus	= 0x00000002u,
4162306a36Sopenharmony_ci};
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci/* i2c busses in the system */
4462306a36Sopenharmony_cistruct pmac_i2c_bus;
4562306a36Sopenharmony_cistruct i2c_adapter;
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_ci/* Init, called early during boot */
4862306a36Sopenharmony_ciextern int pmac_i2c_init(void);
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci/* Lookup an i2c bus for a device-node. The node can be either the bus
5162306a36Sopenharmony_ci * node itself or a device below it. In the case of a multibus, the bus
5262306a36Sopenharmony_ci * node itself is the controller node, else, it's a child of the controller
5362306a36Sopenharmony_ci * node
5462306a36Sopenharmony_ci */
5562306a36Sopenharmony_ciextern struct pmac_i2c_bus *pmac_i2c_find_bus(struct device_node *node);
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci/* Get the address for an i2c device. This strips the bus number if
5862306a36Sopenharmony_ci * necessary. The 7 bits address is returned 1 bit right shifted so that the
5962306a36Sopenharmony_ci * direction can be directly ored in
6062306a36Sopenharmony_ci */
6162306a36Sopenharmony_ciextern u8 pmac_i2c_get_dev_addr(struct device_node *device);
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ci/* Get infos about a bus */
6462306a36Sopenharmony_ciextern struct device_node *pmac_i2c_get_controller(struct pmac_i2c_bus *bus);
6562306a36Sopenharmony_ciextern struct device_node *pmac_i2c_get_bus_node(struct pmac_i2c_bus *bus);
6662306a36Sopenharmony_ciextern int pmac_i2c_get_type(struct pmac_i2c_bus *bus);
6762306a36Sopenharmony_ciextern int pmac_i2c_get_flags(struct pmac_i2c_bus *bus);
6862306a36Sopenharmony_ciextern int pmac_i2c_get_channel(struct pmac_i2c_bus *bus);
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_ci/* i2c layer adapter helpers */
7162306a36Sopenharmony_ciextern struct i2c_adapter *pmac_i2c_get_adapter(struct pmac_i2c_bus *bus);
7262306a36Sopenharmony_ciextern struct pmac_i2c_bus *pmac_i2c_adapter_to_bus(struct i2c_adapter *adapter);
7362306a36Sopenharmony_ci
7462306a36Sopenharmony_ci/* March a device or bus with an i2c adapter structure, to be used by drivers
7562306a36Sopenharmony_ci * to match device-tree nodes with i2c adapters during adapter discovery
7662306a36Sopenharmony_ci * callbacks
7762306a36Sopenharmony_ci */
7862306a36Sopenharmony_ciextern int pmac_i2c_match_adapter(struct device_node *dev,
7962306a36Sopenharmony_ci				  struct i2c_adapter *adapter);
8062306a36Sopenharmony_ci
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_ci/* (legacy) Locking functions exposed to i2c-keywest */
8362306a36Sopenharmony_ciextern int pmac_low_i2c_lock(struct device_node *np);
8462306a36Sopenharmony_ciextern int pmac_low_i2c_unlock(struct device_node *np);
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_ci/* Access functions for platform code */
8762306a36Sopenharmony_ciextern int pmac_i2c_open(struct pmac_i2c_bus *bus, int polled);
8862306a36Sopenharmony_ciextern void pmac_i2c_close(struct pmac_i2c_bus *bus);
8962306a36Sopenharmony_ciextern int pmac_i2c_setmode(struct pmac_i2c_bus *bus, int mode);
9062306a36Sopenharmony_ciextern int pmac_i2c_xfer(struct pmac_i2c_bus *bus, u8 addrdir, int subsize,
9162306a36Sopenharmony_ci			 u32 subaddr, u8 *data,  int len);
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ci/* Suspend/resume code called by via-pmu directly for now */
9462306a36Sopenharmony_ciextern void pmac_pfunc_i2c_suspend(void);
9562306a36Sopenharmony_ciextern void pmac_pfunc_i2c_resume(void);
9662306a36Sopenharmony_ci
9762306a36Sopenharmony_ci#endif /* __KERNEL__ */
9862306a36Sopenharmony_ci#endif /* __PMAC_LOW_I2C_H__ */
99