Skip to content

Commit 4cc33f8

Browse files
committed
Merge remote-tracking branch 'adafruit/master' into nrf_board_rename
2 parents 05ea9fd + 728622f commit 4cc33f8

File tree

7 files changed

+31
-18
lines changed

7 files changed

+31
-18
lines changed

.gitignore

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,6 @@
77
*.bin
88
*.map
99
*.hex
10-
!ports/nrf/**/bootloader/**/*.hex
1110
*.dis
1211
*.exe
1312

ports/nrf/boards/adafruit_nrf52840_s140_v6.ld

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
GNU linker script for NRF52840 w/S140 6.0.0 SoftDevice
2+
GNU linker script for NRF52840 w/S140 6.x.x SoftDevice
33

44
MEMORY MAP
55
------------------------------------------------------------------------
@@ -17,7 +17,7 @@
1717
0x00000000..0x00000FFF (4KB) Master Boot Record
1818
*/
1919

20-
/* Specify the memory areas (S140 6.0.0) */
20+
/* Specify the memory areas (S140 6.x.x) */
2121
MEMORY
2222
{
2323
FLASH (rx) : ORIGIN = 0x00000000, LENGTH = 0x100000

ports/nrf/boards/feather_nrf52840_express/mpconfigboard.mk

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ MCU_SERIES = m4
22
MCU_VARIANT = nrf52
33
MCU_SUB_VARIANT = nrf52840
44
SD ?= s140
5-
SOFTDEV_VERSION ?= 6.0.0
5+
SOFTDEV_VERSION ?= 6.1.0
66

77
BOOT_SETTING_ADDR = 0xFF000
88

ports/nrf/boards/pca10056/mpconfigboard.mk

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ MCU_SERIES = m4
22
MCU_VARIANT = nrf52
33
MCU_SUB_VARIANT = nrf52840
44
SD ?= s140
5-
SOFTDEV_VERSION ?= 6.0.0
5+
SOFTDEV_VERSION ?= 6.1.0
66

77
BOOT_SETTING_ADDR = 0xFF000
88

ports/nrf/drivers/bluetooth/download_ble_stack.sh

Lines changed: 8 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -35,18 +35,16 @@ function download_s132_nrf52_5_0_0
3535
cd -
3636
}
3737

38-
function download_s140_nrf52_6_0_0
38+
function download_s140_nrf52_6_1_0
3939
{
4040
echo ""
4141
echo "####################################"
42-
echo "### Downloading s140_nrf52_6.0.0 ###"
42+
echo "### Downloading s140_nrf52_6.1.0 ###"
4343
echo "####################################"
4444
echo ""
45-
46-
mkdir -p "${1}/s140_nrf52_6.0.0"
47-
cd "${1}/s140_nrf52_6.0.0"
48-
49-
wget https://www.nordicsemi.com/eng/nordic/download_resource/60624/20/49271410/116072
45+
mkdir -p "${1}/s140_nrf52_6.1.0"
46+
cd "${1}/s140_nrf52_6.1.0"
47+
wget https://www.nordicsemi.com/eng/nordic/download_resource/60624/25/88218841/116072
5048
mv 116072 temp.zip
5149
unzip -u temp.zip
5250
rm temp.zip
@@ -59,15 +57,15 @@ if [ $# -eq 0 ]; then
5957
echo "No Bluetooth LE stack defined, downloading all."
6058
download_s132_nrf52_2_0_1 "${SCRIPT_DIR}"
6159
download_s132_nrf52_5_0_0 "${SCRIPT_DIR}"
62-
download_s140_nrf52_6_0_0 "${SCRIPT_DIR}"
60+
download_s140_nrf52_6_1_0 "${SCRIPT_DIR}"
6361
else
6462
case $1 in
6563
"s132_nrf52_2_0_1" )
6664
download_s132_nrf52_2_0_1 "${SCRIPT_DIR}" ;;
6765
"s132_nrf52_5_0_0" )
6866
download_s132_nrf52_5_0_0 "${SCRIPT_DIR}" ;;
69-
"s140_nrf52_6_0_0" )
70-
download_s140_nrf52_6_0_0 "${SCRIPT_DIR}" ;;
67+
"s140_nrf52_6_1_0" )
68+
download_s140_nrf52_6_1_0 "${SCRIPT_DIR}" ;;
7169
esac
7270
fi
7371

ports/nrf/usb/usb.c

Lines changed: 16 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -58,7 +58,7 @@ void usb_init(void) {
5858

5959
sd_power_usbregstatus_get(&usb_reg);
6060
}else
61-
#else
61+
#endif
6262
{
6363
// Power module init
6464
const nrfx_power_config_t pwr_cfg = { 0 };
@@ -72,7 +72,6 @@ void usb_init(void) {
7272

7373
usb_reg = NRF_POWER->USBREGSTATUS;
7474
}
75-
#endif
7675

7776
if ( usb_reg & POWER_USBREGSTATUS_VBUSDETECT_Msk ) {
7877
tusb_hal_nrf_power_event(NRFX_POWER_USB_EVT_DETECTED);
@@ -82,6 +81,21 @@ void usb_init(void) {
8281
tusb_hal_nrf_power_event(NRFX_POWER_USB_EVT_READY);
8382
}
8483

84+
// create serial number based on device unique id
85+
extern uint16_t usb_desc_str_serial[1 + 16];
86+
87+
char nibble_to_hex[16] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};
88+
89+
for (int i = 0; i < 2; i++) {
90+
for (int j = 0; j < 8; j++) {
91+
uint8_t nibble = (NRF_FICR->DEVICEID[i] >> j * 4) & 0xf;
92+
93+
// Invert order since it is LE, +1 for skipping descriptor header
94+
uint8_t const idx = (15 - (i * 8 + j)) + 1;
95+
usb_desc_str_serial[idx] = nibble_to_hex[nibble];
96+
}
97+
}
98+
8599
tusb_init();
86100

87101
#if MICROPY_KBD_EXCEPTION

ports/nrf/usb/usb_desc.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -78,6 +78,8 @@ enum {
7878
// STRING DESCRIPTORS
7979
//--------------------------------------------------------------------+
8080

81+
uint16_t usb_desc_str_serial[1+16] = { TUD_DESC_STR_HEADER(16) };
82+
8183
// array of pointer to string descriptors
8284
uint16_t const * const string_desc_arr [] =
8385
{
@@ -91,7 +93,7 @@ uint16_t const * const string_desc_arr [] =
9193
TUD_DESC_STRCONV('C','i','r','c','u','i','t','P','y',' ','n','R','F','5','2'),
9294

9395
// 3 Serials TODO use chip ID
94-
TUD_DESC_STRCONV('1', '2', '3', '4', '5'),
96+
usb_desc_str_serial,
9597

9698
// 4 CDC Interface
9799
TUD_DESC_STRCONV('C','i','r','c','u','i','t','P','y',' ','S','e','r','i','a','l'),

0 commit comments

Comments
 (0)