forked from someone42/hardware-bitcoin-wallet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
stream_comm.h
120 lines (114 loc) · 4.38 KB
/
stream_comm.h
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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/** \file stream_comm.h
*
* \brief Describes functions, types and constants exported by stream_comm.c.
*
*
* This file is licensed as described by the file LICENCE.
*/
#ifndef STREAM_COMM_H_INCLUDED
#define STREAM_COMM_H_INCLUDED
#include "common.h"
/** Major version number to report to the host. */
#define VERSION_MAJOR 0
/** Minor version number to report to the host. */
#define VERSION_MINOR 4
/**
* \defgroup PacketTypes Type values for packets.
*
* See the file PROTOCOL for more information about the format of packets
* and what the payload of packets should be.
*
* @{
*/
/** Request a response from the wallet. */
#define PACKET_TYPE_PING 0x00
/** Create a new wallet. */
#define PACKET_TYPE_NEW_WALLET 0x04
/** Create a new address in a wallet. */
#define PACKET_TYPE_NEW_ADDRESS 0x05
/** Get number of addresses in a wallet. */
#define PACKET_TYPE_GET_NUM_ADDRESSES 0x06
/** Get an address and its associated public key from a wallet. */
#define PACKET_TYPE_GET_ADDRESS_PUBKEY 0x09
/** Sign a transaction. */
#define PACKET_TYPE_SIGN_TRANSACTION 0x0A
/** Load (unlock) a wallet. */
#define PACKET_TYPE_LOAD_WALLET 0x0B
/** Format storage area, erasing everything. */
#define PACKET_TYPE_FORMAT 0x0D
/** Change encryption key of a wallet. */
#define PACKET_TYPE_CHANGE_KEY 0x0E
/** Change name of a wallet. */
#define PACKET_TYPE_CHANGE_NAME 0x0F
/** List all wallets. */
#define PACKET_TYPE_LIST_WALLETS 0x10
/** Backup a wallet. */
#define PACKET_TYPE_BACKUP_WALLET 0x11
/** Restore wallet from a backup. */
#define PACKET_TYPE_RESTORE_WALLET 0x12
/** Get device UUID. */
#define PACKET_TYPE_GET_DEVICE_UUID 0x13
/** Get bytes of entropy. */
#define PACKET_TYPE_GET_ENTROPY 0x14
/** Get master public key. */
#define PACKET_TYPE_GET_MASTER_KEY 0x15
/** Delete a wallet. */
#define PACKET_TYPE_DELETE_WALLET 0x16
/** Initialise device's state. */
#define PACKET_TYPE_INITIALIZE 0x17
/** An address from a wallet (response to #PACKET_TYPE_GET_ADDRESS_PUBKEY
* or #PACKET_TYPE_NEW_ADDRESS). */
#define PACKET_TYPE_ADDRESS_PUBKEY 0x30
/** Number of addresses in a wallet
* (response to #PACKET_TYPE_GET_NUM_ADDRESSES). */
#define PACKET_TYPE_NUM_ADDRESSES 0x31
/** Public information about all wallets
* (response to #PACKET_TYPE_LIST_WALLETS). */
#define PACKET_TYPE_WALLETS 0x32
/** Wallet's response to ping (see #PACKET_TYPE_PING). */
#define PACKET_TYPE_PING_RESPONSE 0x33
/** Packet signifying successful completion of an operation. */
#define PACKET_TYPE_SUCCESS 0x34
/** Packet signifying failure of an operation. */
#define PACKET_TYPE_FAILURE 0x35
/** Device UUID (response to #PACKET_TYPE_GET_DEVICE_UUID). */
#define PACKET_TYPE_DEVICE_UUID 0x36
/** Some bytes of entropy (response to #PACKET_TYPE_GET_ENTROPY). */
#define PACKET_TYPE_ENTROPY 0x37
/** Master public key (response to #PACKET_TYPE_GET_MASTER_KEY). */
#define PACKET_TYPE_MASTER_KEY 0x38
/** Signature (response to #PACKET_TYPE_SIGN_TRANSACTION). */
#define PACKET_TYPE_SIGNATURE 0x39
/** Version information and list of features. */
#define PACKET_TYPE_FEATURES 0x3a
/** Device wants to wait for button press (beginning of ButtonRequest
* interjection). */
#define PACKET_TYPE_BUTTON_REQUEST 0x50
/** Host will allow button press (response to #PACKET_TYPE_BUTTON_REQUEST). */
#define PACKET_TYPE_BUTTON_ACK 0x51
/** Host will not allow button press (response
* to #PACKET_TYPE_BUTTON_REQUEST). */
#define PACKET_TYPE_BUTTON_CANCEL 0x52
/** Device wants host to send a password (beginning of PinRequest
* interjection. */
#define PACKET_TYPE_PIN_REQUEST 0x53
/** Host sends password (response to #PACKET_TYPE_PIN_REQUEST). */
#define PACKET_TYPE_PIN_ACK 0x54
/** Host does not want to send password (response
* to #PACKET_TYPE_PIN_REQUEST). */
#define PACKET_TYPE_PIN_CANCEL 0x55
/** Device wants host to send a one-time password (beginning of OtpRequest
* interjection. */
#define PACKET_TYPE_OTP_REQUEST 0x56
/** Host sends one-time password (response to #PACKET_TYPE_OTP_REQUEST). */
#define PACKET_TYPE_OTP_ACK 0x57
/** Host does not want to send one-time password (response
* to #PACKET_TYPE_OTP_REQUEST). */
#define PACKET_TYPE_OTP_CANCEL 0x58
/**@}*/
extern void processPacket(void);
#ifdef TEST
extern void setTestInputStream(const uint8_t *buffer, uint32_t length);
extern void setInfiniteZeroInputStream(void);
#endif // #ifdef TEST
#endif // #ifndef STREAM_COMM_H_INCLUDED