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