OSC-CV Converter

Dependencies:   Bonjour OSCReceiver TextLCD mbed mbed-rpc BurstSPI DebouncedInterrupt FastIO MIDI OSC OSCtoCV ClockControl

OSC to CV Converter

http://gtbts.tumblr.com/post/125663817741/osc-to-cv-converter-ver2-mbed-osctocv

/media/uploads/casiotone401/tumblr_nsg7y4pkfg1qlle9fo1_540.png

Committer:
casiotone401
Date:
Sat Jan 09 10:58:45 2016 +0000
Revision:
20:a44f4a024902
Parent:
19:467f98c51e2d
Child:
21:2273c3676f1b
separate source

Who changed what in which revision?

UserRevisionLine numberNew contents of line
casiotone401 0:a4d93cd4c30d 1 //-------------------------------------------------------------
casiotone401 20:a44f4a024902 2 // TI DAC8568 OSCtoCV Converter
casiotone401 0:a4d93cd4c30d 3 //
casiotone401 0:a4d93cd4c30d 4 // DAC8568 16bit Octal DAC http://www.ti.com/product/dac8568
casiotone401 0:a4d93cd4c30d 5 //
casiotone401 0:a4d93cd4c30d 6 // referred to
casiotone401 0:a4d93cd4c30d 7 // xshige's OSCReceiver
casiotone401 0:a4d93cd4c30d 8 // http://mbed.org/users/xshige/programs/OSCReceiver/
casiotone401 0:a4d93cd4c30d 9 // radiojunkbox's OSC-CV_Example
casiotone401 0:a4d93cd4c30d 10 // http://mbed.org/users/radiojunkbox/code/KAMUI_OSC-CV_Example/
casiotone401 0:a4d93cd4c30d 11 // Robin Price's Homebrew midi-cv box
casiotone401 0:a4d93cd4c30d 12 // http://crx091081gb.net/?p=69
casiotone401 0:a4d93cd4c30d 13 // Masahiro Hattori's TextLCD Module Functions
casiotone401 0:a4d93cd4c30d 14 // http://www.eleclabo.com/denshi/device/lcd1602/gcram.html
casiotone401 0:a4d93cd4c30d 15 // Dirk-Willem van Gulik's BonjourLib
casiotone401 0:a4d93cd4c30d 16 // http://mbed.org/users/dirkx/code/BonjourLib/file/bb6472f455e8/services/mDNS
casiotone401 0:a4d93cd4c30d 17 //
casiotone401 0:a4d93cd4c30d 18 // Released under the MIT License: http://mbed.org/license/mit
casiotone401 0:a4d93cd4c30d 19 //-------------------------------------------------------------
casiotone401 0:a4d93cd4c30d 20
casiotone401 0:a4d93cd4c30d 21 #pragma O3
casiotone401 0:a4d93cd4c30d 22 #pragma Otime
casiotone401 0:a4d93cd4c30d 23
casiotone401 0:a4d93cd4c30d 24 #include "mbed.h"
casiotone401 15:3e4bc47d6a39 25 #include "FastIO.h"
casiotone401 20:a44f4a024902 26 //#include "FastAnalogIn.h"
casiotone401 15:3e4bc47d6a39 27 #include "DebouncedInterrupt.h"
casiotone401 0:a4d93cd4c30d 28 #include "TextLCD.h" //edit "writeCommand" "writeData" protected -> public
casiotone401 0:a4d93cd4c30d 29 #include "EthernetNetIf.h"
casiotone401 0:a4d93cd4c30d 30 #include "HTTPServer.h"
casiotone401 0:a4d93cd4c30d 31 #include "mDNSResponder.h" // mDNS response to announce oneselve
casiotone401 0:a4d93cd4c30d 32 #include "UDPSocket.h"
casiotone401 0:a4d93cd4c30d 33 #include "OSCReceiver.h"
casiotone401 15:3e4bc47d6a39 34 #include "mbedOSC.h"
casiotone401 15:3e4bc47d6a39 35 #include "MIDI.h"
casiotone401 20:a44f4a024902 36 #include "OSCtoCV.h"
casiotone401 20:a44f4a024902 37 #include "OSCtoCV_Sequencer.h"
casiotone401 20:a44f4a024902 38 #include "OSCtoCV_GateSequencer.h"
casiotone401 20:a44f4a024902 39 #include "OSCtoCV_Euclidean.h"
casiotone401 20:a44f4a024902 40
casiotone401 0:a4d93cd4c30d 41 #include <stdlib.h>
casiotone401 0:a4d93cd4c30d 42 #include <ctype.h>
casiotone401 1:fd4f70088311 43 #include <math.h>
casiotone401 0:a4d93cd4c30d 44
casiotone401 0:a4d93cd4c30d 45 //-------------------------------------------------------------
casiotone401 20:a44f4a024902 46 // Macros
casiotone401 0:a4d93cd4c30d 47
casiotone401 14:977f3c5a4b4e 48 #define MODE_Calb 0 // Calibration (for VCO Tuning)
casiotone401 15:3e4bc47d6a39 49 #define MODE_OSC 1 // Mode OSCtoCV
casiotone401 15:3e4bc47d6a39 50 #define MODE_SEQ 2 // Mode Shift Sequencer
casiotone401 15:3e4bc47d6a39 51 #define MODE_185 3 // Mode M185 Sequencer
casiotone401 15:3e4bc47d6a39 52 #define MODE_EUC 4 // Mode Euclidean Sequencer
casiotone401 15:3e4bc47d6a39 53
casiotone401 15:3e4bc47d6a39 54 #define MODE_TOTAL 5 // Modes
casiotone401 0:a4d93cd4c30d 55
casiotone401 0:a4d93cd4c30d 56 //-------------------------------------------------------------
casiotone401 0:a4d93cd4c30d 57 // Functions
casiotone401 0:a4d93cd4c30d 58
casiotone401 15:3e4bc47d6a39 59 void InitOSCCV(void);
casiotone401 4:b9f5ae574447 60 inline void NetPoll(void);
casiotone401 20:a44f4a024902 61 void CalibrationCV(void);
casiotone401 15:3e4bc47d6a39 62 inline void SetCV(void);
casiotone401 15:3e4bc47d6a39 63 inline int CheckBPM(void);
casiotone401 20:a44f4a024902 64 void CheckModeSW(void);
casiotone401 15:3e4bc47d6a39 65 inline void LCD();
casiotone401 0:a4d93cd4c30d 66 void WriteCustomChar(unsigned char, unsigned char*);
casiotone401 0:a4d93cd4c30d 67 int SetupEthNetIf(void);
casiotone401 4:b9f5ae574447 68 inline void onUDPSocketEvent(UDPSocketEvent);
casiotone401 20:a44f4a024902 69
casiotone401 0:a4d93cd4c30d 70
casiotone401 0:a4d93cd4c30d 71 //-------------------------------------------------------------
casiotone401 20:a44f4a024902 72 // Global Variables
casiotone401 0:a4d93cd4c30d 73
casiotone401 0:a4d93cd4c30d 74 // CV Meter Custom Character
casiotone401 0:a4d93cd4c30d 75 unsigned char str1[8] = {0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x1F};
casiotone401 0:a4d93cd4c30d 76 unsigned char str2[8] = {0x00,0x00,0x00,0x00,0x00,0x00,0x1F,0x1F};
casiotone401 0:a4d93cd4c30d 77 unsigned char str3[8] = {0x00,0x00,0x00,0x00,0x00,0x1F,0x1F,0x1F};
casiotone401 0:a4d93cd4c30d 78 unsigned char str4[8] = {0x00,0x00,0x00,0x00,0x1F,0x1F,0x1F,0x1F};
casiotone401 0:a4d93cd4c30d 79 unsigned char str5[8] = {0x00,0x00,0x00,0x1F,0x1F,0x1F,0x1F,0x1F};
casiotone401 0:a4d93cd4c30d 80 unsigned char str6[8] = {0x00,0x00,0x1F,0x1F,0x1F,0x1F,0x1F,0x1F};
casiotone401 0:a4d93cd4c30d 81 unsigned char str7[8] = {0x00,0x1F,0x1F,0x1F,0x1F,0x1F,0x1F,0x1F};
casiotone401 0:a4d93cd4c30d 82 unsigned char str8[8] = {0x1F,0x1F,0x1F,0x1F,0x1F,0x1F,0x1F,0x1F};
casiotone401 0:a4d93cd4c30d 83
casiotone401 20:a44f4a024902 84 // OSCtoCV Converter Mode
casiotone401 20:a44f4a024902 85 int gMode;
casiotone401 15:3e4bc47d6a39 86
casiotone401 20:a44f4a024902 87 // UDP Socket
casiotone401 20:a44f4a024902 88 UDPSocket gUdp;
casiotone401 15:3e4bc47d6a39 89
casiotone401 0:a4d93cd4c30d 90 //-------------------------------------------------------------
casiotone401 0:a4d93cd4c30d 91 // main
casiotone401 0:a4d93cd4c30d 92
casiotone401 0:a4d93cd4c30d 93 int main()
casiotone401 0:a4d93cd4c30d 94 {
casiotone401 7:a04f8378662e 95 float pot, _pot;
casiotone401 15:3e4bc47d6a39 96 int bpm;
casiotone401 20:a44f4a024902 97
casiotone401 20:a44f4a024902 98 InitOSCCV();
casiotone401 14:977f3c5a4b4e 99
casiotone401 20:a44f4a024902 100 InitEuclideanSeq(); // Init Euclidean Sequencer
casiotone401 15:3e4bc47d6a39 101
casiotone401 15:3e4bc47d6a39 102 gCtrl[3] = _pot = pot = gMode = 0;
casiotone401 15:3e4bc47d6a39 103 gGlide = gAIN.read();
casiotone401 15:3e4bc47d6a39 104
casiotone401 15:3e4bc47d6a39 105 LCD();
casiotone401 15:3e4bc47d6a39 106 gLCD.locate( 0, 1 );
casiotone401 15:3e4bc47d6a39 107 gLCD.printf("12345678 G>>%3.2f", gGlide);
casiotone401 15:3e4bc47d6a39 108
casiotone401 15:3e4bc47d6a39 109 // Main loop
casiotone401 15:3e4bc47d6a39 110 while (1)
casiotone401 15:3e4bc47d6a39 111 {
casiotone401 15:3e4bc47d6a39 112 LCD(); // Check Text LCD
casiotone401 15:3e4bc47d6a39 113
casiotone401 15:3e4bc47d6a39 114 pot = gAIN.read(); // Update glide value
casiotone401 15:3e4bc47d6a39 115
casiotone401 15:3e4bc47d6a39 116 if (!pot) // when glide pot value == 0
casiotone401 15:3e4bc47d6a39 117 { // use gCtrl[3] value
casiotone401 15:3e4bc47d6a39 118 if (abs(gCtrl[3] - _pot) > 0.01f)
casiotone401 15:3e4bc47d6a39 119 {
casiotone401 15:3e4bc47d6a39 120 _pot = gGlide = gCtrl[3];
casiotone401 15:3e4bc47d6a39 121
casiotone401 15:3e4bc47d6a39 122 gLCD.locate( 9, 1 );
casiotone401 15:3e4bc47d6a39 123 gLCD.printf("G>>%3.2f", gGlide);
casiotone401 15:3e4bc47d6a39 124 }
casiotone401 15:3e4bc47d6a39 125
casiotone401 15:3e4bc47d6a39 126 } else if (abs(pot - _pot) > 0.01f) {
casiotone401 15:3e4bc47d6a39 127
casiotone401 15:3e4bc47d6a39 128 _pot = gGlide = gAIN.read();
casiotone401 15:3e4bc47d6a39 129
casiotone401 15:3e4bc47d6a39 130 gLCD.locate( 9, 1 );
casiotone401 15:3e4bc47d6a39 131 gLCD.printf("G>>%3.2f", gGlide);
casiotone401 15:3e4bc47d6a39 132 }
casiotone401 15:3e4bc47d6a39 133
casiotone401 17:55e5136790a6 134 bpm = CheckBPM(); // check current BPM
casiotone401 17:55e5136790a6 135
casiotone401 15:3e4bc47d6a39 136 switch (gMode)
casiotone401 15:3e4bc47d6a39 137 {
casiotone401 15:3e4bc47d6a39 138 case MODE_OSC: // OSCtoCV mode
casiotone401 15:3e4bc47d6a39 139
casiotone401 15:3e4bc47d6a39 140 SetCV();
casiotone401 15:3e4bc47d6a39 141 break;
casiotone401 15:3e4bc47d6a39 142
casiotone401 15:3e4bc47d6a39 143 case MODE_SEQ: // Shift Sequencer mode
casiotone401 15:3e4bc47d6a39 144
casiotone401 15:3e4bc47d6a39 145 ShiftCVSeq(GateSeq(bpm, N16TH, GATE1, 3, NON_INVERT, GATESOUT_OFF, SYNC_ON), gCtrlSW[0]);
casiotone401 15:3e4bc47d6a39 146 GateSeq(bpm, N8TH, GATE2, 3, NON_INVERT, GATESOUT_ON, SYNC_OFF);
casiotone401 15:3e4bc47d6a39 147
casiotone401 15:3e4bc47d6a39 148 if (gCtrlSW[3])
casiotone401 15:3e4bc47d6a39 149 {
casiotone401 15:3e4bc47d6a39 150 EuclideanSeq(GateSeq(bpm, N16TH, SUBGATE, 1, NON_INVERT, GATESOUT_OFF, SYNC_OFF), gCtrlSW[0], GATESOUT_OFF);
casiotone401 15:3e4bc47d6a39 151 }
casiotone401 15:3e4bc47d6a39 152 break;
casiotone401 15:3e4bc47d6a39 153
casiotone401 15:3e4bc47d6a39 154 case MODE_185: // M185 Sequencer mode
casiotone401 15:3e4bc47d6a39 155
casiotone401 15:3e4bc47d6a39 156 M185Seq(GateSeq(bpm, N16TH, GATE1, 3, NON_INVERT, GATESOUT_OFF, SYNC_ON), gCtrlSW[0]);
casiotone401 15:3e4bc47d6a39 157 GateSeq(bpm, N8TH, GATE2, 3, NON_INVERT, GATESOUT_ON, SYNC_OFF);
casiotone401 15:3e4bc47d6a39 158
casiotone401 15:3e4bc47d6a39 159 if (gCtrlSW[3])
casiotone401 15:3e4bc47d6a39 160 {
casiotone401 15:3e4bc47d6a39 161 EuclideanSeq(GateSeq(bpm, N16TH, SUBGATE, 1, NON_INVERT, GATESOUT_OFF, SYNC_OFF), gCtrlSW[0], GATESOUT_OFF);
casiotone401 15:3e4bc47d6a39 162 }
casiotone401 15:3e4bc47d6a39 163 break;
casiotone401 15:3e4bc47d6a39 164
casiotone401 15:3e4bc47d6a39 165 case MODE_EUC: // Euclidean Sequencer mode
casiotone401 15:3e4bc47d6a39 166
casiotone401 15:3e4bc47d6a39 167 ShiftCVSeq(GateSeq(bpm, N1ST, SUBGATE, 3, NON_INVERT, GATESOUT_OFF, SYNC_OFF), gCtrlSW[0]);
casiotone401 15:3e4bc47d6a39 168 EuclideanSeq(GateSeq(bpm, N16TH, GATE1, 1, NON_INVERT, GATESOUT_OFF, SYNC_OFF), gCtrlSW[0], GATESOUT_ON);
casiotone401 15:3e4bc47d6a39 169 break;
casiotone401 15:3e4bc47d6a39 170
casiotone401 15:3e4bc47d6a39 171 default: // CV Calibration mode
casiotone401 15:3e4bc47d6a39 172
casiotone401 15:3e4bc47d6a39 173 CalibrationCV();
casiotone401 15:3e4bc47d6a39 174 break;
casiotone401 15:3e4bc47d6a39 175 }
casiotone401 15:3e4bc47d6a39 176
casiotone401 15:3e4bc47d6a39 177 }
casiotone401 15:3e4bc47d6a39 178 }
casiotone401 15:3e4bc47d6a39 179
casiotone401 15:3e4bc47d6a39 180 //-------------------------------------------------------------
casiotone401 20:a44f4a024902 181 // Ethernet Polling
casiotone401 20:a44f4a024902 182
casiotone401 20:a44f4a024902 183 inline void NetPoll()
casiotone401 20:a44f4a024902 184 {
casiotone401 20:a44f4a024902 185 Net::poll();
casiotone401 20:a44f4a024902 186 }
casiotone401 20:a44f4a024902 187
casiotone401 20:a44f4a024902 188 //-------------------------------------------------------------
casiotone401 15:3e4bc47d6a39 189 // Initialize OSCtoCV
casiotone401 15:3e4bc47d6a39 190
casiotone401 15:3e4bc47d6a39 191 void InitOSCCV()
casiotone401 15:3e4bc47d6a39 192 {
casiotone401 15:3e4bc47d6a39 193 int i;
casiotone401 20:a44f4a024902 194
casiotone401 20:a44f4a024902 195 //Clock Up --------------------------------------------------------------------
casiotone401 20:a44f4a024902 196 LPC_SC->PLL0CON = 0x00; /* PLL0 Disable */
casiotone401 20:a44f4a024902 197 LPC_SC->PLL0FEED = 0xAA;
casiotone401 20:a44f4a024902 198 LPC_SC->PLL0FEED = 0x55;
casiotone401 20:a44f4a024902 199
casiotone401 20:a44f4a024902 200 LPC_SC->CCLKCFG = 0x00000003; /* Select Clock Divisor = 4 */
casiotone401 20:a44f4a024902 201 LPC_SC->PLL0CFG = 0x00020038; /* configure PLL0 */
casiotone401 20:a44f4a024902 202 LPC_SC->PLL0FEED = 0xAA; /* divide by 3 then multiply by 50 */
casiotone401 20:a44f4a024902 203 LPC_SC->PLL0FEED = 0x55; /* PLL0 frequency = 400,000,000 */
casiotone401 20:a44f4a024902 204
casiotone401 20:a44f4a024902 205 LPC_SC->PLL0CON = 0x01; /* PLL0 Enable */
casiotone401 20:a44f4a024902 206 LPC_SC->PLL0FEED = 0xAA;
casiotone401 20:a44f4a024902 207 LPC_SC->PLL0FEED = 0x55;
casiotone401 20:a44f4a024902 208 while (!(LPC_SC->PLL0STAT & (1<<26)));/* Wait for PLOCK0 */
casiotone401 20:a44f4a024902 209
casiotone401 20:a44f4a024902 210 LPC_SC->PLL0CON = 0x03; /* PLL0 Enable & Connect */
casiotone401 20:a44f4a024902 211 LPC_SC->PLL0FEED = 0xAA;
casiotone401 20:a44f4a024902 212 LPC_SC->PLL0FEED = 0x55;
casiotone401 20:a44f4a024902 213 while (!(LPC_SC->PLL0STAT & ((1<<25) | (1<<24))));/* Wait for PLLC0_STAT & PLLE0_STAT */
casiotone401 20:a44f4a024902 214
casiotone401 20:a44f4a024902 215 SystemCoreClockUpdate();
casiotone401 20:a44f4a024902 216 //-----------------------------------------------------------------------------
casiotone401 20:a44f4a024902 217
casiotone401 20:a44f4a024902 218 wait(0.5);
casiotone401 20:a44f4a024902 219
casiotone401 20:a44f4a024902 220 // Setup Ethernet
casiotone401 20:a44f4a024902 221 SetupEthNetIf();
casiotone401 20:a44f4a024902 222
casiotone401 20:a44f4a024902 223 // Announce mdnsResponder (Bonjour)
casiotone401 20:a44f4a024902 224 HTTPServer svr;
casiotone401 20:a44f4a024902 225 mDNSResponder mdns;
casiotone401 20:a44f4a024902 226
casiotone401 20:a44f4a024902 227 svr.addHandler<SimpleHandler>("/");
casiotone401 20:a44f4a024902 228 svr.bind(INPUT_PORT);
casiotone401 20:a44f4a024902 229 IpAddr ip = gEth.getIp();
casiotone401 20:a44f4a024902 230 mdns.announce(ip, "OSCtoCV", "_osc._udp", INPUT_PORT, "mbed(OSCtoCV)", (char *[]) {"path=/",NULL});
casiotone401 20:a44f4a024902 231
casiotone401 15:3e4bc47d6a39 232 // Write custom char LCD CGRAM
casiotone401 15:3e4bc47d6a39 233 WriteCustomChar(0x00, str1);
casiotone401 15:3e4bc47d6a39 234 WriteCustomChar(0x01, str2);
casiotone401 15:3e4bc47d6a39 235 WriteCustomChar(0x02, str3);
casiotone401 15:3e4bc47d6a39 236 WriteCustomChar(0x03, str4);
casiotone401 15:3e4bc47d6a39 237 WriteCustomChar(0x04, str5);
casiotone401 15:3e4bc47d6a39 238 WriteCustomChar(0x05, str6);
casiotone401 15:3e4bc47d6a39 239 WriteCustomChar(0x06, str7);
casiotone401 15:3e4bc47d6a39 240 WriteCustomChar(0x07, str8);
casiotone401 15:3e4bc47d6a39 241
casiotone401 15:3e4bc47d6a39 242 // Init SPI
casiotone401 15:3e4bc47d6a39 243 gLDAC = _ENABLE;
casiotone401 15:3e4bc47d6a39 244 gSPI.format(8,1); // Data word length 8bit, Mode=1
casiotone401 15:3e4bc47d6a39 245 gSPI.frequency(SPI_RATE);
casiotone401 15:3e4bc47d6a39 246
casiotone401 15:3e4bc47d6a39 247 UpdateCV(CLR, 0, 0); // Ignore CLR Pin
casiotone401 20:a44f4a024902 248
casiotone401 15:3e4bc47d6a39 249 // Init BPM
casiotone401 15:3e4bc47d6a39 250 gCtrl[0] = 0.398f;
casiotone401 15:3e4bc47d6a39 251
casiotone401 15:3e4bc47d6a39 252 // Init Sequence Data
casiotone401 15:3e4bc47d6a39 253 for (i = 0; i < 16; ++i)
casiotone401 15:3e4bc47d6a39 254 {
casiotone401 15:3e4bc47d6a39 255 gSeq_cv[i] = calibMap1[69] * SCALING_N;
casiotone401 15:3e4bc47d6a39 256 }
casiotone401 15:3e4bc47d6a39 257
casiotone401 15:3e4bc47d6a39 258 // Init M185 Reset Count
casiotone401 15:3e4bc47d6a39 259 gCtrl[4] = 1;
casiotone401 4:b9f5ae574447 260
casiotone401 15:3e4bc47d6a39 261 // Set OSC message for sending
casiotone401 15:3e4bc47d6a39 262 sendMes.setIp(touchOSCAddress);
casiotone401 15:3e4bc47d6a39 263 sendMes.setPort(touchOSCPort);
casiotone401 3:ca15241dd6b4 264
casiotone401 15:3e4bc47d6a39 265 gSW.attach(&CheckModeSW,IRQ_RISE, 30); // InterruptIn rising edge(ModeSW)
casiotone401 17:55e5136790a6 266 wait(0.5);
casiotone401 15:3e4bc47d6a39 267
casiotone401 17:55e5136790a6 268 gPoller.attach_us(&NetPoll, POLLING_INTERVAL); // Ticker Polling
casiotone401 20:a44f4a024902 269 wait(1.8);
casiotone401 0:a4d93cd4c30d 270 }
casiotone401 0:a4d93cd4c30d 271
casiotone401 0:a4d93cd4c30d 272 //-------------------------------------------------------------
casiotone401 15:3e4bc47d6a39 273 // Calibration Mode
casiotone401 15:3e4bc47d6a39 274
casiotone401 20:a44f4a024902 275 void CalibrationCV()
casiotone401 14:977f3c5a4b4e 276 {
casiotone401 14:977f3c5a4b4e 277 static int ch;
casiotone401 14:977f3c5a4b4e 278 unsigned int cv;
casiotone401 14:977f3c5a4b4e 279
casiotone401 15:3e4bc47d6a39 280 switch (gMode)
casiotone401 14:977f3c5a4b4e 281 {
casiotone401 14:977f3c5a4b4e 282 case MODE_Calb:
casiotone401 14:977f3c5a4b4e 283
casiotone401 15:3e4bc47d6a39 284 cv = (unsigned int)(calibMap1[69] * SCALING_N); // A880.0Hz
casiotone401 14:977f3c5a4b4e 285
casiotone401 15:3e4bc47d6a39 286 gSUBGATE = gGATES[0] = gGATES[1] = gGATES[2] = gGATES[3] = true;
casiotone401 14:977f3c5a4b4e 287
casiotone401 14:977f3c5a4b4e 288 UpdateCV(WRITE_UPDATE_N, ch, &cv);
casiotone401 15:3e4bc47d6a39 289
casiotone401 14:977f3c5a4b4e 290 break;
casiotone401 14:977f3c5a4b4e 291 }
casiotone401 14:977f3c5a4b4e 292
casiotone401 15:3e4bc47d6a39 293 UpdateCVMeter(ch, &cv);
casiotone401 14:977f3c5a4b4e 294
casiotone401 15:3e4bc47d6a39 295 ++ch;
casiotone401 14:977f3c5a4b4e 296 ch &= 0x07;
casiotone401 14:977f3c5a4b4e 297 }
casiotone401 14:977f3c5a4b4e 298
casiotone401 14:977f3c5a4b4e 299 //-------------------------------------------------------------
casiotone401 14:977f3c5a4b4e 300 // Calculate CV
casiotone401 14:977f3c5a4b4e 301
casiotone401 15:3e4bc47d6a39 302 inline void SetCV()
casiotone401 14:977f3c5a4b4e 303 {
casiotone401 15:3e4bc47d6a39 304 static int ch, qmode, amode, mcount;
casiotone401 14:977f3c5a4b4e 305 static float glidecv[8];
casiotone401 14:977f3c5a4b4e 306 unsigned int cv;
casiotone401 14:977f3c5a4b4e 307 static float qcv;
casiotone401 14:977f3c5a4b4e 308
casiotone401 15:3e4bc47d6a39 309 qmode = (gCtrl[1] * (SCALE_NUM - 1));
casiotone401 15:3e4bc47d6a39 310 amode = SCALE_AOUT * qmode;
casiotone401 15:3e4bc47d6a39 311
casiotone401 15:3e4bc47d6a39 312 gAOUT.write_u16(amode);
casiotone401 15:3e4bc47d6a39 313
casiotone401 15:3e4bc47d6a39 314 switch (qmode)
casiotone401 14:977f3c5a4b4e 315 {
casiotone401 14:977f3c5a4b4e 316 case Lin:
casiotone401 14:977f3c5a4b4e 317
casiotone401 14:977f3c5a4b4e 318 glidecv[ch] = glidecv[ch] * gGlide + gOSC_cv[ch] * (1.0f - gGlide);
casiotone401 14:977f3c5a4b4e 319 break;
casiotone401 14:977f3c5a4b4e 320
casiotone401 14:977f3c5a4b4e 321 case Chr:
casiotone401 15:3e4bc47d6a39 322
casiotone401 15:3e4bc47d6a39 323 qcv = calibMap1[(unsigned int)MapFloat(gOSC_cv[ch], 0, SCALING_N, 0, (QUAN_RES1 - 1))];
casiotone401 14:977f3c5a4b4e 324
casiotone401 14:977f3c5a4b4e 325 glidecv[ch] = glidecv[ch] * gGlide + (qcv * SCALING_N) * (1.0f - gGlide);
casiotone401 15:3e4bc47d6a39 326
casiotone401 14:977f3c5a4b4e 327 break;
casiotone401 14:977f3c5a4b4e 328
casiotone401 15:3e4bc47d6a39 329 case Maj:
casiotone401 15:3e4bc47d6a39 330
casiotone401 15:3e4bc47d6a39 331 qcv = calibMap2[(unsigned int)MapFloat(gOSC_cv[ch], 0, SCALING_N, 0, (QUAN_RES2 - 1))];
casiotone401 15:3e4bc47d6a39 332
casiotone401 14:977f3c5a4b4e 333 glidecv[ch] = glidecv[ch] * gGlide + (qcv * SCALING_N) * (1.0f - gGlide);
casiotone401 15:3e4bc47d6a39 334
casiotone401 14:977f3c5a4b4e 335 break;
casiotone401 15:3e4bc47d6a39 336
casiotone401 15:3e4bc47d6a39 337 case M7:
casiotone401 14:977f3c5a4b4e 338
casiotone401 15:3e4bc47d6a39 339 qcv = calibMap3[(unsigned int)MapFloat(gOSC_cv[ch], 0, SCALING_N, 0, (QUAN_RES3 - 1))];
casiotone401 14:977f3c5a4b4e 340
casiotone401 14:977f3c5a4b4e 341 glidecv[ch] = glidecv[ch] * gGlide + (qcv * SCALING_N) * (1.0f - gGlide);
casiotone401 15:3e4bc47d6a39 342
casiotone401 15:3e4bc47d6a39 343 break;
casiotone401 15:3e4bc47d6a39 344
casiotone401 15:3e4bc47d6a39 345 case Min7:
casiotone401 15:3e4bc47d6a39 346
casiotone401 15:3e4bc47d6a39 347 qcv = calibMap4[(unsigned int)MapFloat(gOSC_cv[ch], 0, SCALING_N, 0, (QUAN_RES4 - 1))];
casiotone401 15:3e4bc47d6a39 348
casiotone401 15:3e4bc47d6a39 349 glidecv[ch] = glidecv[ch] * gGlide + (qcv * SCALING_N) * (1.0f - gGlide);
casiotone401 15:3e4bc47d6a39 350
casiotone401 15:3e4bc47d6a39 351 break;
casiotone401 15:3e4bc47d6a39 352
casiotone401 15:3e4bc47d6a39 353 case Dor:
casiotone401 15:3e4bc47d6a39 354
casiotone401 15:3e4bc47d6a39 355 qcv = calibMap5[(unsigned int)MapFloat(gOSC_cv[ch], 0, SCALING_N, 0, (QUAN_RES5 - 1))];
casiotone401 15:3e4bc47d6a39 356
casiotone401 15:3e4bc47d6a39 357 glidecv[ch] = glidecv[ch] * gGlide + (qcv * SCALING_N) * (1.0f - gGlide);
casiotone401 15:3e4bc47d6a39 358
casiotone401 15:3e4bc47d6a39 359 break;
casiotone401 15:3e4bc47d6a39 360
casiotone401 15:3e4bc47d6a39 361 case Min:
casiotone401 15:3e4bc47d6a39 362
casiotone401 15:3e4bc47d6a39 363 qcv = calibMap6[(unsigned int)MapFloat(gOSC_cv[ch], 0, SCALING_N, 0, (QUAN_RES6 - 1))];
casiotone401 15:3e4bc47d6a39 364
casiotone401 15:3e4bc47d6a39 365 glidecv[ch] = glidecv[ch] * gGlide + (qcv * SCALING_N) * (1.0f - gGlide);
casiotone401 15:3e4bc47d6a39 366
casiotone401 15:3e4bc47d6a39 367 break;
casiotone401 15:3e4bc47d6a39 368
casiotone401 15:3e4bc47d6a39 369 case S5th:
casiotone401 15:3e4bc47d6a39 370
casiotone401 15:3e4bc47d6a39 371 qcv = calibMap7[(unsigned int)MapFloat(gOSC_cv[ch], 0, SCALING_N, 0, (QUAN_RES7 - 1))];
casiotone401 15:3e4bc47d6a39 372
casiotone401 15:3e4bc47d6a39 373 glidecv[ch] = glidecv[ch] * gGlide + (qcv * SCALING_N) * (1.0f - gGlide);
casiotone401 15:3e4bc47d6a39 374
casiotone401 15:3e4bc47d6a39 375 break;
casiotone401 15:3e4bc47d6a39 376
casiotone401 15:3e4bc47d6a39 377 case Wht:
casiotone401 15:3e4bc47d6a39 378
casiotone401 15:3e4bc47d6a39 379 qcv = calibMap8[(unsigned int)MapFloat(gOSC_cv[ch], 0, SCALING_N, 0, (QUAN_RES8 - 1))];
casiotone401 15:3e4bc47d6a39 380
casiotone401 15:3e4bc47d6a39 381 glidecv[ch] = glidecv[ch] * gGlide + (qcv * SCALING_N) * (1.0f - gGlide);
casiotone401 17:55e5136790a6 382
casiotone401 14:977f3c5a4b4e 383 break;
casiotone401 14:977f3c5a4b4e 384 }
casiotone401 17:55e5136790a6 385
casiotone401 17:55e5136790a6 386 cv = (unsigned int)glidecv[ch];
casiotone401 17:55e5136790a6 387
casiotone401 17:55e5136790a6 388 UpdateCV(WRITE_UPDATE_N, ch, &cv);
casiotone401 14:977f3c5a4b4e 389
casiotone401 17:55e5136790a6 390 if (mcount == 0x1F)
casiotone401 17:55e5136790a6 391 {
casiotone401 17:55e5136790a6 392 UpdateCVMeter(ch, &cv);
casiotone401 17:55e5136790a6 393 }
casiotone401 17:55e5136790a6 394
casiotone401 17:55e5136790a6 395 ++ch;
casiotone401 17:55e5136790a6 396
casiotone401 17:55e5136790a6 397 if (ch &= 0x07)
casiotone401 17:55e5136790a6 398 {
casiotone401 17:55e5136790a6 399 ++mcount;
casiotone401 17:55e5136790a6 400 mcount &= 0x3F;
casiotone401 17:55e5136790a6 401 }
casiotone401 14:977f3c5a4b4e 402 }
casiotone401 14:977f3c5a4b4e 403
casiotone401 15:3e4bc47d6a39 404
casiotone401 5:e305509d53f3 405 //-------------------------------------------------------------
casiotone401 15:3e4bc47d6a39 406 // Check BPM
casiotone401 15:3e4bc47d6a39 407
casiotone401 15:3e4bc47d6a39 408 inline int CheckBPM()
casiotone401 15:3e4bc47d6a39 409 {
casiotone401 15:3e4bc47d6a39 410 static int _bpm = -1;
casiotone401 15:3e4bc47d6a39 411 int bpm;
casiotone401 14:977f3c5a4b4e 412
casiotone401 15:3e4bc47d6a39 413 if (gCtrlSW[0])
casiotone401 14:977f3c5a4b4e 414 {
casiotone401 15:3e4bc47d6a39 415 bpm = 0;
casiotone401 15:3e4bc47d6a39 416
casiotone401 15:3e4bc47d6a39 417 return bpm;
casiotone401 0:a4d93cd4c30d 418 }
casiotone401 3:ca15241dd6b4 419
casiotone401 20:a44f4a024902 420 if (gCtrl[0]) {
casiotone401 15:3e4bc47d6a39 421
casiotone401 15:3e4bc47d6a39 422 bpm = (gCtrl[0] * 240 + 5);
casiotone401 15:3e4bc47d6a39 423
casiotone401 15:3e4bc47d6a39 424 if (abs(bpm - _bpm) > 1)
casiotone401 15:3e4bc47d6a39 425 {
casiotone401 15:3e4bc47d6a39 426 _bpm = bpm;
casiotone401 15:3e4bc47d6a39 427
casiotone401 15:3e4bc47d6a39 428 sendMes.setTopAddress("/bpm");
casiotone401 15:3e4bc47d6a39 429 sendMes.setArgs("i", bpm);
casiotone401 15:3e4bc47d6a39 430 osc.sendOsc(&sendMes);
casiotone401 15:3e4bc47d6a39 431 }
casiotone401 15:3e4bc47d6a39 432 }
casiotone401 15:3e4bc47d6a39 433
casiotone401 15:3e4bc47d6a39 434 return bpm;
casiotone401 15:3e4bc47d6a39 435 }
casiotone401 15:3e4bc47d6a39 436
casiotone401 15:3e4bc47d6a39 437 //-------------------------------------------------------------
casiotone401 15:3e4bc47d6a39 438 // Check Mode SW
casiotone401 15:3e4bc47d6a39 439
casiotone401 20:a44f4a024902 440 void CheckModeSW()
casiotone401 15:3e4bc47d6a39 441 {
casiotone401 15:3e4bc47d6a39 442 if (gMode < MODE_TOTAL - 1)
casiotone401 15:3e4bc47d6a39 443 {
casiotone401 15:3e4bc47d6a39 444 ++gMode;
casiotone401 15:3e4bc47d6a39 445
casiotone401 15:3e4bc47d6a39 446 } else {
casiotone401 15:3e4bc47d6a39 447
casiotone401 15:3e4bc47d6a39 448 gMode = 0;
casiotone401 15:3e4bc47d6a39 449 }
casiotone401 15:3e4bc47d6a39 450
casiotone401 15:3e4bc47d6a39 451 gCLOCKOUT = gGATES[0] = gGATES[1] = gGATES[2] = gGATES[3] = false;
casiotone401 15:3e4bc47d6a39 452
casiotone401 15:3e4bc47d6a39 453 if (gMode == MODE_SEQ || gMode == MODE_185 || gMode == MODE_EUC)
casiotone401 15:3e4bc47d6a39 454 {
casiotone401 15:3e4bc47d6a39 455 gTimer.start(); // Sequencer Timer Start
casiotone401 15:3e4bc47d6a39 456 midi.begin(1);
casiotone401 5:e305509d53f3 457
casiotone401 15:3e4bc47d6a39 458 } else {
casiotone401 15:3e4bc47d6a39 459
casiotone401 15:3e4bc47d6a39 460 gTimer.stop(); // Sequencer Timer Stop
casiotone401 5:e305509d53f3 461 }
casiotone401 5:e305509d53f3 462
casiotone401 4:b9f5ae574447 463 }
casiotone401 4:b9f5ae574447 464
casiotone401 4:b9f5ae574447 465 //-------------------------------------------------------------
casiotone401 15:3e4bc47d6a39 466 // Print LCD Mode Status
casiotone401 15:3e4bc47d6a39 467
casiotone401 15:3e4bc47d6a39 468 inline void LCD()
casiotone401 15:3e4bc47d6a39 469 {
casiotone401 15:3e4bc47d6a39 470 static int _mode = -1;
casiotone401 15:3e4bc47d6a39 471 static int _qmode = -1;
casiotone401 15:3e4bc47d6a39 472 static int qmode;
casiotone401 15:3e4bc47d6a39 473
casiotone401 15:3e4bc47d6a39 474 if (_mode != gMode)
casiotone401 15:3e4bc47d6a39 475 {
casiotone401 15:3e4bc47d6a39 476 sendMes.setTopAddress("/mode");
casiotone401 15:3e4bc47d6a39 477
casiotone401 15:3e4bc47d6a39 478 switch (gMode)
casiotone401 15:3e4bc47d6a39 479 {
casiotone401 15:3e4bc47d6a39 480 case MODE_Calb:
casiotone401 15:3e4bc47d6a39 481 gLCD.locate( 9, 0 );
casiotone401 15:3e4bc47d6a39 482 gLCD.printf("CLB|880");
casiotone401 15:3e4bc47d6a39 483
casiotone401 15:3e4bc47d6a39 484 sendMes.setArgs("s", "Calibration");
casiotone401 15:3e4bc47d6a39 485 osc.sendOsc(&sendMes);
casiotone401 15:3e4bc47d6a39 486
casiotone401 15:3e4bc47d6a39 487 sendMes.setTopAddress("/scale");
casiotone401 15:3e4bc47d6a39 488 sendMes.setArgs("s", "880Hz");
casiotone401 15:3e4bc47d6a39 489
casiotone401 15:3e4bc47d6a39 490 _qmode = -1;
casiotone401 15:3e4bc47d6a39 491
casiotone401 15:3e4bc47d6a39 492 break;
casiotone401 15:3e4bc47d6a39 493
casiotone401 15:3e4bc47d6a39 494 case MODE_OSC:
casiotone401 15:3e4bc47d6a39 495 gLCD.locate( 9, 0 );
casiotone401 15:3e4bc47d6a39 496 gLCD.printf("OSC|");
casiotone401 15:3e4bc47d6a39 497
casiotone401 15:3e4bc47d6a39 498 sendMes.setArgs("s", "OSCtoCV");
casiotone401 15:3e4bc47d6a39 499
casiotone401 15:3e4bc47d6a39 500 break;
casiotone401 15:3e4bc47d6a39 501
casiotone401 15:3e4bc47d6a39 502 case MODE_SEQ:
casiotone401 15:3e4bc47d6a39 503 gLCD.locate( 9, 0 );
casiotone401 15:3e4bc47d6a39 504 gLCD.printf("ASR|");
casiotone401 15:3e4bc47d6a39 505
casiotone401 15:3e4bc47d6a39 506 sendMes.setArgs("s", "ASR SEQ");
casiotone401 15:3e4bc47d6a39 507
casiotone401 15:3e4bc47d6a39 508 break;
casiotone401 15:3e4bc47d6a39 509
casiotone401 15:3e4bc47d6a39 510 case MODE_185:
casiotone401 15:3e4bc47d6a39 511 gLCD.locate( 9, 0 );
casiotone401 15:3e4bc47d6a39 512 gLCD.printf("185|");
casiotone401 15:3e4bc47d6a39 513
casiotone401 15:3e4bc47d6a39 514 sendMes.setArgs("s", "M185 SEQ");
casiotone401 15:3e4bc47d6a39 515
casiotone401 15:3e4bc47d6a39 516 break;
casiotone401 15:3e4bc47d6a39 517
casiotone401 15:3e4bc47d6a39 518 case MODE_EUC:
casiotone401 15:3e4bc47d6a39 519 gLCD.locate( 9, 0 );
casiotone401 15:3e4bc47d6a39 520 gLCD.printf("EUC|");
casiotone401 15:3e4bc47d6a39 521
casiotone401 15:3e4bc47d6a39 522 sendMes.setArgs("s", "Euclidean SEQ");
casiotone401 15:3e4bc47d6a39 523
casiotone401 15:3e4bc47d6a39 524 break;
casiotone401 15:3e4bc47d6a39 525
casiotone401 15:3e4bc47d6a39 526 default:
casiotone401 15:3e4bc47d6a39 527 break;
casiotone401 15:3e4bc47d6a39 528 }
casiotone401 15:3e4bc47d6a39 529
casiotone401 15:3e4bc47d6a39 530 osc.sendOsc(&sendMes);
casiotone401 15:3e4bc47d6a39 531 _mode = gMode;
casiotone401 15:3e4bc47d6a39 532 }
casiotone401 15:3e4bc47d6a39 533
casiotone401 15:3e4bc47d6a39 534 qmode = (gCtrl[1] * (SCALE_NUM - 1));
casiotone401 15:3e4bc47d6a39 535
casiotone401 17:55e5136790a6 536 if (_qmode != qmode)
casiotone401 15:3e4bc47d6a39 537 {
casiotone401 15:3e4bc47d6a39 538 sendMes.setTopAddress("/scale");
casiotone401 15:3e4bc47d6a39 539
casiotone401 15:3e4bc47d6a39 540 switch (qmode)
casiotone401 15:3e4bc47d6a39 541 {
casiotone401 15:3e4bc47d6a39 542 case Lin:
casiotone401 15:3e4bc47d6a39 543 gLCD.locate( 13, 0 );
casiotone401 15:3e4bc47d6a39 544 gLCD.printf("lin");
casiotone401 15:3e4bc47d6a39 545
casiotone401 15:3e4bc47d6a39 546 sendMes.setArgs("s", "Linear");
casiotone401 15:3e4bc47d6a39 547
casiotone401 15:3e4bc47d6a39 548 break;
casiotone401 15:3e4bc47d6a39 549
casiotone401 15:3e4bc47d6a39 550 case Chr:
casiotone401 15:3e4bc47d6a39 551 gLCD.locate( 13, 0 );
casiotone401 15:3e4bc47d6a39 552 gLCD.printf("chr");
casiotone401 15:3e4bc47d6a39 553
casiotone401 15:3e4bc47d6a39 554 sendMes.setArgs("s", "Chromatic");
casiotone401 15:3e4bc47d6a39 555
casiotone401 15:3e4bc47d6a39 556 break;
casiotone401 15:3e4bc47d6a39 557
casiotone401 15:3e4bc47d6a39 558 case Maj:
casiotone401 15:3e4bc47d6a39 559 gLCD.locate( 13, 0 );
casiotone401 15:3e4bc47d6a39 560 gLCD.printf("maj");
casiotone401 15:3e4bc47d6a39 561
casiotone401 15:3e4bc47d6a39 562 sendMes.setArgs("s", "Major");
casiotone401 15:3e4bc47d6a39 563
casiotone401 15:3e4bc47d6a39 564 break;
casiotone401 15:3e4bc47d6a39 565
casiotone401 15:3e4bc47d6a39 566 case M7:
casiotone401 15:3e4bc47d6a39 567 gLCD.locate( 13, 0 );
casiotone401 15:3e4bc47d6a39 568 gLCD.printf("ma7");
casiotone401 15:3e4bc47d6a39 569
casiotone401 15:3e4bc47d6a39 570 sendMes.setArgs("s", "Major7");
casiotone401 15:3e4bc47d6a39 571
casiotone401 15:3e4bc47d6a39 572 break;
casiotone401 15:3e4bc47d6a39 573
casiotone401 15:3e4bc47d6a39 574 case Min7:
casiotone401 15:3e4bc47d6a39 575 gLCD.locate( 13, 0 );
casiotone401 15:3e4bc47d6a39 576 gLCD.printf("mi7");
casiotone401 15:3e4bc47d6a39 577
casiotone401 15:3e4bc47d6a39 578 sendMes.setArgs("s", "Minor7");
casiotone401 15:3e4bc47d6a39 579
casiotone401 15:3e4bc47d6a39 580 break;
casiotone401 15:3e4bc47d6a39 581
casiotone401 15:3e4bc47d6a39 582 case Dor:
casiotone401 15:3e4bc47d6a39 583 gLCD.locate( 13, 0 );
casiotone401 15:3e4bc47d6a39 584 gLCD.printf("dor");
casiotone401 15:3e4bc47d6a39 585
casiotone401 15:3e4bc47d6a39 586 sendMes.setArgs("s", "Dorian");
casiotone401 15:3e4bc47d6a39 587
casiotone401 15:3e4bc47d6a39 588 break;
casiotone401 15:3e4bc47d6a39 589
casiotone401 15:3e4bc47d6a39 590 case Min:
casiotone401 15:3e4bc47d6a39 591 gLCD.locate( 13, 0 );
casiotone401 15:3e4bc47d6a39 592 gLCD.printf("min");
casiotone401 15:3e4bc47d6a39 593
casiotone401 15:3e4bc47d6a39 594 sendMes.setTopAddress("/scale");
casiotone401 15:3e4bc47d6a39 595 sendMes.setArgs("s", "Minor");
casiotone401 15:3e4bc47d6a39 596
casiotone401 15:3e4bc47d6a39 597 break;
casiotone401 15:3e4bc47d6a39 598
casiotone401 15:3e4bc47d6a39 599 case S5th:
casiotone401 15:3e4bc47d6a39 600 gLCD.locate( 13, 0 );
casiotone401 15:3e4bc47d6a39 601 gLCD.printf("5th");
casiotone401 15:3e4bc47d6a39 602
casiotone401 15:3e4bc47d6a39 603 sendMes.setArgs("s", "5th");
casiotone401 15:3e4bc47d6a39 604
casiotone401 15:3e4bc47d6a39 605 break;
casiotone401 15:3e4bc47d6a39 606
casiotone401 15:3e4bc47d6a39 607 case Wht:
casiotone401 15:3e4bc47d6a39 608 gLCD.locate( 13, 0 );
casiotone401 15:3e4bc47d6a39 609 gLCD.printf("wht");
casiotone401 15:3e4bc47d6a39 610
casiotone401 15:3e4bc47d6a39 611 sendMes.setArgs("s", "Whole Tone");
casiotone401 15:3e4bc47d6a39 612 break;
casiotone401 15:3e4bc47d6a39 613
casiotone401 15:3e4bc47d6a39 614 default:
casiotone401 15:3e4bc47d6a39 615 break;
casiotone401 15:3e4bc47d6a39 616 }
casiotone401 15:3e4bc47d6a39 617
casiotone401 15:3e4bc47d6a39 618 osc.sendOsc(&sendMes);
casiotone401 15:3e4bc47d6a39 619 _qmode = qmode;
casiotone401 15:3e4bc47d6a39 620 }
casiotone401 15:3e4bc47d6a39 621
casiotone401 4:b9f5ae574447 622 }
casiotone401 4:b9f5ae574447 623
casiotone401 15:3e4bc47d6a39 624
casiotone401 0:a4d93cd4c30d 625 //-------------------------------------------------------------
casiotone401 15:3e4bc47d6a39 626 // Write command Custom Char LCD CGRAM for CV Meter)
casiotone401 0:a4d93cd4c30d 627
casiotone401 0:a4d93cd4c30d 628 void WriteCustomChar(unsigned char addr, unsigned char *c)
casiotone401 0:a4d93cd4c30d 629 {
casiotone401 0:a4d93cd4c30d 630 char cnt = 0;
casiotone401 0:a4d93cd4c30d 631 addr = ((addr << 3) | 0x40);
casiotone401 0:a4d93cd4c30d 632
casiotone401 15:3e4bc47d6a39 633 while (cnt < 0x08)
casiotone401 0:a4d93cd4c30d 634 {
casiotone401 0:a4d93cd4c30d 635 gLCD.writeCommand(addr | cnt);
casiotone401 0:a4d93cd4c30d 636 gLCD.writeData(*c);
casiotone401 4:b9f5ae574447 637
casiotone401 15:3e4bc47d6a39 638 ++cnt;
casiotone401 15:3e4bc47d6a39 639 ++c;
casiotone401 0:a4d93cd4c30d 640 }
casiotone401 0:a4d93cd4c30d 641 }
casiotone401 0:a4d93cd4c30d 642
casiotone401 0:a4d93cd4c30d 643 //-------------------------------------------------------------
casiotone401 0:a4d93cd4c30d 644 // Setup Ethernet port
casiotone401 0:a4d93cd4c30d 645
casiotone401 0:a4d93cd4c30d 646 int SetupEthNetIf()
casiotone401 0:a4d93cd4c30d 647 {
casiotone401 0:a4d93cd4c30d 648 gLCD.locate( 0, 1 );
casiotone401 0:a4d93cd4c30d 649 gLCD.printf("Setting up... ");
casiotone401 0:a4d93cd4c30d 650 // printf("Setting up...\r\n");
casiotone401 0:a4d93cd4c30d 651 EthernetErr ethErr = gEth.setup();
casiotone401 0:a4d93cd4c30d 652
casiotone401 15:3e4bc47d6a39 653 if (ethErr)
casiotone401 0:a4d93cd4c30d 654 {
casiotone401 0:a4d93cd4c30d 655 gLCD.locate( 0, 1 );
casiotone401 0:a4d93cd4c30d 656 gLCD.printf("Error in setup.");
casiotone401 0:a4d93cd4c30d 657 // printf("Error %d in setup.\r\n", ethErr);
casiotone401 0:a4d93cd4c30d 658 return -1;
casiotone401 0:a4d93cd4c30d 659 }
casiotone401 0:a4d93cd4c30d 660 // printf("Setup OK\r\n");
casiotone401 0:a4d93cd4c30d 661
casiotone401 0:a4d93cd4c30d 662 // printf("IP address %d.%d.%d.%d\r\n", gEth.getIp()[0], gEth.getIp()[1], gEth.getIp()[2], gEth.getIp()[3]);
casiotone401 0:a4d93cd4c30d 663 Host broadcast(IpAddr(gEth.getIp()[0], gEth.getIp()[1], gEth.getIp()[2], 255), INPUT_PORT, NULL);
casiotone401 0:a4d93cd4c30d 664 gUdp.setOnEvent(&onUDPSocketEvent);
casiotone401 0:a4d93cd4c30d 665 gUdp.bind(broadcast);
casiotone401 4:b9f5ae574447 666
casiotone401 0:a4d93cd4c30d 667 gLCD.locate( 0, 1 );
casiotone401 0:a4d93cd4c30d 668 gLCD.printf("%03d.%03d.%03d.%03d", gEth.getIp()[0], gEth.getIp()[1], gEth.getIp()[2], gEth.getIp()[3]);
casiotone401 15:3e4bc47d6a39 669
casiotone401 4:b9f5ae574447 670 wait(1.0);
casiotone401 0:a4d93cd4c30d 671
casiotone401 0:a4d93cd4c30d 672 return 0;
casiotone401 0:a4d93cd4c30d 673 }
casiotone401 0:a4d93cd4c30d 674
casiotone401 14:977f3c5a4b4e 675
casiotone401 14:977f3c5a4b4e 676 //-------------------------------------------------------------
casiotone401 15:3e4bc47d6a39 677 // Handller receive OSC UDP Packet
casiotone401 0:a4d93cd4c30d 678
casiotone401 4:b9f5ae574447 679 inline void onUDPSocketEvent(UDPSocketEvent e)
casiotone401 0:a4d93cd4c30d 680 {
casiotone401 15:3e4bc47d6a39 681 static union OSCarg msg[10];
casiotone401 15:3e4bc47d6a39 682 static char buf[896] = {0};
casiotone401 15:3e4bc47d6a39 683 static int recvlen;
casiotone401 15:3e4bc47d6a39 684 static int num, len, offset;
casiotone401 14:977f3c5a4b4e 685 int messagepos = 0;
casiotone401 14:977f3c5a4b4e 686 bool bundleflag = false;
casiotone401 10:ccfeb687c3f2 687
casiotone401 10:ccfeb687c3f2 688 Host host;
casiotone401 10:ccfeb687c3f2 689
casiotone401 15:3e4bc47d6a39 690 switch (e)
casiotone401 0:a4d93cd4c30d 691 {
casiotone401 4:b9f5ae574447 692 case UDPSOCKET_READABLE: // The only event for now
casiotone401 15:3e4bc47d6a39 693
casiotone401 15:3e4bc47d6a39 694 recvlen = gUdp.recvfrom(buf, 896, &host); // packet length
casiotone401 10:ccfeb687c3f2 695
casiotone401 15:3e4bc47d6a39 696 if (recvlen <= 0) break;
casiotone401 15:3e4bc47d6a39 697
casiotone401 15:3e4bc47d6a39 698 if (!bundleflag && buf[0] == '#') // #bundle
casiotone401 0:a4d93cd4c30d 699 {
casiotone401 10:ccfeb687c3f2 700 messagepos += 16; // skip #bundle & timetag
casiotone401 10:ccfeb687c3f2 701 recvlen -= 16;
casiotone401 0:a4d93cd4c30d 702
casiotone401 10:ccfeb687c3f2 703 bundleflag = true;
casiotone401 10:ccfeb687c3f2 704 }
casiotone401 10:ccfeb687c3f2 705
casiotone401 10:ccfeb687c3f2 706 do {
casiotone401 15:3e4bc47d6a39 707 if (bundleflag)
casiotone401 10:ccfeb687c3f2 708 {
casiotone401 10:ccfeb687c3f2 709 messagepos += 4;
casiotone401 10:ccfeb687c3f2 710 recvlen -= 4;
casiotone401 15:3e4bc47d6a39 711
casiotone401 15:3e4bc47d6a39 712 if (recvlen <= 8)
casiotone401 10:ccfeb687c3f2 713 {
casiotone401 10:ccfeb687c3f2 714 bundleflag = false;
casiotone401 10:ccfeb687c3f2 715 break;
casiotone401 10:ccfeb687c3f2 716 }
casiotone401 10:ccfeb687c3f2 717 }
casiotone401 10:ccfeb687c3f2 718
casiotone401 15:3e4bc47d6a39 719 if (getOSCmsg(buf + messagepos, msg) == -1) continue;
casiotone401 4:b9f5ae574447 720
casiotone401 15:3e4bc47d6a39 721 len = strlength(msg[0].address);
casiotone401 10:ccfeb687c3f2 722
casiotone401 15:3e4bc47d6a39 723 if (isdigit(msg[0].address[len-1]))
casiotone401 10:ccfeb687c3f2 724 {
casiotone401 10:ccfeb687c3f2 725 num = msg[0].address[len-1] - '0' - 1;
casiotone401 15:3e4bc47d6a39 726
casiotone401 15:3e4bc47d6a39 727 offset = 1;
casiotone401 15:3e4bc47d6a39 728
casiotone401 15:3e4bc47d6a39 729 if (isdigit(msg[0].address[len-2]))
casiotone401 15:3e4bc47d6a39 730 {
casiotone401 15:3e4bc47d6a39 731 offset = 2;
casiotone401 15:3e4bc47d6a39 732 num += 10;
casiotone401 15:3e4bc47d6a39 733 }
casiotone401 15:3e4bc47d6a39 734
casiotone401 10:ccfeb687c3f2 735 } else {
casiotone401 0:a4d93cd4c30d 736
casiotone401 10:ccfeb687c3f2 737 num = -1;
casiotone401 10:ccfeb687c3f2 738 }
casiotone401 10:ccfeb687c3f2 739
casiotone401 10:ccfeb687c3f2 740 // address pattern SYNC & GATE (Type Tag int, float)
casiotone401 17:55e5136790a6 741 if (!strncmp(msg[0].address + (len - offset) - 4, "sync", 4))
casiotone401 10:ccfeb687c3f2 742 {
casiotone401 15:3e4bc47d6a39 743 if (msg[2].i != 0) gCLOCKOUT = true;
casiotone401 15:3e4bc47d6a39 744 else gCLOCKOUT = false;
casiotone401 10:ccfeb687c3f2 745 continue;
casiotone401 10:ccfeb687c3f2 746
casiotone401 17:55e5136790a6 747 } else if (!strncmp(msg[0].address + (len - offset) - 4, "gate", 4) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 748 if (num > 3) continue;
casiotone401 15:3e4bc47d6a39 749 if (msg[2].i != 0) gGATES[num] = true;
casiotone401 15:3e4bc47d6a39 750 else gGATES[num] = false;
casiotone401 10:ccfeb687c3f2 751 continue;
casiotone401 10:ccfeb687c3f2 752 // (touchOSC Control push, toggle)
casiotone401 17:55e5136790a6 753 } else if (!strncmp(msg[0].address + (len - offset) - 5, "fader", 5) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 754 if (num > 7) continue;
casiotone401 15:3e4bc47d6a39 755 gOSC_cv[num] = msg[2].f * (SCALING_N);
casiotone401 10:ccfeb687c3f2 756 continue;
casiotone401 15:3e4bc47d6a39 757
casiotone401 17:55e5136790a6 758 } else if (!strncmp(msg[0].address + (len - offset) - 9, "multixy1/", 9) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 759 if (num > 7) continue;
casiotone401 15:3e4bc47d6a39 760 if (msg[1].typeTag[1] == 'f') gOSC_cv[num] = msg[2].f * (SCALING_N);
casiotone401 15:3e4bc47d6a39 761 if (msg[1].typeTag[1] == 'f') gOSC_cv[++num] = msg[3].f * (SCALING_N);
casiotone401 10:ccfeb687c3f2 762 continue;
casiotone401 10:ccfeb687c3f2 763
casiotone401 17:55e5136790a6 764 } else if (!strncmp(msg[0].address + (len - offset) -12, "multifader1/", 12) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 765 if (num > 7) continue;
casiotone401 15:3e4bc47d6a39 766 if (msg[1].typeTag[1] == 'f') gOSC_cv[num] = msg[2].f * (SCALING_N);
casiotone401 10:ccfeb687c3f2 767 continue;
casiotone401 15:3e4bc47d6a39 768
casiotone401 17:55e5136790a6 769 } else if (!strncmp(msg[0].address + (len - offset) -10, "sequencer/", 10) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 770 if (num > 15) continue;
casiotone401 15:3e4bc47d6a39 771 gSeq_cv[num] = msg[2].f * (SCALING_N);
casiotone401 10:ccfeb687c3f2 772 continue;
casiotone401 0:a4d93cd4c30d 773
casiotone401 17:55e5136790a6 774 } else if (!strncmp(msg[0].address + (len - offset) - 6, "ctrlsw", 6) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 775 if (num > 7) continue;
casiotone401 15:3e4bc47d6a39 776 if (msg[2].i != 0) gCtrlSW[num] = true;
casiotone401 14:977f3c5a4b4e 777 else gCtrlSW[num] = false;
casiotone401 10:ccfeb687c3f2 778 continue;
casiotone401 4:b9f5ae574447 779
casiotone401 17:55e5136790a6 780 } else if (!strncmp(msg[0].address + (len - offset) - 4, "ctrl", 4) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 781 if (num > 7) continue;
casiotone401 15:3e4bc47d6a39 782 gCtrl[num] = msg[2].f;
casiotone401 15:3e4bc47d6a39 783 continue;
casiotone401 15:3e4bc47d6a39 784
casiotone401 17:55e5136790a6 785 } else if (!strncmp(msg[0].address + (len - offset) - 9, "pulsecnt/", 9) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 786 if (num > 7) continue;
casiotone401 15:3e4bc47d6a39 787 gPulseCount[num] = msg[2].f;
casiotone401 15:3e4bc47d6a39 788 continue;
casiotone401 15:3e4bc47d6a39 789
casiotone401 17:55e5136790a6 790 } else if (!strncmp(msg[0].address + (len - offset) - 9, "gatemode/", 9) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 791 if (num > 15) continue;
casiotone401 15:3e4bc47d6a39 792 gGateMode[num] = msg[2].f;
casiotone401 15:3e4bc47d6a39 793 continue;
casiotone401 15:3e4bc47d6a39 794
casiotone401 17:55e5136790a6 795 } else if (!strncmp(msg[0].address + (len - offset) - 6, "slide/", 6) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 796 if (num > 15) continue;
casiotone401 15:3e4bc47d6a39 797 gSlide[num] = msg[2].f;
casiotone401 15:3e4bc47d6a39 798 continue;
casiotone401 15:3e4bc47d6a39 799
casiotone401 17:55e5136790a6 800 } else if (!strncmp(msg[0].address + (len - offset-2) - 7, "accent/", 7) && (num != -1)) {
casiotone401 17:55e5136790a6 801
casiotone401 17:55e5136790a6 802 if (isdigit(msg[0].address[len-3]))
casiotone401 17:55e5136790a6 803 {
casiotone401 17:55e5136790a6 804 num = msg[0].address[len-3] - '0' - 1;
casiotone401 17:55e5136790a6 805 }
casiotone401 17:55e5136790a6 806
casiotone401 17:55e5136790a6 807 gAccent[num] = msg[2].i;
casiotone401 17:55e5136790a6 808 continue;
casiotone401 17:55e5136790a6 809
casiotone401 17:55e5136790a6 810 } else if (!strncmp(msg[0].address + (len - offset-3) - 7, "accent/", 7) && (num != -1)) {
casiotone401 17:55e5136790a6 811
casiotone401 17:55e5136790a6 812 if (isdigit(msg[0].address[len-3]))
casiotone401 17:55e5136790a6 813 {
casiotone401 17:55e5136790a6 814 num = msg[0].address[len-3] - '0' - 1;
casiotone401 17:55e5136790a6 815
casiotone401 17:55e5136790a6 816 if (isdigit(msg[0].address[len-4]))
casiotone401 17:55e5136790a6 817 {
casiotone401 17:55e5136790a6 818 num += 10;
casiotone401 17:55e5136790a6 819 }
casiotone401 17:55e5136790a6 820 }
casiotone401 17:55e5136790a6 821
casiotone401 17:55e5136790a6 822 gAccent[num] = msg[2].i;
casiotone401 17:55e5136790a6 823 continue;
casiotone401 17:55e5136790a6 824
casiotone401 17:55e5136790a6 825 } else if (!strncmp(msg[0].address + (len - offset) - 4, "euca", 4) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 826 if (num > 5) continue;
casiotone401 15:3e4bc47d6a39 827 gEucA[num] = msg[2].f;
casiotone401 15:3e4bc47d6a39 828 continue;
casiotone401 15:3e4bc47d6a39 829
casiotone401 17:55e5136790a6 830 } else if (!strncmp(msg[0].address + (len - offset) - 4, "eucb", 4) && (num != -1)) {
casiotone401 15:3e4bc47d6a39 831 if (num > 5) continue;
casiotone401 15:3e4bc47d6a39 832 gEucB[num] = msg[2].f;
casiotone401 15:3e4bc47d6a39 833 continue;
casiotone401 15:3e4bc47d6a39 834
casiotone401 20:a44f4a024902 835 } else if (!strncmp(msg[0].address + (len - offset) - 3, "acv", 3) && (num != -1)) {
casiotone401 20:a44f4a024902 836 if (num > 3) continue;
casiotone401 20:a44f4a024902 837 gArd_cv[num] = msg[2].f * (SCALING_N);
casiotone401 20:a44f4a024902 838 continue;
casiotone401 20:a44f4a024902 839
casiotone401 20:a44f4a024902 840 } else if (!strncmp(msg[0].address + (len - offset) - 3, "pot", 3) && (num != -1)) {
casiotone401 20:a44f4a024902 841 if (num > 2) continue;
casiotone401 20:a44f4a024902 842 gArdPot[num] = msg[2].f;
casiotone401 20:a44f4a024902 843 continue;
casiotone401 20:a44f4a024902 844
casiotone401 20:a44f4a024902 845 } else if (!strncmp(msg[0].address + (len - offset) - 2, "sw", 2) && (num != -1)) {
casiotone401 20:a44f4a024902 846 if (num > 2) continue;
casiotone401 20:a44f4a024902 847 if (msg[2].i != 0) gArdSW[num] = true;
casiotone401 20:a44f4a024902 848 else gArdSW[num] = false;
casiotone401 20:a44f4a024902 849 continue;
casiotone401 20:a44f4a024902 850
casiotone401 15:3e4bc47d6a39 851 } else {
casiotone401 10:ccfeb687c3f2 852 continue;
casiotone401 10:ccfeb687c3f2 853 }
casiotone401 10:ccfeb687c3f2 854
casiotone401 15:3e4bc47d6a39 855 } while (bundleflag);
casiotone401 15:3e4bc47d6a39 856 }
casiotone401 15:3e4bc47d6a39 857 }
casiotone401 15:3e4bc47d6a39 858