summaryrefslogtreecommitdiff
path: root/include/cmd_i2c.h
blob: 7334fd4f7aeecffea504227cc9c971635a66d533 (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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/*
 * (C) Copyright 2001
 * Gerald Van Baren, Custom IDEAS, vanbaren@cideas.com.
 *
 * See file CREDITS for list of people who contributed to this
 * project.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation; either version 2 of
 * the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 * MA 02111-1307 USA
 */

/*
 * I2C Functions
 */
#ifndef	_CMD_I2C_H
#define _CMD_I2C_H

#if (CONFIG_COMMANDS & CFG_CMD_I2C)
#define CMD_TBL_IMD	MK_CMD_TBL_ENTRY(				\
	"imd",		3,	4,	1,	do_i2c_md,		\
	"imd     - i2c memory display\n",				\
	"chip address[.0, .1, .2] [# of objects]\n    - i2c memory display\n" \
),
#define CMD_TBL_IMM	MK_CMD_TBL_ENTRY(				\
 	"imm",		3,	3,	1,	do_i2c_mm,		\
	"imm     - i2c memory modify (auto-incrementing)\n",		\
	"chip address[.0, .1, .2]\n"					\
	"    - memory modify, auto increment address\n"			\
),
#define CMD_TBL_INM	MK_CMD_TBL_ENTRY(				\
	"inm",		3,	3,	1,	do_i2c_nm,		\
	"inm     - memory modify (constant address)\n",			\
	"chip address[.0, .1, .2]\n    - memory modify, read and keep address\n" \
),
#define CMD_TBL_IMW	MK_CMD_TBL_ENTRY(				\
	"imw",		3,	5,	1,	do_i2c_mw,		\
	"imw     - memory write (fill)\n",				\
	"chip address[.0, .1, .2] value [count]\n    - memory write (fill)\n" \
),
#define	CMD_TBL_ICRC	MK_CMD_TBL_ENTRY(				\
	"icrc32",	4,	5,	1,	do_i2c_crc,		\
	"icrc32  - checksum calculation\n",				\
	"chip address[.0, .1, .2] count\n    - compute CRC32 checksum\n" \
),
#define CMD_TBL_IPROBE	MK_CMD_TBL_ENTRY(				\
	"iprobe",	3,	1,	1,	do_i2c_probe,		\
	"iprobe  - probe to discover valid I2C chip addresses\n",	\
	"\n    -discover valid I2C chip addresses\n"			\
),
/*
 * Require full name for "iloop" because it is an infinite loop!
 */
#define CMD_TBL_ILOOP	MK_CMD_TBL_ENTRY(				\
	"iloop",	5,	5,	1,	do_i2c_loop,		\
	"iloop   - infinite loop on address range\n",			\
	"chip address[.0, .1, .2] [# of objects]\n"			\
	"    - loop, reading a set of addresses\n"			\
),
#if (CONFIG_COMMANDS & CFG_CMD_SDRAM)
#define CMD_TBL_ISDRAM	MK_CMD_TBL_ENTRY(				\
	"isdram",	6,	2,	1,	do_sdram,		\
	"isdram  - print SDRAM configuration information\n",		\
	"chip\n    - print SDRAM configuration information\n"		\
	"      (valid chip values 50..57)\n"				\
),
#else
#define CMD_TBL_ISDRAM
#endif


int do_i2c_md(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
int do_i2c_mm(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
int do_i2c_nm(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
int do_i2c_mw(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
int do_i2c_crc(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
int do_i2c_probe(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
int do_i2c_loop(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
int do_sdram(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);

#else
#define CMD_TBL_IMD
#define CMD_TBL_IMM
#define CMD_TBL_INM
#define CMD_TBL_IMW
#define CMD_TBL_ICRC
#define CMD_TBL_IPROBE
#define CMD_TBL_ILOOP
#define CMD_TBL_ISDRAM
#endif	/* CFG_CMD_MEMORY */

#endif	/* _CMD_I2C_H */