Merge ChibiOS and LUFA descriptor support (#2362)
* Move lufa descriptor to protocol/usb_descriptor * Try to compile usb_descriptor on ChibiOS * Add lufa_utils for ChibiOS Lufa USB descriptors for ChibiOS * More lufa_util compatibility fixes * First compiling version of shared USB descriptor * Send the usb descriptors * Fix the CONSOLE output on ChibiOS * Add errors for unsupported interfaces * Enable support for vitual serial port USB descriptors * Implement virtual serial port for ChibiOS * Cleanup the lufa_utils Use the default lufa header files * Add raw hid support for ChibiOS This is completely untested * Enable midi compilation on ChibiOS * Move midi functionality out of lufa.c * Don't register sysex callback when not needed * ChibiOS compilation fixes * Update ChibiOS submodule * Fix the Midi USB descriptor It didn't work properly when both Midi and Virtual serial port was enabled. * Add MIDI support for ChibiOS * Fix USB descriptor strings on ChibiOS * Use serial usb driver for raw hid * Generalize the ChibiOS stream like drivers This makes the initialization much more simple and eliminates a lot of the code duplication. * Convert console output to chibios stream driver * Fixes for ChibiOS update * Update the ChibiOS contrib submodule To include the usb data toggle synchronization fixes * Fix duplicate reset enumeration on ChibiOS * Add missing include * Add number of endpoints check for ChibiOS * Enable serial USB driver on all keyboards * Add missing includes when API is enabled withot midi * Add another missing inlcude
This commit is contained in:
parent
63c16f4b63
commit
53ff8a31b6
38 changed files with 761 additions and 1237 deletions
|
@ -1,5 +1,5 @@
|
|||
//Copyright 20010 Alex Norman
|
||||
//writen by Alex Norman
|
||||
//writen by Alex Norman
|
||||
//
|
||||
//This file is part of avr-bytequeue.
|
||||
//
|
||||
|
@ -22,6 +22,7 @@
|
|||
//implementations of the typedef and these functions
|
||||
|
||||
#include "interrupt_setting.h"
|
||||
#if defined(__AVR__)
|
||||
#include <avr/interrupt.h>
|
||||
|
||||
interrupt_setting_t store_and_clear_interrupt(void) {
|
||||
|
@ -33,4 +34,16 @@ interrupt_setting_t store_and_clear_interrupt(void) {
|
|||
void restore_interrupt_setting(interrupt_setting_t setting) {
|
||||
SREG = setting;
|
||||
}
|
||||
#elif defined(__arm__)
|
||||
#include "ch.h"
|
||||
|
||||
interrupt_setting_t store_and_clear_interrupt(void) {
|
||||
chSysLock();
|
||||
return 0;
|
||||
}
|
||||
|
||||
void restore_interrupt_setting(interrupt_setting_t setting) {
|
||||
chSysUnlock();
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue