@ -49,7 +49,7 @@
# endif
# endif
# include "suspend.h"
# include "suspend.h"
# include " descriptor.h"
# include " usb_ descriptor.h"
# include "lufa.h"
# include "lufa.h"
# include "quantum.h"
# include "quantum.h"
# include <util/atomic.h>
# include <util/atomic.h>
@ -83,7 +83,7 @@
# endif
# endif
# ifdef MIDI_ENABLE
# ifdef MIDI_ENABLE
# include " sysex_tools .h"
# include " qmk_midi .h"
# endif
# endif
# ifdef RAW_ENABLE
# ifdef RAW_ENABLE
@ -97,12 +97,6 @@ static uint8_t keyboard_led_stats = 0;
static report_keyboard_t keyboard_report_sent ;
static report_keyboard_t keyboard_report_sent ;
# ifdef MIDI_ENABLE
static void usb_send_func ( MidiDevice * device , uint16_t cnt , uint8_t byte0 , uint8_t byte1 , uint8_t byte2 ) ;
static void usb_get_midi ( MidiDevice * device ) ;
static void midi_usb_init ( MidiDevice * device ) ;
# endif
/* Host driver */
/* Host driver */
static uint8_t keyboard_leds ( void ) ;
static uint8_t keyboard_leds ( void ) ;
static void send_keyboard ( report_keyboard_t * report ) ;
static void send_keyboard ( report_keyboard_t * report ) ;
@ -115,48 +109,8 @@ host_driver_t lufa_driver = {
send_mouse ,
send_mouse ,
send_system ,
send_system ,
send_consumer ,
send_consumer ,
# ifdef MIDI_ENABLE
usb_send_func ,
usb_get_midi ,
midi_usb_init
# endif
} ;
/*******************************************************************************
* MIDI
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# ifdef MIDI_ENABLE
USB_ClassInfo_MIDI_Device_t USB_MIDI_Interface =
{
. Config =
{
. StreamingInterfaceNumber = AS_INTERFACE ,
. DataINEndpoint =
{
. Address = MIDI_STREAM_IN_EPADDR ,
. Size = MIDI_STREAM_EPSIZE ,
. Banks = 1 ,
} ,
. DataOUTEndpoint =
{
. Address = MIDI_STREAM_OUT_EPADDR ,
. Size = MIDI_STREAM_EPSIZE ,
. Banks = 1 ,
} ,
} ,
} ;
} ;
# define SYSEX_START_OR_CONT 0x40
# define SYSEX_ENDS_IN_1 0x50
# define SYSEX_ENDS_IN_2 0x60
# define SYSEX_ENDS_IN_3 0x70
# define SYS_COMMON_1 0x50
# define SYS_COMMON_2 0x20
# define SYS_COMMON_3 0x30
# endif
# ifdef VIRTSER_ENABLE
# ifdef VIRTSER_ENABLE
USB_ClassInfo_CDC_Device_t cdc_device =
USB_ClassInfo_CDC_Device_t cdc_device =
{
{
@ -853,170 +807,32 @@ int8_t sendchar(uint8_t c)
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# ifdef MIDI_ENABLE
# ifdef MIDI_ENABLE
static void usb_send_func ( MidiDevice * device , uint16_t cnt , uint8_t byte0 , uint8_t byte1 , uint8_t byte2 ) {
USB_ClassInfo_MIDI_Device_t USB_MIDI_Interface =
MIDI_EventPacket_t event ;
event . Data1 = byte0 ;
event . Data2 = byte1 ;
event . Data3 = byte2 ;
uint8_t cable = 0 ;
// Endpoint_SelectEndpoint(MIDI_STREAM_IN_EPNUM);
//if the length is undefined we assume it is a SYSEX message
if ( midi_packet_length ( byte0 ) = = UNDEFINED ) {
switch ( cnt ) {
case 3 :
if ( byte2 = = SYSEX_END )
event . Event = MIDI_EVENT ( cable , SYSEX_ENDS_IN_3 ) ;
else
event . Event = MIDI_EVENT ( cable , SYSEX_START_OR_CONT ) ;
break ;
case 2 :
if ( byte1 = = SYSEX_END )
event . Event = MIDI_EVENT ( cable , SYSEX_ENDS_IN_2 ) ;
else
event . Event = MIDI_EVENT ( cable , SYSEX_START_OR_CONT ) ;
break ;
case 1 :
if ( byte0 = = SYSEX_END )
event . Event = MIDI_EVENT ( cable , SYSEX_ENDS_IN_1 ) ;
else
event . Event = MIDI_EVENT ( cable , SYSEX_START_OR_CONT ) ;
break ;
default :
return ; //invalid cnt
}
} else {
//deal with 'system common' messages
//TODO are there any more?
switch ( byte0 & 0xF0 ) {
case MIDI_SONGPOSITION :
event . Event = MIDI_EVENT ( cable , SYS_COMMON_3 ) ;
break ;
case MIDI_SONGSELECT :
case MIDI_TC_QUARTERFRAME :
event . Event = MIDI_EVENT ( cable , SYS_COMMON_2 ) ;
break ;
default :
event . Event = MIDI_EVENT ( cable , byte0 ) ;
break ;
}
}
// Endpoint_Write_Stream_LE(&event, sizeof(event), NULL);
// Endpoint_ClearIN();
MIDI_Device_SendEventPacket ( & USB_MIDI_Interface , & event ) ;
MIDI_Device_Flush ( & USB_MIDI_Interface ) ;
MIDI_Device_USBTask ( & USB_MIDI_Interface ) ;
USB_USBTask ( ) ;
}
static void usb_get_midi ( MidiDevice * device ) {
MIDI_EventPacket_t event ;
while ( MIDI_Device_ReceiveEventPacket ( & USB_MIDI_Interface , & event ) ) {
midi_packet_length_t length = midi_packet_length ( event . Data1 ) ;
uint8_t input [ 3 ] ;
input [ 0 ] = event . Data1 ;
input [ 1 ] = event . Data2 ;
input [ 2 ] = event . Data3 ;
if ( length = = UNDEFINED ) {
//sysex
if ( event . Event = = MIDI_EVENT ( 0 , SYSEX_START_OR_CONT ) | | event . Event = = MIDI_EVENT ( 0 , SYSEX_ENDS_IN_3 ) ) {
length = 3 ;
} else if ( event . Event = = MIDI_EVENT ( 0 , SYSEX_ENDS_IN_2 ) ) {
length = 2 ;
} else if ( event . Event = = MIDI_EVENT ( 0 , SYSEX_ENDS_IN_1 ) ) {
length = 1 ;
} else {
//XXX what to do?
}
}
//pass the data to the device input function
if ( length ! = UNDEFINED )
midi_device_input ( device , length , input ) ;
}
MIDI_Device_USBTask ( & USB_MIDI_Interface ) ;
USB_USBTask ( ) ;
}
static void midi_usb_init ( MidiDevice * device ) {
midi_device_init ( device ) ;
midi_device_set_send_func ( device , usb_send_func ) ;
midi_device_set_pre_input_process_func ( device , usb_get_midi ) ;
// SetupHardware();
sei ( ) ;
}
void MIDI_Task ( void )
{
{
. Config =
/* Device must be connected and configured for the task to run */
dprint ( " in MIDI_TASK \n " ) ;
if ( USB_DeviceState ! = DEVICE_STATE_Configured )
return ;
dprint ( " continuing in MIDI_TASK \n " ) ;
Endpoint_SelectEndpoint ( MIDI_STREAM_IN_EPADDR ) ;
if ( Endpoint_IsINReady ( ) )
{
{
. StreamingInterfaceNumber = AS_INTERFACE ,
dprint ( " Endpoint is ready \n " ) ;
. DataINEndpoint =
uint8_t MIDICommand = 0 ;
uint8_t MIDIPitch ;
/* Get board button status - if pressed use channel 10 (percussion), otherwise use channel 1 */
uint8_t Channel = MIDI_CHANNEL ( 1 ) ;
MIDICommand = MIDI_COMMAND_NOTE_ON ;
MIDIPitch = 0x3E ;
/* Check if a MIDI command is to be sent */
if ( MIDICommand )
{
{
dprint ( " Command exists \n " ) ;
. Address = MIDI_STREAM_IN_EPADDR ,
MIDI_EventPacket_t MIDIEvent = ( MIDI_EventPacket_t )
. Size = MIDI_STREAM_EPSIZE ,
. Banks = 1 ,
} ,
. DataOUTEndpoint =
{
{
. Event = MIDI_EVENT ( 0 , MIDICommand ) ,
. Address = MIDI_STREAM_OUT_EPADDR ,
. Size = MIDI_STREAM_EPSIZE ,
. Data1 = MIDICommand | Channel ,
. Banks = 1 ,
. Data2 = MIDIPitch ,
} ,
. Data3 = MIDI_STANDARD_VELOCITY ,
} ,
} ;
} ;
/* Write the MIDI event packet to the endpoint */
void send_midi_packet ( MIDI_EventPacket_t * event ) {
Endpoint_Write_Stream_LE ( & MIDIEvent , sizeof ( MIDIEvent ) , NULL ) ;
MIDI_Device_SendEventPacket ( & USB_MIDI_Interface , event ) ;
/* Send the data in the endpoint to the host */
Endpoint_ClearIN ( ) ;
}
}
}
bool recv_midi_packet ( MIDI_EventPacket_t * const event ) {
/* Select the MIDI OUT stream */
return MIDI_Device_ReceiveEventPacket ( & USB_MIDI_Interface , event ) ;
Endpoint_SelectEndpoint ( MIDI_STREAM_OUT_EPADDR ) ;
/* Check if a MIDI command has been received */
if ( Endpoint_IsOUTReceived ( ) )
{
MIDI_EventPacket_t MIDIEvent ;
/* Read the MIDI event packet from the endpoint */
Endpoint_Read_Stream_LE ( & MIDIEvent , sizeof ( MIDIEvent ) , NULL ) ;
/* If the endpoint is now empty, clear the bank */
if ( ! ( Endpoint_BytesInEndpoint ( ) ) )
{
/* Clear the endpoint ready for new packet */
Endpoint_ClearOUT ( ) ;
}
}
}
}
# endif
# endif
@ -1105,26 +921,6 @@ static void setup_usb(void)
print_set_sendchar ( sendchar ) ;
print_set_sendchar ( sendchar ) ;
}
}
# ifdef MIDI_ENABLE
void fallthrough_callback ( MidiDevice * device ,
uint16_t cnt , uint8_t byte0 , uint8_t byte1 , uint8_t byte2 ) ;
void cc_callback ( MidiDevice * device ,
uint8_t chan , uint8_t num , uint8_t val ) ;
void sysex_callback ( MidiDevice * device ,
uint16_t start , uint8_t length , uint8_t * data ) ;
void setup_midi ( void )
{
# ifdef MIDI_ADVANCED
midi_init ( ) ;
# endif
midi_device_init ( & midi_device ) ;
midi_device_set_send_func ( & midi_device , usb_send_func ) ;
midi_device_set_pre_input_process_func ( & midi_device , usb_get_midi ) ;
}
# endif
int main ( void ) __attribute__ ( ( weak ) ) ;
int main ( void ) __attribute__ ( ( weak ) ) ;
int main ( void )
int main ( void )
{
{
@ -1137,18 +933,6 @@ int main(void)
setup_usb ( ) ;
setup_usb ( ) ;
sei ( ) ;
sei ( ) ;
# ifdef MIDI_ENABLE
midi_register_fallthrough_callback ( & midi_device , fallthrough_callback ) ;
midi_register_cc_callback ( & midi_device , cc_callback ) ;
midi_register_sysex_callback ( & midi_device , sysex_callback ) ;
// init_notes();
// midi_send_cc(&midi_device, 0, 1, 2);
// midi_send_cc(&midi_device, 15, 1, 0);
// midi_send_noteon(&midi_device, 0, 64, 127);
// midi_send_noteoff(&midi_device, 0, 64, 127);
# endif
# if defined(MODULE_ADAFRUIT_EZKEY) || defined(MODULE_RN42)
# if defined(MODULE_ADAFRUIT_EZKEY) || defined(MODULE_RN42)
serial_init ( ) ;
serial_init ( ) ;
# endif
# endif
@ -1193,10 +977,7 @@ int main(void)
keyboard_task ( ) ;
keyboard_task ( ) ;
# ifdef MIDI_ENABLE
# ifdef MIDI_ENABLE
midi_device_process ( & midi_device ) ;
MIDI_Device_USBTask ( & USB_MIDI_Interface ) ;
# ifdef MIDI_ADVANCED
midi_task ( ) ;
# endif
# endif
# endif
# if defined(RGBLIGHT_ANIMATIONS) & defined(RGBLIGHT_ENABLE)
# if defined(RGBLIGHT_ANIMATIONS) & defined(RGBLIGHT_ENABLE)
@ -1223,71 +1004,10 @@ int main(void)
}
}
}
}
# ifdef MIDI_ENABLE
uint16_t CALLBACK_USB_GetDescriptor ( const uint16_t wValue ,
void fallthrough_callback ( MidiDevice * device ,
const uint16_t wIndex ,
uint16_t cnt , uint8_t byte0 , uint8_t byte1 , uint8_t byte2 ) {
const void * * const DescriptorAddress )
{
# ifdef AUDIO_ENABLE
return get_usb_descriptor ( wValue , wIndex , DescriptorAddress ) ;
if ( cnt = = 3 ) {
switch ( byte0 & 0xF0 ) {
case MIDI_NOTEON :
play_note ( ( ( double ) 261.6 ) * pow ( 2.0 , - 4.0 ) * pow ( 2.0 , ( byte1 & 0x7F ) / 12.0 ) , ( byte2 & 0x7F ) / 8 ) ;
break ;
case MIDI_NOTEOFF :
stop_note ( ( ( double ) 261.6 ) * pow ( 2.0 , - 4.0 ) * pow ( 2.0 , ( byte1 & 0x7F ) / 12.0 ) ) ;
break ;
}
}
if ( byte0 = = MIDI_STOP ) {
stop_all_notes ( ) ;
}
# endif
}
void cc_callback ( MidiDevice * device ,
uint8_t chan , uint8_t num , uint8_t val ) {
//sending it back on the next channel
// midi_send_cc(device, (chan + 1) % 16, num, val);
}
# ifdef API_SYSEX_ENABLE
uint8_t midi_buffer [ MIDI_SYSEX_BUFFER ] = { 0 } ;
# endif
void sysex_callback ( MidiDevice * device , uint16_t start , uint8_t length , uint8_t * data ) {
# ifdef API_SYSEX_ENABLE
// SEND_STRING("\n");
// send_word(start);
// SEND_STRING(": ");
// Don't store the header
int16_t pos = start - 4 ;
for ( uint8_t place = 0 ; place < length ; place + + ) {
// send_byte(*data);
if ( pos > = 0 ) {
if ( * data = = 0xF7 ) {
// SEND_STRING("\nRD: ");
// for (uint8_t i = 0; i < start + place + 1; i++){
// send_byte(midi_buffer[i]);
// SEND_STRING(" ");
// }
const unsigned decoded_length = sysex_decoded_length ( pos ) ;
uint8_t decoded [ API_SYSEX_MAX_SIZE ] ;
sysex_decode ( decoded , midi_buffer , pos ) ;
process_api ( decoded_length , decoded ) ;
return ;
}
else if ( pos > = MIDI_SYSEX_BUFFER ) {
return ;
}
midi_buffer [ pos ] = * data ;
}
// SEND_STRING(" ");
data + + ;
pos + + ;
}
# endif
}
}
# endif