PageRenderTime 43ms CodeModel.GetById 23ms app.highlight 13ms RepoModel.GetById 4ms app.codeStats 0ms

/arch/powerpc/include/asm/pmac_low_i2c.h

https://bitbucket.org/abioy/linux
C Header | 103 lines | 47 code | 17 blank | 39 comment | 0 complexity | 5a14aee715cb39d60279e2c7afeb3bbc MD5 | raw file
Possible License(s): CC-BY-SA-3.0, GPL-2.0, LGPL-2.0, AGPL-1.0
  1/* 
  2 *  include/asm-ppc/pmac_low_i2c.h
  3 *
  4 *  Copyright (C) 2003 Ben. Herrenschmidt (benh@kernel.crashing.org)
  5 *
  6 *  This program is free software; you can redistribute it and/or
  7 *  modify it under the terms of the GNU General Public License
  8 *  as published by the Free Software Foundation; either version
  9 *  2 of the License, or (at your option) any later version.
 10 *
 11 */
 12#ifndef __PMAC_LOW_I2C_H__
 13#define __PMAC_LOW_I2C_H__
 14#ifdef __KERNEL__
 15
 16/* i2c mode (based on the platform functions format) */
 17enum {
 18	pmac_i2c_mode_dumb	= 1,
 19	pmac_i2c_mode_std	= 2,
 20	pmac_i2c_mode_stdsub	= 3,
 21	pmac_i2c_mode_combined	= 4,
 22};
 23
 24/* RW bit in address */
 25enum {
 26	pmac_i2c_read		= 0x01,
 27	pmac_i2c_write		= 0x00
 28};
 29
 30/* i2c bus type */
 31enum {
 32	pmac_i2c_bus_keywest	= 0,
 33	pmac_i2c_bus_pmu	= 1,
 34	pmac_i2c_bus_smu	= 2,
 35};
 36
 37/* i2c bus features */
 38enum {
 39	/* can_largesub : supports >1 byte subaddresses (SMU only) */
 40	pmac_i2c_can_largesub	= 0x00000001u,
 41
 42	/* multibus : device node holds multiple busses, bus number is
 43	 * encoded in bits 0xff00 of "reg" of a given device
 44	 */
 45	pmac_i2c_multibus	= 0x00000002u,
 46};
 47
 48/* i2c busses in the system */
 49struct pmac_i2c_bus;
 50struct i2c_adapter;
 51
 52/* Init, called early during boot */
 53extern int pmac_i2c_init(void);
 54
 55/* Lookup an i2c bus for a device-node. The node can be either the bus
 56 * node itself or a device below it. In the case of a multibus, the bus
 57 * node itself is the controller node, else, it's a child of the controller
 58 * node
 59 */
 60extern struct pmac_i2c_bus *pmac_i2c_find_bus(struct device_node *node);
 61
 62/* Get the address for an i2c device. This strips the bus number if
 63 * necessary. The 7 bits address is returned 1 bit right shifted so that the
 64 * direction can be directly ored in
 65 */
 66extern u8 pmac_i2c_get_dev_addr(struct device_node *device);
 67
 68/* Get infos about a bus */
 69extern struct device_node *pmac_i2c_get_controller(struct pmac_i2c_bus *bus);
 70extern struct device_node *pmac_i2c_get_bus_node(struct pmac_i2c_bus *bus);
 71extern int pmac_i2c_get_type(struct pmac_i2c_bus *bus);
 72extern int pmac_i2c_get_flags(struct pmac_i2c_bus *bus);
 73extern int pmac_i2c_get_channel(struct pmac_i2c_bus *bus);
 74
 75/* i2c layer adapter helpers */
 76extern struct i2c_adapter *pmac_i2c_get_adapter(struct pmac_i2c_bus *bus);
 77extern struct pmac_i2c_bus *pmac_i2c_adapter_to_bus(struct i2c_adapter *adapter);
 78
 79/* March a device or bus with an i2c adapter structure, to be used by drivers
 80 * to match device-tree nodes with i2c adapters during adapter discovery
 81 * callbacks
 82 */
 83extern int pmac_i2c_match_adapter(struct device_node *dev,
 84				  struct i2c_adapter *adapter);
 85
 86
 87/* (legacy) Locking functions exposed to i2c-keywest */
 88extern int pmac_low_i2c_lock(struct device_node *np);
 89extern int pmac_low_i2c_unlock(struct device_node *np);
 90
 91/* Access functions for platform code */
 92extern int pmac_i2c_open(struct pmac_i2c_bus *bus, int polled);
 93extern void pmac_i2c_close(struct pmac_i2c_bus *bus);
 94extern int pmac_i2c_setmode(struct pmac_i2c_bus *bus, int mode);
 95extern int pmac_i2c_xfer(struct pmac_i2c_bus *bus, u8 addrdir, int subsize,
 96			 u32 subaddr, u8 *data,  int len);
 97
 98/* Suspend/resume code called by via-pmu directly for now */
 99extern void pmac_pfunc_i2c_suspend(void);
100extern void pmac_pfunc_i2c_resume(void);
101
102#endif /* __KERNEL__ */
103#endif /* __PMAC_LOW_I2C_H__ */