Skip to content

Commit 9622b4f

Browse files
authored
Merge branch 'adafruit:master' into nrf52840-bboard
2 parents 2e59aa3 + 80fca98 commit 9622b4f

File tree

8 files changed

+104
-5
lines changed

8 files changed

+104
-5
lines changed

.github/workflows/githubci.yml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -36,6 +36,7 @@ jobs:
3636
- 'ebyte_e73_tbb'
3737
- 'electronut_labs_papyr'
3838
- 'ikigaisense_vita'
39+
- 'm60_keyboard'
3940
- 'mdk_nrf52840_dongle'
4041
- 'nice_nano'
4142
- 'nrf52840_m2'

changelog.md

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,9 @@
11
# Adafruit nRF52 Bootloader Changelog
22

3+
## 0.6.0 - 2021.06.19
4+
5+
- Update tinyusb to latest to fix the race condition with control transfer, which could cause failed to connect to DFU Serial occasionally.
6+
37
## 0.5.1 - 2021.06.02
48

59
- more boards support

lib/sdk11/components/ble/ble_services/ble_dfu/ble_dfu.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -463,7 +463,7 @@ uint32_t ble_dfu_init(ble_dfu_t * p_dfu, ble_dfu_init_t * p_dfu_init)
463463

464464
p_dfu->conn_handle = BLE_CONN_HANDLE_INVALID;
465465

466-
ble_uuid_t service_uuid;
466+
ble_uuid_t service_uuid = {0};
467467
uint32_t err_code;
468468

469469
const ble_uuid128_t base_uuid128 =

lib/tinyusb

Submodule tinyusb updated 435 files

src/boards/m60_keyboard/board.h

Lines changed: 71 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,71 @@
1+
/*
2+
* The MIT License (MIT)
3+
*
4+
* Copyright (c) 2020 Yihui Xiong for Makerdiary
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+
#ifndef _MAKERDIARY_M60_KEYBOARD_H_
26+
#define _MAKERDIARY_M60_KEYBOARD_H_
27+
28+
#define _PINNUM(port, pin) ((port)*32 + (pin))
29+
30+
/*------------------------------------------------------------------*/
31+
/* LED
32+
*------------------------------------------------------------------*/
33+
#define LEDS_NUMBER 1
34+
#define LED_PRIMARY_PIN _PINNUM(0, 30) // Red
35+
#define LED_STATE_ON 0
36+
37+
#define LED_RGB_RED_PIN _PINNUM(0, 30)
38+
#define LED_RGB_GREEN_PIN _PINNUM(0, 29)
39+
#define LED_RGB_BLUE_PIN _PINNUM(0, 31)
40+
#define BOARD_RGB_BRIGHTNESS 0x404040
41+
/*------------------------------------------------------------------*/
42+
/* BUTTON
43+
*------------------------------------------------------------------*/
44+
#define BUTTONS_NUMBER 2
45+
#define BUTTON_1 _PINNUM(0, 27)
46+
#define BUTTON_2 _PINNUM(1, 7)
47+
#define BUTTON_PULL NRF_GPIO_PIN_PULLUP
48+
49+
//--------------------------------------------------------------------+
50+
// BLE OTA
51+
//--------------------------------------------------------------------+
52+
#define BLEDIS_MANUFACTURER "Makerdiary"
53+
#define BLEDIS_MODEL "M60 Mechanical Keyboard"
54+
55+
//--------------------------------------------------------------------+
56+
// USB
57+
//--------------------------------------------------------------------+
58+
#define USB_DESC_VID 0x2886
59+
#define USB_DESC_UF2_PID 0xF00F
60+
#define USB_DESC_CDC_ONLY_PID 0xF00F
61+
62+
//--------------------------------------------------------------------+
63+
// UF2
64+
//--------------------------------------------------------------------+
65+
#define UF2_PRODUCT_NAME "MakerDiary M60 Mechanical Keyboard"
66+
#define UF2_VOLUME_LABEL "M60KEYBOARD"
67+
#define UF2_BOARD_ID "M60KEYBOARD"
68+
#define UF2_INDEX_URL "https://wiki.makerdiary.com/m60/"
69+
70+
71+
#endif /* _MAKERDIARY_M60_KEYBOARD_H_ */

src/boards/m60_keyboard/board.mk

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
MCU_SUB_VARIANT = nrf52840
2+
USE_NFCT = yes

src/boards/m60_keyboard/pinconfig.c

Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
#include "boards.h"
2+
#include "uf2/configkeys.h"
3+
4+
__attribute__((used, section(".bootloaderConfig")))
5+
const uint32_t bootloaderConfig[] =
6+
{
7+
/* CF2 START */
8+
CFG_MAGIC0, CFG_MAGIC1, // magic
9+
5, 100, // used entries, total entries
10+
11+
204, 0x100000, // FLASH_BYTES = 0x100000
12+
205, 0x40000, // RAM_BYTES = 0x40000
13+
208, (USB_DESC_VID << 16) | USB_DESC_UF2_PID, // BOOTLOADER_BOARD_ID = USB VID+PID, used for verification when updating bootloader via uf2
14+
209, 0xada52840, // UF2_FAMILY = 0xada52840
15+
210, 0x20, // PINS_PORT_SIZE = PA_32
16+
17+
0, 0, 0, 0, 0, 0, 0, 0
18+
/* CF2 END */
19+
};

src/main.c

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -414,14 +414,16 @@ uint32_t proc_ble(void)
414414
__ALIGN(4) uint8_t ev_buf[ BLE_EVT_LEN_MAX(BLEGATT_ATT_MTU_MAX) ];
415415
uint16_t ev_len = BLE_EVT_LEN_MAX(BLEGATT_ATT_MTU_MAX);
416416

417+
// Init header
418+
ble_evt_t* evt = (ble_evt_t*) ev_buf;
419+
evt->header.evt_id = BLE_EVT_INVALID;
420+
417421
// Get BLE Event
418422
uint32_t err = sd_ble_evt_get(ev_buf, &ev_len);
419423

420424
// Handle valid event, ignore error
421425
if( NRF_SUCCESS == err)
422426
{
423-
ble_evt_t* evt = (ble_evt_t*) ev_buf;
424-
425427
switch (evt->header.evt_id)
426428
{
427429
case BLE_GAP_EVT_CONNECTED:
@@ -448,7 +450,7 @@ uint32_t proc_ble(void)
448450
// process SOC event from SD
449451
uint32_t proc_soc(void)
450452
{
451-
uint32_t soc_evt;
453+
uint32_t soc_evt = 0;
452454
uint32_t err = sd_evt_get(&soc_evt);
453455

454456
if (NRF_SUCCESS == err)

0 commit comments

Comments
 (0)