Skip to content

Commit 0fe6a09

Browse files
newbrainnewbrainliamfraser
authored
Unique serial numbers for picoprobe (#8)
Co-authored-by: newbrain <newbrain@tiscali.it> Co-authored-by: Liam Fraser <liam@raspberrypi.com>
1 parent 8ab7ebc commit 0fe6a09

File tree

5 files changed

+91
-2
lines changed

5 files changed

+91
-2
lines changed

CMakeLists.txt

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,7 @@ add_executable(picoprobe
1212
src/usb_descriptors.c
1313
src/probe.c
1414
src/cdc_uart.c
15+
src/get_serial.c
1516
)
1617

1718
if (DEFINED ENV{PICOPROBE_LED})
@@ -25,6 +26,6 @@ pico_generate_pio_header(picoprobe ${CMAKE_CURRENT_LIST_DIR}/src/probe.pio)
2526

2627
target_include_directories(picoprobe PRIVATE src)
2728

28-
target_link_libraries(picoprobe PRIVATE pico_stdlib tinyusb_device tinyusb_board hardware_pio)
29+
target_link_libraries(picoprobe PRIVATE pico_stdlib pico_unique_id tinyusb_device tinyusb_board hardware_pio)
2930

3031
pico_add_extra_outputs(picoprobe)

src/get_serial.c

Lines changed: 50 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,50 @@
1+
/*
2+
* The MIT License (MIT)
3+
*
4+
* Copyright (c) 2021 Federico Zuccardi Merli
5+
*
6+
* Permission is hereby granted, free of charge, to any person obtaining a copy
7+
* of this software and associated documentation files (the "Software"), to deal
8+
* in the Software without restriction, including without limitation the rights
9+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10+
* copies of the Software, and to permit persons to whom the Software is
11+
* furnished to do so, subject to the following conditions:
12+
*
13+
* The above copyright notice and this permission notice shall be included in
14+
* all copies or substantial portions of the Software.
15+
*
16+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22+
* THE SOFTWARE.
23+
*
24+
*/
25+
26+
#include <stdint.h>
27+
#include "pico/unique_id.h"
28+
#include "get_serial.h"
29+
30+
/* C string for iSerialNumber in USB Device Descriptor, two chars per byte + terminating NUL */
31+
char usb_serial[PICO_UNIQUE_BOARD_ID_SIZE_BYTES * 2 + 1];
32+
33+
/* Why a uint8_t[8] array inside a struct instead of an uint64_t an inquiring mind might wonder */
34+
static pico_unique_board_id_t uID;
35+
36+
void usb_serial_init(void)
37+
{
38+
pico_get_unique_board_id(&uID);
39+
40+
for (int i = 0; i < PICO_UNIQUE_BOARD_ID_SIZE_BYTES * 2; i++)
41+
{
42+
/* Byte index inside the uid array */
43+
int bi = i / 2;
44+
/* Use high nibble first to keep memory order (just cosmetics) */
45+
uint8_t nibble = (uID.id[bi] >> 4) & 0x0F;
46+
uID.id[bi] <<= 4;
47+
/* Binary to hex digit */
48+
usb_serial[i] = nibble < 10 ? nibble + '0' : nibble + 'A' - 10;
49+
}
50+
}

src/get_serial.h

Lines changed: 35 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
/*
2+
* The MIT License (MIT)
3+
*
4+
* Copyright (c) 2021 Federico Zuccardi Merli
5+
*
6+
* Permission is hereby granted, free of charge, to any person obtaining a copy
7+
* of this software and associated documentation files (the "Software"), to deal
8+
* in the Software without restriction, including without limitation the rights
9+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10+
* copies of the Software, and to permit persons to whom the Software is
11+
* furnished to do so, subject to the following conditions:
12+
*
13+
* The above copyright notice and this permission notice shall be included in
14+
* all copies or substantial portions of the Software.
15+
*
16+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22+
* THE SOFTWARE.
23+
*
24+
*/
25+
26+
#ifndef GET_SERIAL_H_
27+
#define GET_SERIAL_H_
28+
29+
/* Contains unique serial number string (NUL terminated) after call to init_usb_serial */
30+
extern char usb_serial[];
31+
32+
/* Fills unique_serial with the flash unique id */
33+
extern void usb_serial_init(void);
34+
35+
#endif

src/main.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -33,6 +33,7 @@
3333
#include "picoprobe_config.h"
3434
#include "probe.h"
3535
#include "cdc_uart.h"
36+
#include "get_serial.h"
3637
#include "led.h"
3738

3839
// UART0 for Picoprobe debug
@@ -41,6 +42,7 @@
4142
int main(void) {
4243

4344
board_init();
45+
usb_serial_init();
4446
cdc_uart_init();
4547
tusb_init();
4648
probe_init();

src/usb_descriptors.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,7 @@
2424
*/
2525

2626
#include "tusb.h"
27+
#include "get_serial.h"
2728

2829

2930
//--------------------------------------------------------------------+
@@ -106,7 +107,7 @@ char const* string_desc_arr [] =
106107
(const char[]) { 0x09, 0x04 }, // 0: is supported language is English (0x0409)
107108
"Raspberry Pi", // 1: Manufacturer
108109
"Picoprobe", // 2: Product
109-
"123456", // 3: Serials, should use chip ID
110+
usb_serial, // 3: Serial, uses flash unique ID
110111
};
111112

112113
static uint16_t _desc_str[32];

0 commit comments

Comments
 (0)