<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=Windows-1252">
<style type="text/css" style="display:none;"> P {margin-top:0;margin-bottom:0;} </style>
</head>
<body dir="ltr">
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Hi Dave,</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Thats a really good tip to use the I2C decoding feature on the Tek.  I imagine by now its standard feature on the uhhh, clone Rigol scopes.</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
A look at basic circular buffer interrupt structure may help:</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Buffer of length x is assigned;</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
head and tail pointers to buffer are equal;<br>
</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Interrupt driven code is input from serial to buffer, moving head buffer and tail pointer +1 and storing new data;</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
application reads from tail buffer pointer, non interrupt driven,  at its own speed, decrements tail pointer;</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Modulo buffer len math on the pointers, these two buffer pointers chase each other as interrupts and application run.</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Randy<br>
</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div>
<div id="appendonsend"></div>
<div style="font-family:Calibri,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)">
<br>
</div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="divRplyFwdMsg" dir="ltr"><font style="font-size:11pt" face="Calibri, sans-serif" color="#000000"><b>From:</b> Synth-diy <synth-diy-bounces@synth-diy.org> on behalf of Dave Brown <davebr@modularsynthesis.com><br>
<b>Sent:</b> Thursday, March 19, 2020 11:13 PM<br>
<b>To:</b> synth-diy@synth-diy.org <synth-diy@synth-diy.org><br>
<b>Subject:</b> Re: [sdiy] MIDI I/O c code..</font>
<div> </div>
</div>
<div lang="EN-US">
<div class="x_WordSection1">
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:11.0pt; font-family:"Calibri","sans-serif"; color:#1F497D">In 2005 I wrote a MIDI processing program to do minor manipulation such as transposing notes, changing CC messages, etc. I did it in assembly in an 8 MHZ ATTINY2313. Receive and
 transmit are interrupt driven out of 32 byte buffers each. It handles running status and can filter out some of the real time messages. It will take everything I can throw at it with two hands on the keyboard. It is highly optimized assembly but I suspect
 your issue is not emptying the buffers fast enough.</span></p>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:11.0pt; font-family:"Calibri","sans-serif"; color:#1F497D"> </span></p>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:11.0pt; font-family:"Calibri","sans-serif"; color:#1F497D">I also run this same code on a 16 MHz Basic Stamp which does have I2C D/As which do take some time so care has to be taken. The same code on an Arduino runs about 4.5X faster
 because the I2C is handled in hardware whereas on the Basic Stamp it is done in software.</span></p>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:11.0pt; font-family:"Calibri","sans-serif"; color:#1F497D"> </span></p>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:11.0pt; font-family:"Calibri","sans-serif"; color:#1F497D">I found my Tektronix scope with I2C decoding capability invaluable in seeing where my bottlenecks were in all the communications. Even without that capability I would often use
 an external pin to create timing signals so I could accurately measure code execution. But I’m a hw guy by nature.</span></p>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:11.0pt; font-family:"Calibri","sans-serif"; color:#1F497D"> </span></p>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:11.0pt; font-family:"Calibri","sans-serif"; color:#1F497D">FYI</span></p>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:11.0pt; font-family:"Calibri","sans-serif"; color:#1F497D"><br>
Dave</span></p>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:11.0pt; font-family:"Calibri","sans-serif"; color:#1F497D"> </span></p>
<div style="border:none; border-left:solid blue 1.5pt; padding:0in 0in 0in 4.0pt">
<div>
<blockquote style="border:none; border-left:solid #CCCCCC 1.0pt; padding:0in 0in 0in 6.0pt; margin-left:4.8pt; margin-right:0in">
<div>
<div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<b><span style="font-size:10.0pt; font-family:"Tahoma","sans-serif"" lang="FR">De :</span></b><span style="font-size:10.0pt; font-family:"Tahoma","sans-serif"" lang="FR"> dougall [mailto:<a href="mailto:dougalli@gmail.com" target="_blank">dougalli@gmail.com</a>]
<br>
<b>Envoyé :</b> 19 mars 2020 21:06<br>
<b>À :</b> <a href="mailto:eidorian@aladan.net" target="_blank">eidorian@aladan.net</a><br>
<b>Cc :</b> Jean-Pierre Desrochers; <a href="mailto:Synth-diy@synth-diy.org" target="_blank">
Synth-diy@synth-diy.org</a><br>
<b>Objet :</b> Re: [sdiy] MIDI I/O c code..</span><span lang="FR-CA"></span></p>
<div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span lang="FR-CA"> Are you handling running status and note off sent as zero velocity note on?</span></p>
<div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span lang="FR-CA"> -d</span></p>
</div>
</div>
<div>
<div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span lang="FR-CA"> On Fri, 20 Mar 2020 at 11:55, <<a href="mailto:eidorian@aladan.net" target="_blank">eidorian@aladan.net</a>> wrote:</span></p>
</div>
<blockquote style="border:none; border-left:solid #CCCCCC 1.0pt; padding:0in 0in 0in 6.0pt; margin-left:4.8pt; margin-top:5.0pt; margin-right:0in; margin-bottom:5.0pt">
<div>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">Sorry, I don't have example code for you, but here is some analysis that I hope might help point you in the right direction:</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">20MHz / 31,250Hz => ~640 instructions per MIDI data bit, or 6,400 instructions per MIDI data byte.  That's quite a lot of instruction execution time between notes, so I'd be checking
 the efficiency/optimisation of the code.</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">How long is it taking to update the analog outputs and do other processing?  If it's updating all 8 CVs via a "slow" protocol like I2C every time it loops then that might be taking
 a while, and maybe you need a different approach (i.e. only update a CV output when it changes).</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">How have you implemented the FIFO?  Do you have locking to ensure the interrupt isn't writing to it while the main loop is updating it?</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">Create a debug version that has checks on the FIFO size in the interrupt, and sets an LED on if it overflows, so you can confirm for certainly whether or not that's the problem.</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">What I do (with 30+ years of programming experience) is pretend I'm the CPU, and "execute" the code in my head (or on paper if complex) in order to try to work out what unplanned
 or unexpected things might be happening to cause the problematic behaviour.</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">Cheers,<br>
A.</span><span lang="FR-CA"></span></p>
<div id="x_m_-1322366504434334221gmail-m_5822220122528591338signature">
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">---</span><span lang="FR-CA"></span></p>
<div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Courier New"" lang="FR-CA"> </span><span lang="FR-CA"></span></p>
</div>
</div>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA"> </span><span lang="FR-CA"></span></p>
<p id="x_m_-1322366504434334221gmail-m_5822220122528591338reply-intro" style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">On 20-03-2020 11:14, Jean-Pierre Desrochers wrote:</span><span lang="FR-CA"></span></p>
<blockquote style="border:none; border-left:solid #1010FF 1.5pt; padding:0in 0in 0in 5.0pt; margin-left:0in; margin-top:5.0pt; margin-right:0in; margin-bottom:5.0pt">
<blockquote style="border:none; border-left:solid #1010FF 1.5pt; padding:0in 0in 0in 5.0pt; margin-left:0in; margin-top:5.0pt; margin-right:0in; margin-bottom:5.0pt">
<div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA"> </span><span lang="FR-CA"></span></p>
</div>
</blockquote>
</blockquote>
<blockquote style="border:none; border-left:solid #1010FF 1.5pt; padding:0in 0in 0in 5.0pt; margin-left:0in; margin-top:5.0pt; margin-right:0in; margin-bottom:5.0pt">
<div id="x_m_-1322366504434334221gmail-m_5822220122528591338replybody1">
<div>
<div>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">I’m working on a new polyphonic MIDI to CV module (8 voices).</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">So far I did my tests with an old PIC16F887 @ 20Mhz micro I had on hand.</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">I use a USART interrupt driven c function to ‘catch’ all the incoming MIDI bytes.</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">My code is pretty fast, but still, since I only read one MIDI channel (1-16) at the time
<br>
when I play very fast chords on an external keyboard</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">all the notes are read in the incoming queue but sometimes</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">I get stuck notes or unread ones..</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">Same thing happens when playing MIDI files on Cakewalk SONAR
<br>
feeding my prototype with  a MIDI cable.<br>
The interrupt function grabs each incoming byte and put them</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">In a receive buffer of 32 bytes and the main () reads and treats them in a FIFO manner</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">Later in the main loop.</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA"> </span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<em><span style="font-family:"Verdana","sans-serif"" lang="FR-CA">-Would a 32Mhz micro do a difference in the USART interrupt reading speed ?</span></em><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<em><span style="font-family:"Verdana","sans-serif"" lang="FR-CA">-And is 32 bytes long enough for the RxBuffer to handle a 6 voices chords ?</span></em><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<em><span style="font-family:"Verdana","sans-serif"" lang="FR-CA">-And finaly I checked the web for a ‘decent’ C code examples</span></em><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<em><span style="font-family:"Verdana","sans-serif"" lang="FR-CA">  for MIDI reception (MIDI Tx is much easier to implement) with no success..</span></em><i><span style="font-family:"Verdana","sans-serif"" lang="FR-CA"><br>
<em><span style="font-family:"Verdana","sans-serif"">  ‘Obscure’ Arduino libraries all around with no explainations of its inner code.</span></em></span></i><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA"> </span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">Did anybody use good C code available ?</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA">JP</span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA"> </span><span lang="FR-CA"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA"><a href="mailto:Synth-diy@synth-diy.org" target="_blank">Synth-diy@synth-diy.org</a></span><span lang="FR-CA"></span></p>
</div>
</div>
</div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Verdana","sans-serif"" lang="FR-CA"> </span><span lang="FR-CA"></span></p>
<div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span style="font-size:10.0pt; font-family:"Courier New"" lang="FR-CA">_______________________________________________<br>
Synth-diy mailing list<br>
<a href="mailto:Synth-diy@synth-diy.org" target="_blank">Synth-diy@synth-diy.org</a><br>
<a href="http://synth-diy.org/mailman/listinfo/synth-diy" target="_blank">http://synth-diy.org/mailman/listinfo/synth-diy</a></span><span lang="FR-CA"></span></p>
</div>
</blockquote>
</div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
<span lang="FR-CA">_______________________________________________<br>
Synth-diy mailing list<br>
<a href="mailto:Synth-diy@synth-diy.org" target="_blank">Synth-diy@synth-diy.org</a><br>
<a href="http://synth-diy.org/mailman/listinfo/synth-diy" target="_blank">http://synth-diy.org/mailman/listinfo/synth-diy</a></span></p>
</blockquote>
</div>
</div>
</div>
<p class="x_MsoNormal" style="margin: 0in 0in 0.0001pt; font-size: 12pt; font-family: "Times New Roman", "serif";margin-right: 0in; margin-left: 0in; font-size: 12pt; font-family: "Times New Roman", "serif";">
_______________________________________________<br>
Synth-diy mailing list<br>
<a href="mailto:Synth-diy@synth-diy.org" target="_blank">Synth-diy@synth-diy.org</a><br>
<a href="http://synth-diy.org/mailman/listinfo/synth-diy" target="_blank">http://synth-diy.org/mailman/listinfo/synth-diy</a></p>
</blockquote>
</div>
</div>
</div>
</div>
</div>
</body>
</html>