mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-05 13:01:12 +00:00
use C99 for loop where possible
This commit is contained in:
parent
e9fb5b08c7
commit
3d7d0f0734
@ -289,8 +289,7 @@ uint8_t *cryptoHDNodePathToPubkey(const HDNodePathType *hdnodepath)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
layoutProgressUpdate(true);
|
layoutProgressUpdate(true);
|
||||||
uint32_t i;
|
for (uint32_t i = 0; i < hdnodepath->address_n_count; i++) {
|
||||||
for (i = 0; i < hdnodepath->address_n_count; i++) {
|
|
||||||
if (hdnode_public_ckd(&node, hdnodepath->address_n[i]) == 0) {
|
if (hdnode_public_ckd(&node, hdnodepath->address_n[i]) == 0) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -301,8 +300,7 @@ uint8_t *cryptoHDNodePathToPubkey(const HDNodePathType *hdnodepath)
|
|||||||
|
|
||||||
int cryptoMultisigPubkeyIndex(const MultisigRedeemScriptType *multisig, const uint8_t *pubkey)
|
int cryptoMultisigPubkeyIndex(const MultisigRedeemScriptType *multisig, const uint8_t *pubkey)
|
||||||
{
|
{
|
||||||
size_t i;
|
for (size_t i = 0; i < multisig->pubkeys_count; i++) {
|
||||||
for (i = 0; i < multisig->pubkeys_count; i++) {
|
|
||||||
const uint8_t *node_pubkey = cryptoHDNodePathToPubkey(&(multisig->pubkeys[i]));
|
const uint8_t *node_pubkey = cryptoHDNodePathToPubkey(&(multisig->pubkeys[i]));
|
||||||
if (node_pubkey && memcmp(node_pubkey, pubkey, 33) == 0) {
|
if (node_pubkey && memcmp(node_pubkey, pubkey, 33) == 0) {
|
||||||
return i;
|
return i;
|
||||||
@ -318,17 +316,16 @@ int cryptoMultisigFingerprint(const MultisigRedeemScriptType *multisig, uint8_t
|
|||||||
if (n > 15) {
|
if (n > 15) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
uint32_t i, j;
|
|
||||||
// check sanity
|
// check sanity
|
||||||
if (!multisig->has_m || multisig->m < 1 || multisig->m > 15) return 0;
|
if (!multisig->has_m || multisig->m < 1 || multisig->m > 15) return 0;
|
||||||
for (i = 0; i < n; i++) {
|
for (uint32_t i = 0; i < n; i++) {
|
||||||
ptr[i] = &(multisig->pubkeys[i]);
|
ptr[i] = &(multisig->pubkeys[i]);
|
||||||
if (!ptr[i]->node.has_public_key || ptr[i]->node.public_key.size != 33) return 0;
|
if (!ptr[i]->node.has_public_key || ptr[i]->node.public_key.size != 33) return 0;
|
||||||
if (ptr[i]->node.chain_code.size != 32) return 0;
|
if (ptr[i]->node.chain_code.size != 32) return 0;
|
||||||
}
|
}
|
||||||
// minsort according to pubkey
|
// minsort according to pubkey
|
||||||
for (i = 0; i < n - 1; i++) {
|
for (uint32_t i = 0; i < n - 1; i++) {
|
||||||
for (j = n - 1; j > i; j--) {
|
for (uint32_t j = n - 1; j > i; j--) {
|
||||||
if (memcmp(ptr[i]->node.public_key.bytes, ptr[j]->node.public_key.bytes, 33) > 0) {
|
if (memcmp(ptr[i]->node.public_key.bytes, ptr[j]->node.public_key.bytes, 33) > 0) {
|
||||||
swap = ptr[i];
|
swap = ptr[i];
|
||||||
ptr[i] = ptr[j];
|
ptr[i] = ptr[j];
|
||||||
@ -340,7 +337,7 @@ int cryptoMultisigFingerprint(const MultisigRedeemScriptType *multisig, uint8_t
|
|||||||
SHA256_CTX ctx;
|
SHA256_CTX ctx;
|
||||||
sha256_Init(&ctx);
|
sha256_Init(&ctx);
|
||||||
sha256_Update(&ctx, (const uint8_t *)&(multisig->m), sizeof(uint32_t));
|
sha256_Update(&ctx, (const uint8_t *)&(multisig->m), sizeof(uint32_t));
|
||||||
for (i = 0; i < n; i++) {
|
for (uint32_t i = 0; i < n; i++) {
|
||||||
sha256_Update(&ctx, (const uint8_t *)&(ptr[i]->node.depth), sizeof(uint32_t));
|
sha256_Update(&ctx, (const uint8_t *)&(ptr[i]->node.depth), sizeof(uint32_t));
|
||||||
sha256_Update(&ctx, (const uint8_t *)&(ptr[i]->node.fingerprint), sizeof(uint32_t));
|
sha256_Update(&ctx, (const uint8_t *)&(ptr[i]->node.fingerprint), sizeof(uint32_t));
|
||||||
sha256_Update(&ctx, (const uint8_t *)&(ptr[i]->node.child_num), sizeof(uint32_t));
|
sha256_Update(&ctx, (const uint8_t *)&(ptr[i]->node.child_num), sizeof(uint32_t));
|
||||||
|
@ -26,15 +26,14 @@
|
|||||||
|
|
||||||
void oledDebug(const char *line)
|
void oledDebug(const char *line)
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
static const char *lines[8] = {0, 0, 0, 0, 0, 0, 0, 0};
|
static const char *lines[8] = {0, 0, 0, 0, 0, 0, 0, 0};
|
||||||
static char id = 3;
|
static char id = 3;
|
||||||
for (i = 0; i < 7; i++) {
|
for (int i = 0; i < 7; i++) {
|
||||||
lines[i] = lines[i + 1];
|
lines[i] = lines[i + 1];
|
||||||
}
|
}
|
||||||
lines[7] = line;
|
lines[7] = line;
|
||||||
oledClear();
|
oledClear();
|
||||||
for (i = 0; i < 8; i++) {
|
for (int i = 0; i < 8; i++) {
|
||||||
if (lines[i]) {
|
if (lines[i]) {
|
||||||
oledDrawChar(0, i * 8, '0' + (id + i) % 10, 1);
|
oledDrawChar(0, i * 8, '0' + (id + i) % 10, 1);
|
||||||
oledDrawString(8, i * 8, lines[i]);
|
oledDrawString(8, i * 8, lines[i]);
|
||||||
|
@ -283,12 +283,12 @@ static void layoutEthereumData(const uint8_t *data, uint32_t len, uint32_t total
|
|||||||
{
|
{
|
||||||
char hexdata[3][17];
|
char hexdata[3][17];
|
||||||
char summary[20];
|
char summary[20];
|
||||||
int i;
|
|
||||||
uint32_t printed = 0;
|
uint32_t printed = 0;
|
||||||
for (i = 0; i < 3; i++) {
|
for (int i = 0; i < 3; i++) {
|
||||||
uint32_t linelen = len - printed;
|
uint32_t linelen = len - printed;
|
||||||
if (linelen > 8)
|
if (linelen > 8) {
|
||||||
linelen = 8;
|
linelen = 8;
|
||||||
|
}
|
||||||
data2hex(data, linelen, hexdata[i]);
|
data2hex(data, linelen, hexdata[i]);
|
||||||
data += linelen;
|
data += linelen;
|
||||||
printed += linelen;
|
printed += linelen;
|
||||||
|
@ -1169,7 +1169,7 @@ void fsm_msgDebugLinkMemoryWrite(DebugLinkMemoryWrite *msg)
|
|||||||
if (msg->flash) {
|
if (msg->flash) {
|
||||||
flash_clear_status_flags();
|
flash_clear_status_flags();
|
||||||
flash_unlock();
|
flash_unlock();
|
||||||
for (unsigned int i = 0; i < length; i += 4) {
|
for (uint32_t i = 0; i < length; i += 4) {
|
||||||
uint32_t word;
|
uint32_t word;
|
||||||
memcpy(&word, msg->memory.bytes + i, 4);
|
memcpy(&word, msg->memory.bytes + i, 4);
|
||||||
flash_program_word(msg->address + i, word);
|
flash_program_word(msg->address + i, word);
|
||||||
|
@ -143,8 +143,7 @@ static inline void msg_debug_out_pad(void)
|
|||||||
static bool pb_callback_out(pb_ostream_t *stream, const uint8_t *buf, size_t count)
|
static bool pb_callback_out(pb_ostream_t *stream, const uint8_t *buf, size_t count)
|
||||||
{
|
{
|
||||||
(void)stream;
|
(void)stream;
|
||||||
size_t i;
|
for (size_t i = 0; i < count; i++) {
|
||||||
for (i = 0; i < count; i++) {
|
|
||||||
msg_out_append(buf[i]);
|
msg_out_append(buf[i]);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -155,8 +154,7 @@ static bool pb_callback_out(pb_ostream_t *stream, const uint8_t *buf, size_t cou
|
|||||||
static bool pb_debug_callback_out(pb_ostream_t *stream, const uint8_t *buf, size_t count)
|
static bool pb_debug_callback_out(pb_ostream_t *stream, const uint8_t *buf, size_t count)
|
||||||
{
|
{
|
||||||
(void)stream;
|
(void)stream;
|
||||||
size_t i;
|
for (size_t i = 0; i < count; i++) {
|
||||||
for (i = 0; i < count; i++) {
|
|
||||||
msg_debug_out_append(buf[i]);
|
msg_debug_out_append(buf[i]);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -33,11 +33,10 @@ void pinmatrix_draw(const char *text)
|
|||||||
};
|
};
|
||||||
oledSwipeLeft();
|
oledSwipeLeft();
|
||||||
const int w = bmp_digit0.width, h = bmp_digit0.height, pad = 2;
|
const int w = bmp_digit0.width, h = bmp_digit0.height, pad = 2;
|
||||||
int i, j, k;
|
for (int i = 0; i < 3; i++) {
|
||||||
for (i = 0; i < 3; i++) {
|
for (int j = 0; j < 3; j++) {
|
||||||
for (j = 0; j < 3; j++) {
|
|
||||||
// use (2 - j) instead of j to achieve 789456123 layout
|
// use (2 - j) instead of j to achieve 789456123 layout
|
||||||
k = pinmatrix_perm[i + (2 - j) * 3] - '0';
|
int k = pinmatrix_perm[i + (2 - j) * 3] - '0';
|
||||||
if (text) {
|
if (text) {
|
||||||
oledDrawStringCenter(0, text);
|
oledDrawStringCenter(0, text);
|
||||||
}
|
}
|
||||||
@ -49,8 +48,7 @@ void pinmatrix_draw(const char *text)
|
|||||||
|
|
||||||
void pinmatrix_start(const char *text)
|
void pinmatrix_start(const char *text)
|
||||||
{
|
{
|
||||||
int i;
|
for (int i = 0; i < 9; i++) {
|
||||||
for (i = 0; i < 9; i++) {
|
|
||||||
pinmatrix_perm[i] = '1' + i;
|
pinmatrix_perm[i] = '1' + i;
|
||||||
}
|
}
|
||||||
pinmatrix_perm[9] = 0;
|
pinmatrix_perm[9] = 0;
|
||||||
|
@ -130,11 +130,10 @@ static void recovery_request(void) {
|
|||||||
* Check mnemonic and send success/failure.
|
* Check mnemonic and send success/failure.
|
||||||
*/
|
*/
|
||||||
static void recovery_done(void) {
|
static void recovery_done(void) {
|
||||||
uint32_t i;
|
|
||||||
char new_mnemonic[sizeof(storage.mnemonic)] = {0};
|
char new_mnemonic[sizeof(storage.mnemonic)] = {0};
|
||||||
|
|
||||||
strlcpy(new_mnemonic, words[0], sizeof(new_mnemonic));
|
strlcpy(new_mnemonic, words[0], sizeof(new_mnemonic));
|
||||||
for (i = 1; i < word_count; i++) {
|
for (uint32_t i = 1; i < word_count; i++) {
|
||||||
strlcat(new_mnemonic, " ", sizeof(new_mnemonic));
|
strlcat(new_mnemonic, " ", sizeof(new_mnemonic));
|
||||||
strlcat(new_mnemonic, words[i], sizeof(new_mnemonic));
|
strlcat(new_mnemonic, words[i], sizeof(new_mnemonic));
|
||||||
}
|
}
|
||||||
@ -202,9 +201,8 @@ static void recovery_done(void) {
|
|||||||
*/
|
*/
|
||||||
static void add_choice(char choice[12], int prefixlen, const char *first, const char *last) {
|
static void add_choice(char choice[12], int prefixlen, const char *first, const char *last) {
|
||||||
// assert prefixlen < 4
|
// assert prefixlen < 4
|
||||||
int i;
|
|
||||||
char *dest = choice;
|
char *dest = choice;
|
||||||
for (i = 0; i < prefixlen; i++) {
|
for (int i = 0; i < prefixlen; i++) {
|
||||||
*dest++ = toupper((int) first[i]);
|
*dest++ = toupper((int) first[i]);
|
||||||
}
|
}
|
||||||
if (first[0] != last[0]) {
|
if (first[0] != last[0]) {
|
||||||
@ -216,7 +214,7 @@ static void add_choice(char choice[12], int prefixlen, const char *first, const
|
|||||||
} else if (prefixlen < 3) {
|
} else if (prefixlen < 3) {
|
||||||
/* AB-AC, etc. */
|
/* AB-AC, etc. */
|
||||||
*dest++ = '-';
|
*dest++ = '-';
|
||||||
for (i = 0; i < prefixlen; i++) {
|
for (int i = 0; i < prefixlen; i++) {
|
||||||
*dest++ = toupper((int) last[i]);
|
*dest++ = toupper((int) last[i]);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -240,11 +238,9 @@ static void add_choice(char choice[12], int prefixlen, const char *first, const
|
|||||||
*/
|
*/
|
||||||
static void display_choices(bool twoColumn, char choices[9][12], int num)
|
static void display_choices(bool twoColumn, char choices[9][12], int num)
|
||||||
{
|
{
|
||||||
int i;
|
const int nColumns = twoColumn ? 2 : 3;
|
||||||
int nColumns = twoColumn ? 2 : 3;
|
const int displayedChoices = nColumns * 3;
|
||||||
int displayedChoices = nColumns * 3;
|
for (int i = 0; i < displayedChoices; i++) {
|
||||||
int row, col;
|
|
||||||
for (i = 0; i < displayedChoices; i++) {
|
|
||||||
word_matrix[i] = i;
|
word_matrix[i] = i;
|
||||||
}
|
}
|
||||||
/* scramble matrix */
|
/* scramble matrix */
|
||||||
@ -259,9 +255,9 @@ static void display_choices(bool twoColumn, char choices[9][12], int num)
|
|||||||
oledBox(0, 27, 127, 63, false);
|
oledBox(0, 27, 127, 63, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (row = 0; row < 3; row ++) {
|
for (int row = 0; row < 3; row ++) {
|
||||||
int y = 55 - row * 11;
|
int y = 55 - row * 11;
|
||||||
for (col = 0; col < nColumns; col++) {
|
for (int col = 0; col < nColumns; col++) {
|
||||||
int x = twoColumn ? 64 * col + 32 : 42 * col + 22;
|
int x = twoColumn ? 64 * col + 32 : 42 * col + 22;
|
||||||
int choice = word_matrix[nColumns*row + col];
|
int choice = word_matrix[nColumns*row + col];
|
||||||
const char *text = choice < num ? choices[choice] : "-";
|
const char *text = choice < num ? choices[choice] : "-";
|
||||||
@ -276,14 +272,14 @@ static void display_choices(bool twoColumn, char choices[9][12], int num)
|
|||||||
oledRefresh();
|
oledRefresh();
|
||||||
|
|
||||||
/* avoid picking out of range numbers */
|
/* avoid picking out of range numbers */
|
||||||
for (i = 0; i < displayedChoices; i++) {
|
for (int i = 0; i < displayedChoices; i++) {
|
||||||
if (word_matrix[i] > num)
|
if (word_matrix[i] > num)
|
||||||
word_matrix[i] = 0;
|
word_matrix[i] = 0;
|
||||||
}
|
}
|
||||||
/* two column layout: middle column = right column */
|
/* two column layout: middle column = right column */
|
||||||
if (twoColumn) {
|
if (twoColumn) {
|
||||||
static const uint8_t twolayout[9] = { 0, 1, 1, 2, 3, 3, 4, 5, 5 };
|
static const uint8_t twolayout[9] = { 0, 1, 1, 2, 3, 3, 4, 5, 5 };
|
||||||
for (i = 8; i >= 2; i--) {
|
for (int i = 8; i >= 2; i--) {
|
||||||
word_matrix[i] = word_matrix[twolayout[i]];
|
word_matrix[i] = word_matrix[twolayout[i]];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -295,15 +291,15 @@ static void display_choices(bool twoColumn, char choices[9][12], int num)
|
|||||||
static void next_matrix(void) {
|
static void next_matrix(void) {
|
||||||
const char * const *wl = mnemonic_wordlist();
|
const char * const *wl = mnemonic_wordlist();
|
||||||
char word_choices[9][12];
|
char word_choices[9][12];
|
||||||
uint32_t i, idx, first, num;
|
uint32_t idx, num;
|
||||||
bool last = (word_index % 4) == 3;
|
bool last = (word_index % 4) == 3;
|
||||||
|
|
||||||
switch (word_index % 4) {
|
switch (word_index % 4) {
|
||||||
case 3:
|
case 3:
|
||||||
idx = TABLE1(word_pincode / 9) + word_pincode % 9;
|
idx = TABLE1(word_pincode / 9) + word_pincode % 9;
|
||||||
first = word_table2[idx] & 0xfff;
|
const uint32_t first = word_table2[idx] & 0xfff;
|
||||||
num = (word_table2[idx+1] & 0xfff) - first;
|
num = (word_table2[idx + 1] & 0xfff) - first;
|
||||||
for (i = 0; i < num; i++) {
|
for (uint32_t i = 0; i < num; i++) {
|
||||||
strlcpy(word_choices[i], wl[first + i], sizeof(word_choices[i]));
|
strlcpy(word_choices[i], wl[first + i], sizeof(word_choices[i]));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -311,7 +307,7 @@ static void next_matrix(void) {
|
|||||||
case 2:
|
case 2:
|
||||||
idx = TABLE1(word_pincode);
|
idx = TABLE1(word_pincode);
|
||||||
num = TABLE1(word_pincode + 1) - idx;
|
num = TABLE1(word_pincode + 1) - idx;
|
||||||
for (i = 0; i < num; i++) {
|
for (uint32_t i = 0; i < num; i++) {
|
||||||
add_choice(word_choices[i], (word_table2[idx + i] >> 12),
|
add_choice(word_choices[i], (word_table2[idx + i] >> 12),
|
||||||
wl[TABLE2(idx + i)],
|
wl[TABLE2(idx + i)],
|
||||||
wl[TABLE2(idx + i + 1) - 1]);
|
wl[TABLE2(idx + i + 1) - 1]);
|
||||||
@ -321,7 +317,7 @@ static void next_matrix(void) {
|
|||||||
case 1:
|
case 1:
|
||||||
idx = word_pincode * 9;
|
idx = word_pincode * 9;
|
||||||
num = 9;
|
num = 9;
|
||||||
for (i = 0; i < num; i++) {
|
for (uint32_t i = 0; i < num; i++) {
|
||||||
add_choice(word_choices[i], (word_table1[idx + i] >> 12),
|
add_choice(word_choices[i], (word_table1[idx + i] >> 12),
|
||||||
wl[TABLE2(TABLE1(idx + i))],
|
wl[TABLE2(TABLE1(idx + i))],
|
||||||
wl[TABLE2(TABLE1(idx + i + 1)) - 1]);
|
wl[TABLE2(TABLE1(idx + i + 1)) - 1]);
|
||||||
@ -330,7 +326,7 @@ static void next_matrix(void) {
|
|||||||
|
|
||||||
case 0:
|
case 0:
|
||||||
num = 9;
|
num = 9;
|
||||||
for (i = 0; i < num; i++) {
|
for (uint32_t i = 0; i < num; i++) {
|
||||||
add_choice(word_choices[i], 1,
|
add_choice(word_choices[i], 1,
|
||||||
wl[TABLE2(TABLE1(9*i))],
|
wl[TABLE2(TABLE1(9*i))],
|
||||||
wl[TABLE2(TABLE1(9*(i+1)))-1]);
|
wl[TABLE2(TABLE1(9*(i+1)))-1]);
|
||||||
@ -437,11 +433,10 @@ void recovery_init(uint32_t _word_count, bool passphrase_protection, bool pin_pr
|
|||||||
word_index = 0;
|
word_index = 0;
|
||||||
next_matrix();
|
next_matrix();
|
||||||
} else {
|
} else {
|
||||||
uint32_t i;
|
for (uint32_t i = 0; i < word_count; i++) {
|
||||||
for (i = 0; i < word_count; i++) {
|
|
||||||
word_order[i] = i + 1;
|
word_order[i] = i + 1;
|
||||||
}
|
}
|
||||||
for (i = word_count; i < 24; i++) {
|
for (uint32_t i = word_count; i < 24; i++) {
|
||||||
word_order[i] = 0;
|
word_order[i] = 0;
|
||||||
}
|
}
|
||||||
random_permute(word_order, 24);
|
random_permute(word_order, 24);
|
||||||
|
@ -120,13 +120,11 @@ void reset_backup(bool separated)
|
|||||||
storage.needs_backup = false;
|
storage.needs_backup = false;
|
||||||
storage_commit();
|
storage_commit();
|
||||||
|
|
||||||
int pass, word_pos, i = 0, j;
|
for (int pass = 0; pass < 2; pass++) {
|
||||||
|
int i = 0;
|
||||||
for (pass = 0; pass < 2; pass++) {
|
for (int word_pos = 1; word_pos <= (int)strength/32*3; word_pos++) {
|
||||||
i = 0;
|
|
||||||
for (word_pos = 1; word_pos <= (int)strength/32*3; word_pos++) {
|
|
||||||
// copy current_word
|
// copy current_word
|
||||||
j = 0;
|
int j = 0;
|
||||||
while (storage.mnemonic[i] != ' ' && storage.mnemonic[i] != 0 && j + 1 < (int)sizeof(current_word)) {
|
while (storage.mnemonic[i] != ' ' && storage.mnemonic[i] != 0 && j + 1 < (int)sizeof(current_word)) {
|
||||||
current_word[j] = storage.mnemonic[i];
|
current_word[j] = storage.mnemonic[i];
|
||||||
i++; j++;
|
i++; j++;
|
||||||
|
@ -702,8 +702,6 @@ static bool signing_sign_segwit_input(TxInputType *txinput) {
|
|||||||
|
|
||||||
resp.serialized.signature.size = ecdsa_sig_to_der(sig, resp.serialized.signature.bytes);
|
resp.serialized.signature.size = ecdsa_sig_to_der(sig, resp.serialized.signature.bytes);
|
||||||
if (txinput->has_multisig) {
|
if (txinput->has_multisig) {
|
||||||
uint32_t r, i, script_len;
|
|
||||||
int nwitnesses;
|
|
||||||
// fill in the signature
|
// fill in the signature
|
||||||
int pubkey_idx = cryptoMultisigPubkeyIndex(&(txinput->multisig), node.public_key);
|
int pubkey_idx = cryptoMultisigPubkeyIndex(&(txinput->multisig), node.public_key);
|
||||||
if (pubkey_idx < 0) {
|
if (pubkey_idx < 0) {
|
||||||
@ -714,10 +712,10 @@ static bool signing_sign_segwit_input(TxInputType *txinput) {
|
|||||||
memcpy(txinput->multisig.signatures[pubkey_idx].bytes, resp.serialized.signature.bytes, resp.serialized.signature.size);
|
memcpy(txinput->multisig.signatures[pubkey_idx].bytes, resp.serialized.signature.bytes, resp.serialized.signature.size);
|
||||||
txinput->multisig.signatures[pubkey_idx].size = resp.serialized.signature.size;
|
txinput->multisig.signatures[pubkey_idx].size = resp.serialized.signature.size;
|
||||||
|
|
||||||
r = 1; // skip number of items (filled in later)
|
uint32_t r = 1; // skip number of items (filled in later)
|
||||||
resp.serialized.serialized_tx.bytes[r] = 0; r++;
|
resp.serialized.serialized_tx.bytes[r] = 0; r++;
|
||||||
nwitnesses = 2;
|
int nwitnesses = 2;
|
||||||
for (i = 0; i < txinput->multisig.signatures_count; i++) {
|
for (uint32_t i = 0; i < txinput->multisig.signatures_count; i++) {
|
||||||
if (txinput->multisig.signatures[i].size == 0) {
|
if (txinput->multisig.signatures[i].size == 0) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -725,7 +723,7 @@ static bool signing_sign_segwit_input(TxInputType *txinput) {
|
|||||||
txinput->multisig.signatures[i].bytes[txinput->multisig.signatures[i].size] = 1;
|
txinput->multisig.signatures[i].bytes[txinput->multisig.signatures[i].size] = 1;
|
||||||
r += tx_serialize_script(txinput->multisig.signatures[i].size + 1, txinput->multisig.signatures[i].bytes, resp.serialized.serialized_tx.bytes + r);
|
r += tx_serialize_script(txinput->multisig.signatures[i].size + 1, txinput->multisig.signatures[i].bytes, resp.serialized.serialized_tx.bytes + r);
|
||||||
}
|
}
|
||||||
script_len = compile_script_multisig(&txinput->multisig, 0);
|
uint32_t script_len = compile_script_multisig(&txinput->multisig, 0);
|
||||||
r += ser_length(script_len, resp.serialized.serialized_tx.bytes + r);
|
r += ser_length(script_len, resp.serialized.serialized_tx.bytes + r);
|
||||||
r += compile_script_multisig(&txinput->multisig, resp.serialized.serialized_tx.bytes + r);
|
r += compile_script_multisig(&txinput->multisig, resp.serialized.serialized_tx.bytes + r);
|
||||||
resp.serialized.serialized_tx.bytes[0] = nwitnesses;
|
resp.serialized.serialized_tx.bytes[0] = nwitnesses;
|
||||||
|
@ -212,8 +212,7 @@ void session_clear(bool clear_pin)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static uint32_t storage_flash_words(uint32_t addr, uint32_t *src, int nwords) {
|
static uint32_t storage_flash_words(uint32_t addr, uint32_t *src, int nwords) {
|
||||||
int i;
|
for (int i = 0; i < nwords; i++) {
|
||||||
for (i = 0; i < nwords; i++) {
|
|
||||||
flash_program_word(addr, *src++);
|
flash_program_word(addr, *src++);
|
||||||
addr += 4;
|
addr += 4;
|
||||||
}
|
}
|
||||||
|
@ -249,10 +249,10 @@ uint32_t compile_script_multisig(const MultisigRedeemScriptType *multisig, uint8
|
|||||||
const uint32_t n = multisig->pubkeys_count;
|
const uint32_t n = multisig->pubkeys_count;
|
||||||
if (m < 1 || m > 15) return 0;
|
if (m < 1 || m > 15) return 0;
|
||||||
if (n < 1 || n > 15) return 0;
|
if (n < 1 || n > 15) return 0;
|
||||||
uint32_t i, r = 0;
|
uint32_t r = 0;
|
||||||
if (out) {
|
if (out) {
|
||||||
out[r] = 0x50 + m; r++;
|
out[r] = 0x50 + m; r++;
|
||||||
for (i = 0; i < n; i++) {
|
for (uint32_t i = 0; i < n; i++) {
|
||||||
out[r] = 33; r++; // OP_PUSH 33
|
out[r] = 33; r++; // OP_PUSH 33
|
||||||
const uint8_t *pubkey = cryptoHDNodePathToPubkey(&(multisig->pubkeys[i]));
|
const uint8_t *pubkey = cryptoHDNodePathToPubkey(&(multisig->pubkeys[i]));
|
||||||
if (!pubkey) return 0;
|
if (!pubkey) return 0;
|
||||||
@ -279,8 +279,7 @@ uint32_t compile_script_multisig_hash(const MultisigRedeemScriptType *multisig,
|
|||||||
|
|
||||||
uint8_t d[2];
|
uint8_t d[2];
|
||||||
d[0] = 0x50 + m; sha256_Update(&ctx, d, 1);
|
d[0] = 0x50 + m; sha256_Update(&ctx, d, 1);
|
||||||
uint32_t i;
|
for (uint32_t i = 0; i < n; i++) {
|
||||||
for (i = 0; i < n; i++) {
|
|
||||||
d[0] = 33; sha256_Update(&ctx, d, 1); // OP_PUSH 33
|
d[0] = 33; sha256_Update(&ctx, d, 1); // OP_PUSH 33
|
||||||
const uint8_t *pubkey = cryptoHDNodePathToPubkey(&(multisig->pubkeys[i]));
|
const uint8_t *pubkey = cryptoHDNodePathToPubkey(&(multisig->pubkeys[i]));
|
||||||
if (!pubkey) return 0;
|
if (!pubkey) return 0;
|
||||||
@ -308,9 +307,9 @@ uint32_t serialize_script_sig(const uint8_t *signature, uint32_t signature_len,
|
|||||||
|
|
||||||
uint32_t serialize_script_multisig(const MultisigRedeemScriptType *multisig, uint8_t *out)
|
uint32_t serialize_script_multisig(const MultisigRedeemScriptType *multisig, uint8_t *out)
|
||||||
{
|
{
|
||||||
uint32_t i, r = 0;
|
uint32_t r = 0;
|
||||||
out[r] = 0x00; r++;
|
out[r] = 0x00; r++;
|
||||||
for (i = 0; i < multisig->signatures_count; i++) {
|
for (uint32_t i = 0; i < multisig->signatures_count; i++) {
|
||||||
if (multisig->signatures[i].size == 0) {
|
if (multisig->signatures[i].size == 0) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -331,8 +330,7 @@ uint32_t serialize_script_multisig(const MultisigRedeemScriptType *multisig, uin
|
|||||||
|
|
||||||
uint32_t tx_prevout_hash(SHA256_CTX *ctx, const TxInputType *input)
|
uint32_t tx_prevout_hash(SHA256_CTX *ctx, const TxInputType *input)
|
||||||
{
|
{
|
||||||
int i;
|
for (int i = 0; i < 32; i++) {
|
||||||
for (i = 0; i < 32; i++) {
|
|
||||||
sha256_Update(ctx, &(input->prev_hash.bytes[31 - i]), 1);
|
sha256_Update(ctx, &(input->prev_hash.bytes[31 - i]), 1);
|
||||||
}
|
}
|
||||||
sha256_Update(ctx, (const uint8_t *)&input->prev_index, 4);
|
sha256_Update(ctx, (const uint8_t *)&input->prev_index, 4);
|
||||||
@ -391,7 +389,6 @@ uint32_t tx_serialize_header_hash(TxStruct *tx)
|
|||||||
|
|
||||||
uint32_t tx_serialize_input(TxStruct *tx, const TxInputType *input, uint8_t *out)
|
uint32_t tx_serialize_input(TxStruct *tx, const TxInputType *input, uint8_t *out)
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
if (tx->have_inputs >= tx->inputs_len) {
|
if (tx->have_inputs >= tx->inputs_len) {
|
||||||
// already got all inputs
|
// already got all inputs
|
||||||
return 0;
|
return 0;
|
||||||
@ -400,7 +397,7 @@ uint32_t tx_serialize_input(TxStruct *tx, const TxInputType *input, uint8_t *out
|
|||||||
if (tx->have_inputs == 0) {
|
if (tx->have_inputs == 0) {
|
||||||
r += tx_serialize_header(tx, out + r);
|
r += tx_serialize_header(tx, out + r);
|
||||||
}
|
}
|
||||||
for (i = 0; i < 32; i++) {
|
for (int i = 0; i < 32; i++) {
|
||||||
*(out + r + i) = input->prev_hash.bytes[31 - i];
|
*(out + r + i) = input->prev_hash.bytes[31 - i];
|
||||||
}
|
}
|
||||||
r += 32;
|
r += 32;
|
||||||
@ -558,9 +555,8 @@ void tx_hash_final(TxStruct *t, uint8_t *hash, bool reverse)
|
|||||||
sha256_Final(&(t->ctx), hash);
|
sha256_Final(&(t->ctx), hash);
|
||||||
sha256_Raw(hash, 32, hash);
|
sha256_Raw(hash, 32, hash);
|
||||||
if (!reverse) return;
|
if (!reverse) return;
|
||||||
uint8_t i, k;
|
for (uint8_t i = 0; i < 16; i++) {
|
||||||
for (i = 0; i < 16; i++) {
|
uint8_t k = hash[31 - i];
|
||||||
k = hash[31 - i];
|
|
||||||
hash[31 - i] = hash[i];
|
hash[31 - i] = hash[i];
|
||||||
hash[i] = k;
|
hash[i] = k;
|
||||||
}
|
}
|
||||||
|
@ -431,10 +431,9 @@ void u2f_version(const APDU *a)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void getReadableAppId(const uint8_t appid[U2F_APPID_SIZE], const char **appname, const BITMAP **appicon) {
|
void getReadableAppId(const uint8_t appid[U2F_APPID_SIZE], const char **appname, const BITMAP **appicon) {
|
||||||
unsigned int i;
|
|
||||||
static char buf[8+2+8+1];
|
static char buf[8+2+8+1];
|
||||||
|
|
||||||
for (i = 0; i < sizeof(u2f_well_known)/sizeof(U2FWellKnown); i++) {
|
for (unsigned int i = 0; i < sizeof(u2f_well_known)/sizeof(U2FWellKnown); i++) {
|
||||||
if (memcmp(appid, u2f_well_known[i].appid, U2F_APPID_SIZE) == 0) {
|
if (memcmp(appid, u2f_well_known[i].appid, U2F_APPID_SIZE) == 0) {
|
||||||
*appname = u2f_well_known[i].appname;
|
*appname = u2f_well_known[i].appname;
|
||||||
*appicon = u2f_well_known[i].appicon;
|
*appicon = u2f_well_known[i].appicon;
|
||||||
@ -473,9 +472,9 @@ const HDNode *generateKeyHandle(const uint8_t app_id[], uint8_t key_handle[])
|
|||||||
uint8_t keybase[U2F_APPID_SIZE + KEY_PATH_LEN];
|
uint8_t keybase[U2F_APPID_SIZE + KEY_PATH_LEN];
|
||||||
|
|
||||||
// Derivation path is m/U2F'/r'/r'/r'/r'/r'/r'/r'/r'
|
// Derivation path is m/U2F'/r'/r'/r'/r'/r'/r'/r'/r'
|
||||||
uint32_t i, key_path[KEY_PATH_ENTRIES];
|
uint32_t key_path[KEY_PATH_ENTRIES];
|
||||||
key_path[0] = U2F_KEY_PATH;
|
key_path[0] = U2F_KEY_PATH;
|
||||||
for (i = 1; i < KEY_PATH_ENTRIES; i++) {
|
for (uint32_t i = 1; i < KEY_PATH_ENTRIES; i++) {
|
||||||
// high bit for hardened keys
|
// high bit for hardened keys
|
||||||
key_path[i]= 0x80000000 | random32();
|
key_path[i]= 0x80000000 | random32();
|
||||||
}
|
}
|
||||||
|
58
oled.c
58
oled.c
@ -81,9 +81,8 @@ static bool is_debug_link = 0;
|
|||||||
*/
|
*/
|
||||||
inline void SPISend(uint32_t base, uint8_t *data, int len)
|
inline void SPISend(uint32_t base, uint8_t *data, int len)
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
delay(1);
|
delay(1);
|
||||||
for (i = 0; i < len; i++) {
|
for (int i = 0; i < len; i++) {
|
||||||
spi_send(base, data[i]);
|
spi_send(base, data[i]);
|
||||||
}
|
}
|
||||||
while (!(SPI_SR(base) & SPI_SR_TXE));
|
while (!(SPI_SR(base) & SPI_SR_TXE));
|
||||||
@ -219,17 +218,13 @@ void oledClearPixel(int x, int y)
|
|||||||
|
|
||||||
void oledDrawChar(int x, int y, char c, int zoom)
|
void oledDrawChar(int x, int y, char c, int zoom)
|
||||||
{
|
{
|
||||||
int char_width;
|
|
||||||
const uint8_t *char_data;
|
|
||||||
|
|
||||||
if ((x >= OLED_WIDTH) || (y >= OLED_HEIGHT)) return;
|
if ((x >= OLED_WIDTH) || (y >= OLED_HEIGHT)) return;
|
||||||
|
|
||||||
char_width = fontCharWidth(c);
|
int char_width = fontCharWidth(c);
|
||||||
char_data = fontCharData(c);
|
const uint8_t *char_data = fontCharData(c);
|
||||||
|
|
||||||
int xo, yo;
|
for (int xo = 0; xo < char_width; xo++) {
|
||||||
for (xo = 0; xo < char_width; xo++) {
|
for (int yo = 0; yo < FONT_HEIGHT; yo++) {
|
||||||
for (yo = 0; yo < FONT_HEIGHT; yo++) {
|
|
||||||
if (char_data[xo] & (1 << (FONT_HEIGHT - 1 - yo))) {
|
if (char_data[xo] & (1 << (FONT_HEIGHT - 1 - yo))) {
|
||||||
if (zoom <= 1) {
|
if (zoom <= 1) {
|
||||||
oledDrawPixel(x + xo, y + yo);
|
oledDrawPixel(x + xo, y + yo);
|
||||||
@ -254,9 +249,8 @@ char oledConvertChar(const char c) {
|
|||||||
int oledStringWidth(const char *text) {
|
int oledStringWidth(const char *text) {
|
||||||
if (!text) return 0;
|
if (!text) return 0;
|
||||||
int l = 0;
|
int l = 0;
|
||||||
char c;
|
|
||||||
for (; *text; text++) {
|
for (; *text; text++) {
|
||||||
c = oledConvertChar(*text);
|
char c = oledConvertChar(*text);
|
||||||
if (c) {
|
if (c) {
|
||||||
l += fontCharWidth(c) + 1;
|
l += fontCharWidth(c) + 1;
|
||||||
}
|
}
|
||||||
@ -273,9 +267,8 @@ void oledDrawString(int x, int y, const char* text)
|
|||||||
size = 2;
|
size = 2;
|
||||||
}
|
}
|
||||||
int l = 0;
|
int l = 0;
|
||||||
char c;
|
|
||||||
for (; *text; text++) {
|
for (; *text; text++) {
|
||||||
c = oledConvertChar(*text);
|
char c = oledConvertChar(*text);
|
||||||
if (c) {
|
if (c) {
|
||||||
oledDrawChar(x + l, y, c, size);
|
oledDrawChar(x + l, y, c, size);
|
||||||
l += size * (fontCharWidth(c) + 1);
|
l += size * (fontCharWidth(c) + 1);
|
||||||
@ -299,9 +292,8 @@ void oledDrawStringRight(int x, int y, const char* text)
|
|||||||
|
|
||||||
void oledDrawBitmap(int x, int y, const BITMAP *bmp)
|
void oledDrawBitmap(int x, int y, const BITMAP *bmp)
|
||||||
{
|
{
|
||||||
int i, j;
|
for (int i = 0; i < min(bmp->width, OLED_WIDTH - x); i++) {
|
||||||
for (i = 0; i < min(bmp->width, OLED_WIDTH - x); i++) {
|
for (int j = 0; j < min(bmp->height, OLED_HEIGHT - y); j++) {
|
||||||
for (j = 0; j < min(bmp->height, OLED_HEIGHT - y); j++) {
|
|
||||||
if (bmp->data[(i / 8) + j * bmp->width / 8] & (1 << (7 - i % 8))) {
|
if (bmp->data[(i / 8) + j * bmp->width / 8] & (1 << (7 - i % 8))) {
|
||||||
OLED_BUFSET(x + i, y + j);
|
OLED_BUFSET(x + i, y + j);
|
||||||
} else {
|
} else {
|
||||||
@ -314,9 +306,8 @@ void oledDrawBitmap(int x, int y, const BITMAP *bmp)
|
|||||||
void oledInvert(int x1, int y1, int x2, int y2)
|
void oledInvert(int x1, int y1, int x2, int y2)
|
||||||
{
|
{
|
||||||
if ((x1 >= OLED_WIDTH) || (y1 >= OLED_HEIGHT) || (x2 >= OLED_WIDTH) || (y2 >= OLED_HEIGHT)) return;
|
if ((x1 >= OLED_WIDTH) || (y1 >= OLED_HEIGHT) || (x2 >= OLED_WIDTH) || (y2 >= OLED_HEIGHT)) return;
|
||||||
int x, y;
|
for (int x = x1; x <= x2; x++) {
|
||||||
for (x = x1; x <= x2; x++) {
|
for (int y = y1; y <= y2; y++) {
|
||||||
for (y = y1; y <= y2; y++) {
|
|
||||||
OLED_BUFTGL(x,y);
|
OLED_BUFTGL(x,y);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -327,17 +318,15 @@ void oledInvert(int x1, int y1, int x2, int y2)
|
|||||||
*/
|
*/
|
||||||
void oledBox(int x1, int y1, int x2, int y2, bool set)
|
void oledBox(int x1, int y1, int x2, int y2, bool set)
|
||||||
{
|
{
|
||||||
int x, y;
|
for (int x = x1; x <= x2; x++) {
|
||||||
for (x = x1; x <= x2; x++) {
|
for (int y = y1; y <= y2; y++) {
|
||||||
for (y = y1; y <= y2; y++) {
|
|
||||||
set ? oledDrawPixel(x, y) : oledClearPixel(x, y);
|
set ? oledDrawPixel(x, y) : oledClearPixel(x, y);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void oledHLine(int y) {
|
void oledHLine(int y) {
|
||||||
int x;
|
for (int x = 0; x < OLED_WIDTH; x++) {
|
||||||
for (x = 0; x < OLED_WIDTH; x++) {
|
|
||||||
oledDrawPixel(x, y);
|
oledDrawPixel(x, y);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -347,12 +336,11 @@ void oledHLine(int y) {
|
|||||||
*/
|
*/
|
||||||
void oledFrame(int x1, int y1, int x2, int y2)
|
void oledFrame(int x1, int y1, int x2, int y2)
|
||||||
{
|
{
|
||||||
int x, y;
|
for (int x = x1; x <= x2; x++) {
|
||||||
for (x = x1; x <= x2; x++) {
|
|
||||||
oledDrawPixel(x, y1);
|
oledDrawPixel(x, y1);
|
||||||
oledDrawPixel(x, y2);
|
oledDrawPixel(x, y2);
|
||||||
}
|
}
|
||||||
for (y = y1 + 1; y < y2; y++) {
|
for (int y = y1 + 1; y < y2; y++) {
|
||||||
oledDrawPixel(x1, y);
|
oledDrawPixel(x1, y);
|
||||||
oledDrawPixel(x2, y);
|
oledDrawPixel(x2, y);
|
||||||
}
|
}
|
||||||
@ -364,10 +352,9 @@ void oledFrame(int x1, int y1, int x2, int y2)
|
|||||||
*/
|
*/
|
||||||
void oledSwipeLeft(void)
|
void oledSwipeLeft(void)
|
||||||
{
|
{
|
||||||
int i, j, k;
|
for (int i = 0; i < OLED_WIDTH; i++) {
|
||||||
for (i = 0; i < OLED_WIDTH; i++) {
|
for (int j = 0; j < OLED_HEIGHT / 8; j++) {
|
||||||
for (j = 0; j < OLED_HEIGHT / 8; j++) {
|
for (int k = OLED_WIDTH-1; k > 0; k--) {
|
||||||
for (k = OLED_WIDTH-1; k > 0; k--) {
|
|
||||||
_oledbuffer[j * OLED_WIDTH + k] = _oledbuffer[j * OLED_WIDTH + k - 1];
|
_oledbuffer[j * OLED_WIDTH + k] = _oledbuffer[j * OLED_WIDTH + k - 1];
|
||||||
}
|
}
|
||||||
_oledbuffer[j * OLED_WIDTH] = 0;
|
_oledbuffer[j * OLED_WIDTH] = 0;
|
||||||
@ -382,10 +369,9 @@ void oledSwipeLeft(void)
|
|||||||
*/
|
*/
|
||||||
void oledSwipeRight(void)
|
void oledSwipeRight(void)
|
||||||
{
|
{
|
||||||
int i, j, k;
|
for (int i = 0; i < OLED_WIDTH / 4; i++) {
|
||||||
for (i = 0; i < OLED_WIDTH / 4; i++) {
|
for (int j = 0; j < OLED_HEIGHT / 8; j++) {
|
||||||
for (j = 0; j < OLED_HEIGHT / 8; j++) {
|
for (int k = 0; k < OLED_WIDTH / 4 - 1; k++) {
|
||||||
for (k = 0; k < OLED_WIDTH / 4 - 1; k++) {
|
|
||||||
_oledbuffer[k * 4 + 0 + j * OLED_WIDTH] = _oledbuffer[k * 4 + 4 + j * OLED_WIDTH];
|
_oledbuffer[k * 4 + 0 + j * OLED_WIDTH] = _oledbuffer[k * 4 + 4 + j * OLED_WIDTH];
|
||||||
_oledbuffer[k * 4 + 1 + j * OLED_WIDTH] = _oledbuffer[k * 4 + 5 + j * OLED_WIDTH];
|
_oledbuffer[k * 4 + 1 + j * OLED_WIDTH] = _oledbuffer[k * 4 + 5 + j * OLED_WIDTH];
|
||||||
_oledbuffer[k * 4 + 2 + j * OLED_WIDTH] = _oledbuffer[k * 4 + 6 + j * OLED_WIDTH];
|
_oledbuffer[k * 4 + 2 + j * OLED_WIDTH] = _oledbuffer[k * 4 + 6 + j * OLED_WIDTH];
|
||||||
|
11
rng.c
11
rng.c
@ -44,9 +44,8 @@ uint32_t random_uniform(uint32_t n)
|
|||||||
|
|
||||||
void random_buffer(uint8_t *buf, size_t len)
|
void random_buffer(uint8_t *buf, size_t len)
|
||||||
{
|
{
|
||||||
size_t i;
|
|
||||||
uint32_t r = 0;
|
uint32_t r = 0;
|
||||||
for (i = 0; i < len; i++) {
|
for (size_t i = 0; i < len; i++) {
|
||||||
if (i % 4 == 0) {
|
if (i % 4 == 0) {
|
||||||
r = random32();
|
r = random32();
|
||||||
}
|
}
|
||||||
@ -56,11 +55,9 @@ void random_buffer(uint8_t *buf, size_t len)
|
|||||||
|
|
||||||
void random_permute(char *str, size_t len)
|
void random_permute(char *str, size_t len)
|
||||||
{
|
{
|
||||||
int i, j;
|
for (int i = len - 1; i >= 1; i--) {
|
||||||
char t;
|
int j = random_uniform(i + 1);
|
||||||
for (i = len - 1; i >= 1; i--) {
|
char t = str[j];
|
||||||
j = random_uniform(i + 1);
|
|
||||||
t = str[j];
|
|
||||||
str[j] = str[i];
|
str[j] = str[i];
|
||||||
str[i] = t;
|
str[i] = t;
|
||||||
}
|
}
|
||||||
|
6
util.c
6
util.c
@ -29,8 +29,7 @@ static const char *hexdigits = "0123456789ABCDEF";
|
|||||||
|
|
||||||
void uint32hex(uint32_t num, char *str)
|
void uint32hex(uint32_t num, char *str)
|
||||||
{
|
{
|
||||||
uint32_t i;
|
for (uint32_t i = 0; i < 8; i++) {
|
||||||
for (i = 0; i < 8; i++) {
|
|
||||||
str[i] = hexdigits[(num >> (28 - i * 4)) & 0xF];
|
str[i] = hexdigits[(num >> (28 - i * 4)) & 0xF];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -38,9 +37,8 @@ void uint32hex(uint32_t num, char *str)
|
|||||||
// converts data to hexa
|
// converts data to hexa
|
||||||
void data2hex(const void *data, uint32_t len, char *str)
|
void data2hex(const void *data, uint32_t len, char *str)
|
||||||
{
|
{
|
||||||
uint32_t i;
|
|
||||||
const uint8_t *cdata = (uint8_t *)data;
|
const uint8_t *cdata = (uint8_t *)data;
|
||||||
for (i = 0; i < len; i++) {
|
for (uint32_t i = 0; i < len; i++) {
|
||||||
str[i * 2 ] = hexdigits[(cdata[i] >> 4) & 0xF];
|
str[i * 2 ] = hexdigits[(cdata[i] >> 4) & 0xF];
|
||||||
str[i * 2 + 1] = hexdigits[cdata[i] & 0xF];
|
str[i * 2 + 1] = hexdigits[cdata[i] & 0xF];
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user