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 */
|