Files
-
blinds / hardware_design / pcb / blinds_v60.brd
-
blinds / hardware_design / pcb / blinds_v60.sch
-
braids / hardware_design / pcb / braids_v50.brd
-
braids / hardware_design / pcb / braids_v50.sch
-
branches / hardware_design / pcb / branches_v40.brd
-
branches / hardware_design / pcb / branches_v40.sch
-
clouds / hardware_design / pcb / clouds_v30.brd
-
clouds / hardware_design / pcb / clouds_v30.sch
-
ears / hardware_design / panel / ears_panel_v30.brd
-
ears / hardware_design / panel / ears_panel_v30.sch
-
ears / hardware_design / pcb / ears_v40.brd
-
ears / hardware_design / pcb / ears_v40.sch
-
edges / hardware_design / pcb / edges_expander_v01.brd
-
edges / hardware_design / pcb / edges_expander_v01.sch
-
edges / hardware_design / pcb / edges_v20.brd
-
edges / hardware_design / pcb / edges_v20.sch
-
elements / hardware_design / pcb / elements_v02.brd
-
elements / hardware_design / pcb / elements_v02.sch
-
frames / hardware_design / pcb / frames_v03.brd
-
frames / hardware_design / pcb / frames_v03.sch
-
grids / hardware_design / pcb / grids_v02.brd
-
grids / hardware_design / pcb / grids_v02.sch
-
kinks / hardware_design / pcb / kinks_v41.brd
-
kinks / hardware_design / pcb / kinks_v41.sch
-
links / hardware_design / pcb / links_v40.brd
-
links / hardware_design / pcb / links_v40.sch
-
marbles / hardware_design / pcb / marbles_v70.brd
-
marbles / hardware_design / pcb / marbles_v70.sch
-
peaks / hardware_design / pcb / peaks_v30.brd
-
peaks / hardware_design / pcb / peaks_v30.sch
-
plaits / hardware_design / pcb / plaits_v50.brd
-
plaits / hardware_design / pcb / plaits_v50.sch
-
rings / hardware_design / pcb / rings_v30.brd
-
rings / hardware_design / pcb / rings_v30.sch
-
ripples / hardware_design / pcb / ripples_v40.brd
-
ripples / hardware_design / pcb / ripples_v40.sch
-
shades / hardware_design / pcb / shades_v30.brd
-
shades / hardware_design / pcb / shades_v30.sch
-
shelves / hardware_design / pcb / shelves_expander_v10.brd
-
shelves / hardware_design / pcb / shelves_expander_v10.sch
-
shelves / hardware_design / pcb / shelves_v05.brd
-
shelves / hardware_design / pcb / shelves_v05.sch
-
stages / hardware_design / pcb / stages_v70.brd
-
stages / hardware_design / pcb / stages_v70.sch
-
streams / hardware_design / pcb / streams_v02_bargraph.brd
-
streams / hardware_design / pcb / streams_v02_bargraph.sch
-
streams / hardware_design / pcb / streams_v05.brd
-
streams / hardware_design / pcb / streams_v05.sch
-
tides / hardware_design / pcb / tides_v40.brd
-
tides / hardware_design / pcb / tides_v40.sch
-
veils / hardware_design / pcb / veils_v40.brd
-
veils / hardware_design / pcb / veils_v40.sch
-
volts / hardware_design / pcb / volts_v01.brd
-
volts / hardware_design / pcb / volts_v01.sch
-
warps / hardware_design / pcb / warps_v30.brd
-
warps / hardware_design / pcb / warps_v30.sch
-
yarns / hardware_design / pcb / yarns_v03.brd
-
yarns / hardware_design / pcb / yarns_v03.sch
Last update 6 years 3 months
by
Olivier Gillet
Filesplaits | |
---|---|
.. | |
bootloader | |
drivers | |
dsp | |
hardware_design | |
resources | |
test | |
__init__.py | |
makefile | |
plaits.cc | |
pot_controller.h | |
resources.cc | |
resources.h | |
settings.cc | |
settings.h | |
ui.cc | |
ui.h |
plaits.cc// Copyright 2016 Olivier Gillet. // // Author: Olivier Gillet (ol.gillet@gmail.com) // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. // // See http://creativecommons.org/licenses/MIT/ for more information. #include <stm32f37x_conf.h> #include "plaits/drivers/audio_dac.h" #include "plaits/drivers/debug_pin.h" #include "plaits/drivers/debug_port.h" #include "plaits/dsp/dsp.h" #include "plaits/dsp/voice.h" #include "plaits/settings.h" #include "plaits/ui.h" using namespace plaits; using namespace stmlib; // #define PROFILE_INTERRUPT 1 const bool test_adc_noise = false; AudioDac audio_dac; DebugPort debug_port; Modulations modulations; Patch patch; Settings settings; Ui ui; Voice voice; char shared_buffer[16384]; uint32_t test_ramp; // Default interrupt handlers. extern "C" { void NMI_Handler() { } void HardFault_Handler() { while (1); } void MemManage_Handler() { while (1); } void BusFault_Handler() { while (1); } void UsageFault_Handler() { while (1); } void SVC_Handler() { } void DebugMon_Handler() { } void PendSV_Handler() { } void __cxa_pure_virtual() { while (1); } } void FillBuffer(AudioDac::Frame* output, size_t size) { #ifdef PROFILE_INTERRUPT TIC #endif // PROFILE_INTERRUPT IWDG_ReloadCounter(); ui.Poll(); if (test_adc_noise) { static float note_lp = 0.0f; float note = modulations.note; ONE_POLE(note_lp, note, 0.0001f); float cents = (note - note_lp) * 100.0f; CONSTRAIN(cents, -8.0f, +8.0f); while (size--) { output->r = output->l = static_cast<int16_t>(cents * 4040.0f); ++output; } } else if (ui.test_mode()) { // 100 Hz ascending and descending ramps. while (size--) { output->l = ~test_ramp >> 16; output->r = test_ramp >> 16; test_ramp += 8947848; ++output; } } else { voice.Render(patch, modulations, (Voice::Frame*)(output), size); ui.set_active_engine(voice.active_engine()); } if (debug_port.readable()) { uint8_t command = debug_port.Read(); uint8_t response = ui.HandleFactoryTestingRequest(command); debug_port.Write(response); } #ifdef PROFILE_INTERRUPT TOC #endif // PROFILE_INTERRUPT } void Init() { NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x8000); IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable); IWDG_SetPrescaler(IWDG_Prescaler_16); BufferAllocator allocator(shared_buffer, 16384); voice.Init(&allocator); volatile size_t counter = 1000000; while (counter--); bool freshly_baked = !settings.Init(); if (freshly_baked) { #ifdef PROFILE_INTERRUPT DebugPin::Init(); #else debug_port.Init(); #endif // PROFILE_INTERRUPT } ui.Init(&patch, &modulations, &settings); audio_dac.Init(48000, kBlockSize); audio_dac.Start(&FillBuffer); IWDG_Enable(); } int main(void) { Init(); while (1) { } }