xref: /openbmc/u-boot/include/atsha204a-i2c.h (revision 2218b32d)
1*aa5eb9a3SMarek Behún /*
2*aa5eb9a3SMarek Behún  * I2C Driver for Atmel ATSHA204 over I2C
3*aa5eb9a3SMarek Behún  *
4*aa5eb9a3SMarek Behún  * Copyright (C) 2014 Josh Datko, Cryptotronix, jbd@cryptotronix.com
5*aa5eb9a3SMarek Behún  * 		 2016 Tomas Hlavacek, CZ.NIC, tmshlvck@gmail.com
6*aa5eb9a3SMarek Behún  * 		 2017 Marek Behun, CZ.NIC, marek.behun@nic.cz
7*aa5eb9a3SMarek Behún  *
8*aa5eb9a3SMarek Behún  * This program is free software; you can redistribute  it and/or modify it
9*aa5eb9a3SMarek Behún  * under the terms of the GNU General Public License version 2 as
10*aa5eb9a3SMarek Behún  * published by the Free Software Foundation.
11*aa5eb9a3SMarek Behún  */
12*aa5eb9a3SMarek Behún #ifndef _ATSHA204_I2C_H_
13*aa5eb9a3SMarek Behún #define _ATSHA204_I2C_H_
14*aa5eb9a3SMarek Behún 
15*aa5eb9a3SMarek Behún enum atsha204a_zone
16*aa5eb9a3SMarek Behún {
17*aa5eb9a3SMarek Behún 	ATSHA204A_ZONE_CONFIG	= 0,
18*aa5eb9a3SMarek Behún 	ATSHA204A_ZONE_OTP	= 1,
19*aa5eb9a3SMarek Behún 	ATSHA204A_ZONE_DATA	= 2,
20*aa5eb9a3SMarek Behún };
21*aa5eb9a3SMarek Behún 
22*aa5eb9a3SMarek Behún enum atsha204a_status
23*aa5eb9a3SMarek Behún {
24*aa5eb9a3SMarek Behún 	ATSHA204A_STATUS_SUCCESS	= 0x00,
25*aa5eb9a3SMarek Behún 	ATSHA204A_STATUS_MISCOMPARE	= 0x01,
26*aa5eb9a3SMarek Behún 	ATSHA204A_STATUS_PARSE_ERROR	= 0x03,
27*aa5eb9a3SMarek Behún 	ATSHA204A_STATUS_EXEC_ERROR	= 0x0F,
28*aa5eb9a3SMarek Behún 	ATSHA204A_STATUS_AFTER_WAKE	= 0x11,
29*aa5eb9a3SMarek Behún 	ATSHA204A_STATUS_CRC_ERROR	= 0xFF,
30*aa5eb9a3SMarek Behún };
31*aa5eb9a3SMarek Behún 
32*aa5eb9a3SMarek Behún enum atsha204a_func
33*aa5eb9a3SMarek Behún {
34*aa5eb9a3SMarek Behún 	ATSHA204A_FUNC_RESET	= 0x00,
35*aa5eb9a3SMarek Behún 	ATSHA204A_FUNC_SLEEP	= 0x01,
36*aa5eb9a3SMarek Behún 	ATSHA204A_FUNC_IDLE	= 0x02,
37*aa5eb9a3SMarek Behún 	ATSHA204A_FUNC_COMMAND	= 0x03,
38*aa5eb9a3SMarek Behún };
39*aa5eb9a3SMarek Behún 
40*aa5eb9a3SMarek Behún enum atsha204a_cmd
41*aa5eb9a3SMarek Behún {
42*aa5eb9a3SMarek Behún 	ATSHA204A_CMD_READ	= 0x02,
43*aa5eb9a3SMarek Behún 	ATSHA204A_CMD_RANDOM	= 0x1B,
44*aa5eb9a3SMarek Behún };
45*aa5eb9a3SMarek Behún 
46*aa5eb9a3SMarek Behún struct atsha204a_resp
47*aa5eb9a3SMarek Behún {
48*aa5eb9a3SMarek Behún 	u8 length;
49*aa5eb9a3SMarek Behún 	u8 code;
50*aa5eb9a3SMarek Behún 	u8 data[82];
51*aa5eb9a3SMarek Behún } __attribute__ ((packed));
52*aa5eb9a3SMarek Behún 
53*aa5eb9a3SMarek Behún struct atsha204a_req
54*aa5eb9a3SMarek Behún {
55*aa5eb9a3SMarek Behún 	u8 function;
56*aa5eb9a3SMarek Behún 	u8 length;
57*aa5eb9a3SMarek Behún 	u8 command;
58*aa5eb9a3SMarek Behún 	u8 param1;
59*aa5eb9a3SMarek Behún 	u16 param2;
60*aa5eb9a3SMarek Behún 	u8 data[78];
61*aa5eb9a3SMarek Behún } __attribute__ ((packed));
62*aa5eb9a3SMarek Behún 
63*aa5eb9a3SMarek Behún int atsha204a_wakeup(struct udevice *);
64*aa5eb9a3SMarek Behún int atsha204a_idle(struct udevice *);
65*aa5eb9a3SMarek Behún int atsha204a_sleep(struct udevice *);
66*aa5eb9a3SMarek Behún int atsha204a_read(struct udevice *, enum atsha204a_zone, bool, u16, u8 *);
67*aa5eb9a3SMarek Behún int atsha204a_get_random(struct udevice *, u8 *, size_t);
68*aa5eb9a3SMarek Behún 
69*aa5eb9a3SMarek Behún #endif /* _ATSHA204_I2C_H_ */
70