Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
A
arduino-pico
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Analytics
Analytics
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
xpstem
arduino-pico
Commits
d3c5039c
Commit
d3c5039c
authored
May 14, 2021
by
Earle F. Philhower, III
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Clean up USB includes and naming
parent
13f4be33
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
49 additions
and
48 deletions
+49
-48
cores/rp2040/RP2040USB.cpp
cores/rp2040/RP2040USB.cpp
+45
-43
cores/rp2040/main.cpp
cores/rp2040/main.cpp
+2
-3
libraries/Keyboard
libraries/Keyboard
+1
-1
libraries/Mouse
libraries/Mouse
+1
-1
No files found.
cores/rp2040/USB.cpp
→
cores/rp2040/
RP2040
USB.cpp
View file @
d3c5039c
...
@@ -21,28 +21,26 @@
...
@@ -21,28 +21,26 @@
#include <Arduino.h>
#include <Arduino.h>
#include "CoreMutex.h"
#include "CoreMutex.h"
#include "RP2040USB.h"
#include "tusb.h"
#include "tusb.h"
#include "class/hid/hid_device.h"
#include "class/hid/hid_device.h"
#include "class/audio/audio.h"
#include "class/audio/audio.h"
#include "class/midi/midi.h"
#include "class/midi/midi.h"
#include "pico/time.h"
#include "pico/time.h"
#include "pico/binary_info.h"
#include "pico/bootrom.h"
#include "hardware/irq.h"
#include "hardware/irq.h"
#include "pico/mutex.h"
#include "pico/mutex.h"
#include "hardware/watchdog.h"
#include "pico/unique_id.h"
#include "pico/unique_id.h"
// Weak function definitions for each type of endpoint
// Big, global USB mutex, shared with all USB devices to make sure we don't
extern
void
__USBInstallSerial
()
__attribute__
((
weak
));
// have multiple cores updating the TUSB state in parallel
extern
void
__USBInstallKeyboard
()
__attribute__
((
weak
));
mutex_t
__usb_mutex
;
extern
void
__USBInstallMouse
()
__attribute__
((
weak
));
extern
void
__USBInstallMIDI
()
__attribute__
((
weak
));
#define PICO_STDIO_USB_TASK_INTERVAL_US 1000
// USB processing will be a periodic timer task
#define PICO_STDIO_USB_LOW_PRIORITY_IRQ 31
#define USB_TASK_INTERVAL 1000
#define USB_TASK_IRQ 31
// USB VID/PID (note that PID can change depending on the add'l interfaces)
#define USBD_VID (0x2E8A) // Raspberry Pi
#define USBD_VID (0x2E8A) // Raspberry Pi
#ifdef SERIALUSB_PID
#ifdef SERIALUSB_PID
...
@@ -72,21 +70,10 @@ extern void __USBInstallMIDI() __attribute__((weak));
...
@@ -72,21 +70,10 @@ extern void __USBInstallMIDI() __attribute__((weak));
#define EPNUM_HID 0x83
#define EPNUM_HID 0x83
#define EPNUM_MIDI 0x01
#define EPNUM_MIDI 0x01
static
char
_idString
[
PICO_UNIQUE_BOARD_ID_SIZE_BYTES
*
2
+
1
];
static
const
char
*
const
usbd_desc_str
[]
=
{
const
uint8_t
*
tud_descriptor_device_cb
(
void
)
{
[
USBD_STR_0
]
=
""
,
[
USBD_STR_MANUF
]
=
"Raspberry Pi"
,
[
USBD_STR_PRODUCT
]
=
"PicoArduino"
,
[
USBD_STR_SERIAL
]
=
_idString
,
[
USBD_STR_CDC
]
=
"Board CDC"
,
};
extern
"C"
const
uint8_t
*
tud_descriptor_device_cb
(
void
)
{
static
tusb_desc_device_t
usbd_desc_device
=
{
static
tusb_desc_device_t
usbd_desc_device
=
{
.
bLength
=
sizeof
(
tusb_desc_device_t
),
.
bLength
=
sizeof
(
tusb_desc_device_t
),
.
bDescriptorType
=
TUSB_DESC_DEVICE
,
.
bDescriptorType
=
TUSB_DESC_DEVICE
,
...
@@ -124,7 +111,11 @@ extern "C" const uint8_t *tud_descriptor_device_cb(void) {
...
@@ -124,7 +111,11 @@ extern "C" const uint8_t *tud_descriptor_device_cb(void) {
return
(
const
uint8_t
*
)
&
usbd_desc_device
;
return
(
const
uint8_t
*
)
&
usbd_desc_device
;
}
}
int
__GetMouseReportID
()
{
int
__USBGetKeyboardReportID
()
{
return
1
;
}
int
__USBGetMouseReportID
()
{
return
__USBInstallKeyboard
?
2
:
1
;
return
__USBInstallKeyboard
?
2
:
1
;
}
}
...
@@ -160,7 +151,7 @@ static uint8_t *GetDescHIDReport(int *len) {
...
@@ -160,7 +151,7 @@ static uint8_t *GetDescHIDReport(int *len) {
// Invoked when received GET HID REPORT DESCRIPTOR
// Invoked when received GET HID REPORT DESCRIPTOR
// Application return pointer to descriptor
// Application return pointer to descriptor
// Descriptor contents must exist long enough for transfer to complete
// Descriptor contents must exist long enough for transfer to complete
extern
"C"
uint8_t
const
*
tud_hid_descriptor_report_cb
(
void
)
uint8_t
const
*
tud_hid_descriptor_report_cb
(
void
)
{
{
return
GetDescHIDReport
(
nullptr
);
return
GetDescHIDReport
(
nullptr
);
}
}
...
@@ -227,6 +218,28 @@ const uint16_t *tud_descriptor_string_cb(uint8_t index, uint16_t langid) {
...
@@ -227,6 +218,28 @@ const uint16_t *tud_descriptor_string_cb(uint8_t index, uint16_t langid) {
#define DESC_STR_MAX (20)
#define DESC_STR_MAX (20)
static
uint16_t
desc_str
[
DESC_STR_MAX
];
static
uint16_t
desc_str
[
DESC_STR_MAX
];
static
char
idString
[
PICO_UNIQUE_BOARD_ID_SIZE_BYTES
*
2
+
1
];
static
const
char
*
const
usbd_desc_str
[]
=
{
[
USBD_STR_0
]
=
""
,
[
USBD_STR_MANUF
]
=
"Raspberry Pi"
,
[
USBD_STR_PRODUCT
]
=
"PicoArduino"
,
[
USBD_STR_SERIAL
]
=
idString
,
[
USBD_STR_CDC
]
=
"Board CDC"
,
};
if
(
!
idString
[
0
])
{
// Get ID string into human readable serial number on the first pass
pico_unique_board_id_t
id
;
pico_get_unique_board_id
(
&
id
);
idString
[
0
]
=
0
;
for
(
auto
i
=
0
;
i
<
PICO_UNIQUE_BOARD_ID_SIZE_BYTES
;
i
++
)
{
char
hx
[
3
];
sprintf
(
hx
,
"%02X"
,
id
.
id
[
i
]);
strcat
(
idString
,
hx
);
}
}
uint8_t
len
;
uint8_t
len
;
if
(
index
==
0
)
{
if
(
index
==
0
)
{
desc_str
[
1
]
=
0x0409
;
// supported language is English
desc_str
[
1
]
=
0x0409
;
// supported language is English
...
@@ -247,9 +260,8 @@ const uint16_t *tud_descriptor_string_cb(uint8_t index, uint16_t langid) {
...
@@ -247,9 +260,8 @@ const uint16_t *tud_descriptor_string_cb(uint8_t index, uint16_t langid) {
return
desc_str
;
return
desc_str
;
}
}
mutex_t
__usb_mutex
;
static
void
low_priority_worker
_irq
()
{
static
void
usb
_irq
()
{
// if the mutex is already owned, then we are in user code
// if the mutex is already owned, then we are in user code
// in this file which will do a tud_task itself, so we'll just do nothing
// in this file which will do a tud_task itself, so we'll just do nothing
// until the next tick; we won't starve
// until the next tick; we won't starve
...
@@ -260,33 +272,23 @@ static void low_priority_worker_irq() {
...
@@ -260,33 +272,23 @@ static void low_priority_worker_irq() {
}
}
static
int64_t
timer_task
(
__unused
alarm_id_t
id
,
__unused
void
*
user_data
)
{
static
int64_t
timer_task
(
__unused
alarm_id_t
id
,
__unused
void
*
user_data
)
{
irq_set_pending
(
PICO_STDIO_USB_LOW_PRIORITY
_IRQ
);
irq_set_pending
(
USB_TASK
_IRQ
);
return
PICO_STDIO_USB_TASK_INTERVAL_US
;
return
USB_TASK_INTERVAL
;
}
}
void
__
StartUSB
()
{
void
__
USBStart
()
{
if
(
tusb_inited
())
{
if
(
tusb_inited
())
{
// Already called
// Already called
return
;
return
;
}
}
// Get ID string into human readable serial number
pico_unique_board_id_t
id
;
pico_get_unique_board_id
(
&
id
);
_idString
[
0
]
=
0
;
for
(
auto
i
=
0
;
i
<
PICO_UNIQUE_BOARD_ID_SIZE_BYTES
;
i
++
)
{
char
hx
[
3
];
sprintf
(
hx
,
"%02X"
,
id
.
id
[
i
]);
strcat
(
_idString
,
hx
);
}
mutex_init
(
&
__usb_mutex
);
mutex_init
(
&
__usb_mutex
);
tusb_init
();
tusb_init
();
irq_set_exclusive_handler
(
PICO_STDIO_USB_LOW_PRIORITY_IRQ
,
low_priority_worker
_irq
);
irq_set_exclusive_handler
(
USB_TASK_IRQ
,
usb
_irq
);
irq_set_enabled
(
PICO_STDIO_USB_LOW_PRIORITY
_IRQ
,
true
);
irq_set_enabled
(
USB_TASK
_IRQ
,
true
);
add_alarm_in_us
(
PICO_STDIO_USB_TASK_INTERVAL_US
,
timer_task
,
NULL
,
true
);
add_alarm_in_us
(
USB_TASK_INTERVAL
,
timer_task
,
NULL
,
true
);
}
}
...
...
cores/rp2040/main.cpp
View file @
d3c5039c
...
@@ -19,6 +19,7 @@
...
@@ -19,6 +19,7 @@
*/
*/
#include <Arduino.h>
#include <Arduino.h>
#include "RP2040USB.h"
#include <pico/stdlib.h>
#include <pico/stdlib.h>
#include <pico/multicore.h>
#include <pico/multicore.h>
...
@@ -52,8 +53,6 @@ static void main1() {
...
@@ -52,8 +53,6 @@ static void main1() {
}
}
}
}
extern
void
__StartUSB
();
extern
"C"
int
main
()
{
extern
"C"
int
main
()
{
#if F_CPU != 125000000
#if F_CPU != 125000000
set_sys_clock_khz
(
F_CPU
/
1000
,
true
);
set_sys_clock_khz
(
F_CPU
/
1000
,
true
);
...
@@ -61,7 +60,7 @@ extern "C" int main() {
...
@@ -61,7 +60,7 @@ extern "C" int main() {
mutex_init
(
&
_pioMutex
);
mutex_init
(
&
_pioMutex
);
initVariant
();
initVariant
();
__
StartUSB
();
__
USBStart
();
#ifndef DISABLE_USB_SERIAL
#ifndef DISABLE_USB_SERIAL
// Enable serial port for reset/upload always
// Enable serial port for reset/upload always
...
...
Keyboard
@
e8c1394e
Subproject commit
b29ed09525169dcbe2964eb332780a14f2c5f466
Subproject commit
e8c1394e693fbd43af900205ddbe195efa59244a
Mouse
@
1b39fd21
Subproject commit
7c824ec29c75dac6393d3fb18f0dd474bc270113
Subproject commit
1b39fd21e5c4ebeb9e7d575f3a75b1da255b28d4
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment