summaryrefslogtreecommitdiff
path: root/firmware/export/i2c-h100.h
blob: f8fd423b7e56f3aec5d079321a51f2f18e693341 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/***************************************************************************
 *             __________               __   ___.
 *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
 *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
 *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
 *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
 *                     \/            \/     \/    \/            \/
 * $Id$
 *
 * Copyright (C) 2002 by Linus Nielsen Feltzing
 *
 * All files in this archive are subject to the GNU General Public License.
 * See the file COPYING in the source tree root for full license agreement.
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
 * KIND, either express or implied.
 *
 ****************************************************************************/

/*
 *  Driver for MCF5249's I2C interface
 *  2005-02-17 hubble@mochine.com
 *
 */
 
#ifndef _I2C_H100_H
#define _I2C_H100_H

void i2c_init(void);
int i2c_write(int device, unsigned char *buf, int count);
void i2c_close(void);


#define MAX_LOOP    0x10000     /* TODO: select a better value */

/* PLLCR control */
#define QSPISEL (1 << 11)		/* Selects QSPI or I2C interface */

/* Offsets to I2C registers from base address */
#define O_MADR	0x00            /* Slave Address        */
#define O_MFDR	0x04            /* Frequency divider    */
#define O_MBCR	0x08            /* Control register     */
#define O_MBSR	0x0c            /* Status register      */
#define O_MBDR	0x10            /* Data register        */

/* MBSR - Status register */
#define ICF     (1 << 7)        /* Transfer Complete	*/
#define IAAS    (1 << 6)        /* Addressed As Alave	*/
#define IBB     (1 << 5)        /* Bus Busy		        */
#define IAL     (1 << 4)        /* Arbitration Lost	    */
#define SRW     (1 << 2)        /* Slave R/W		    */
#define IFF     (1 << 1)        /* I2C Interrupt	    */
#define RXAK    (1 << 0)        /* No Ack bit		    */

/* MBCR - Control register */
#define IEN     (1 << 7)		/* I2C Enable		    */
#define IIEN    (1 << 6)		/* Interrupt Enable	    */
#define MSTA    (1 << 5)		/* Master/Slave select	*/
#define MTX     (1 << 4)		/* Transmit/Receive	    */
#define TXAK    (1 << 3)		/* Transfer ACK		    */
#define RSTA    (1 << 2)		/* Restart..		    */


#endif