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