# HG changeset patch # User Giulio Moro # Date 1453304148 0 # Node ID c706be7daad7e8a250d5ecebe2b85b2c58770981 # Parent d7148d21aaa59ee6de3563d5066acaf40011dd8d Fixed misbehaviour of GPIO when -C2: the GPIO buffer was being processed at double sampling rate and so for the second part of the buffer, it was just processing zeros. Closes #1532. diff -r d7148d21aaa5 -r c706be7daad7 include/pru_rtaudio_bin.h --- a/include/pru_rtaudio_bin.h Tue Jan 19 02:54:13 2016 +0000 +++ b/include/pru_rtaudio_bin.h Wed Jan 20 15:35:48 2016 +0000 @@ -655,7 +655,7 @@ 0x12e3efef, 0x80f73c8f, 0x0104f7f7, - 0xc901f863, + 0xc901f867, 0x24ffffe2, 0x10e2ece7, 0x0904e7e7, @@ -689,7 +689,11 @@ 0x24c1909c, 0xe1003c9b, 0xe14c3a87, - 0xc903f807, + 0xc903f80b, + 0x4902e904, + 0x1101eafb, + 0x6900fb08, + 0x2102b300, 0x1103e1fb, 0x6900fb05, 0xf100269b, @@ -752,13 +756,13 @@ 0x0104f3f3, 0x1504f8f8, 0x0101e1e1, - 0x6ee9e177, + 0x6ee9e173, 0x79000004, 0x1504f8f8, 0x0102e1e1, - 0x6ee9e173, + 0x6ee9e16f, 0x0101eaea, - 0x6eebea70, + 0x6eebea6c, 0x10f0f0e2, 0x10f1f1f0, 0x10e2e2f1, @@ -787,7 +791,7 @@ 0x00e1e3e3, 0xe1002382, 0xf1003982, - 0x5700e243, + 0x5700e23f, 0x240000fb, 0xe1443d9b, 0xc901f80c, diff -r d7148d21aaa5 -r c706be7daad7 pru_rtaudio.p --- a/pru_rtaudio.p Tue Jan 19 02:54:13 2016 +0000 +++ b/pru_rtaudio.p Wed Jan 20 15:35:48 2016 +0000 @@ -383,7 +383,7 @@ JMP r28.w0 // go back to ADC_WRITE_AND_PROCESS_GPIO .macro HANG //useful for debugging -DALOOP: +DALOOP: set r30.t14 clr r30.t14 QBA DALOOP @@ -480,8 +480,15 @@ ADC_CS_ASSERT ADC_TX in QBBC GPIO_DONE, reg_flags, FLAG_BIT_USE_DIGITAL //skip if DIGITAL is disabled + QBLT CASE_4_OR_8_CHANNELS, reg_num_channels, 2 +CASE_2_CHANNELS: + AND r27, reg_frame_current, 0x1 + QBNE GPIO_DONE, r27, 0 + JMP DO_GPIO +CASE_4_OR_8_CHANNELS: AND r27, do_gpio, 0x3 // only do a DIGITAL every 2 SPI I/O QBNE GPIO_DONE, r27, 0 +DO_GPIO: //from here to GPIO_DONE takes 1.8us, while usually ADC_WAIT_FOR_FINISH only waits for 1.14us. //TODO: it would be better to split the DIGITAL stuff in two parts: //- one taking place during DAC_WRITE which sets the GPIO_OE