Skip to content
This repository was archived by the owner on Mar 7, 2026. It is now read-only.
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
47 changes: 22 additions & 25 deletions src/platforms/stm32/serialno.c
Original file line number Diff line number Diff line change
Expand Up @@ -23,44 +23,41 @@
char *serial_no_read(char *s)
{
#if DFU_SERIAL_LENGTH == 9
int i;
volatile uint32_t *unique_id_p = (volatile uint32_t *)DESIG_UNIQUE_ID_BASE;
uint32_t unique_id = *unique_id_p +
*(unique_id_p + 1) +
*(unique_id_p + 2);
const volatile uint32_t *const unique_id_p = (uint32_t *)DESIG_UNIQUE_ID_BASE;
const uint32_t unique_id = unique_id_p[0] + unique_id_p[1] + unique_id_p[2];
/* Fetch serial number from chip's unique ID */
for(i = 0; i < 8; i++) {
s[7-i] = ((unique_id >> (4*i)) & 0xF) + '0';
for(size_t i = 0; i < 8U; ++i) {
s[7U - i] = ((unique_id >> (i * 4U)) & 0x0FU) + '0';
/* If the character is something above 9, then add the offset to make it ASCII A-F */
if (s[7U - i] > '9')
s[7U - i] += 16; /* 'A' - '9' = 17, less 1 gives 16. */
}
for(i = 0; i < 8; i++)
if(s[i] > '9')
s[i] += 'A' - '9' - 1;
#elif DFU_SERIAL_LENGTH == 13
/* Use the same serial number as the ST DFU Bootloader.*/
uint16_t *uid = (uint16_t *)DESIG_UNIQUE_ID_BASE;
const volatile uint16_t *const uid = (uint16_t *)DESIG_UNIQUE_ID_BASE;
# if defined(STM32F4) || defined(STM32F7)
int offset = 3;
# elif defined(STM32L0) || defined(STM32F0) || defined(STM32F3)
int offset = 5;
# endif
sprintf(s, "%04X%04X%04X",
uid[1] + uid[5], uid[0] + uid[4], uid[offset]);
sprintf(s, "%04X%04X%04X", uid[1] + uid[5], uid[0] + uid[4], uid[offset]);
#elif DFU_SERIAL_LENGTH == 25
int i;
uint32_t unique_id[3];
memcpy(unique_id, (uint32_t *)DESIG_UNIQUE_ID_BASE, 12);
for(i = 0; i < 8; i++) {
s[ 7-i] = ((unique_id[0] >> (4*i)) & 0xF) + '0';
s[15-i] = ((unique_id[1] >> (4*i)) & 0xF) + '0';
s[23-i] = ((unique_id[2] >> (4*i)) & 0xF) + '0';
const volatile uint32_t *const unique_id_p = (uint32_t *)DESIG_UNIQUE_ID_BASE;
uint32_t unique_id = 0;
for (size_t i = 0; i < 24U; ++i) {
const size_t chunk = i >> 3U;
const size_t nibble = i & 7U;
if (nibble == 0)
unique_id = unique_id_p[chunk];
s[chunk + (7U - nibble)] = ((unique_id >> (i * 4)) & 0x0F) + '0';

/* If the character is something above 9, then add the offset to make it ASCII A-F */
if (s[chunk + (7U - nibble)] > '9')
s[chunk + (7U - nibble)] += 16; /* 'A' - '9' = 17, less 1 gives 16. */
}
for (i = 0; i < 24; i++)
if(s[i] > '9')
s[i] += 'A' - '9' - 1;
#else
# WARNING "Unhandled DFU_SERIAL_LENGTH"
#endif
s[DFU_SERIAL_LENGTH - 1] = 0;
s[DFU_SERIAL_LENGTH - 1] = '\0';
return s;
}