fix deadlock/race condition
[clinton/Smoothieware.git] / src / main.cpp
CommitLineData
df27a6a3 1/*
4cff3ded
AW
2 This file is part of Smoothie (http://smoothieware.org/). The motion control part is heavily based on Grbl (https://github.com/simen/grbl).
3 Smoothie is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
4 Smoothie is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
df27a6a3 5 You should have received a copy of the GNU General Public License along with Smoothie. If not, see <http://www.gnu.org/licenses/>.
4cff3ded
AW
6*/
7
4cff3ded 8#include "libs/Kernel.h"
88443c6b 9
4cff3ded 10#include "modules/tools/laser/Laser.h"
65d97468 11#include "modules/tools/spindle/Spindle.h"
14ecdbd7 12#include "modules/tools/extruder/ExtruderMaker.h"
3c132bd0 13#include "modules/tools/temperaturecontrol/TemperatureControlPool.h"
201bcb94 14#include "modules/tools/endstops/Endstops.h"
88443c6b 15#include "modules/tools/zprobe/ZProbe.h"
ed866a4b 16#include "modules/tools/scaracal/SCARAcal.h"
cc1d3b1f 17#include "modules/tools/switch/SwitchPool.h"
abe97b79 18#include "modules/tools/temperatureswitch/TemperatureSwitch.h"
88443c6b 19
3fceb8eb 20#include "modules/robot/Conveyor.h"
4eb9c745 21#include "modules/utils/simpleshell/SimpleShell.h"
cf44cb59 22#include "modules/utils/configurator/Configurator.h"
0e8b102e 23#include "modules/utils/currentcontrol/CurrentControl.h"
1cf49da1 24#include "modules/utils/player/Player.h"
81b547a1 25#include "modules/utils/pausebutton/PauseButton.h"
4a679a75 26#include "modules/utils/PlayLed/PlayLed.h"
35089dc7 27#include "modules/utils/panel/Panel.h"
d4ee6ee2 28#include "libs/Network/uip/Network.h"
61134a65 29#include "Config.h"
7af0714f 30#include "checksumm.h"
8d54c34c 31#include "ConfigValue.h"
35089dc7 32
2487f50b 33// #include "libs/ChaNFSSD/SDFileSystem.h"
4eb9c745
AW
34#include "libs/nuts_bolts.h"
35#include "libs/utils.h"
4cff3ded 36
40c831b8
MM
37// Debug
38#include "libs/SerialMessage.h"
a39e1557 39
7c3c5e0f
MM
40#include "libs/USBDevice/USB.h"
41#include "libs/USBDevice/USBMSD/USBMSD.h"
42#include "libs/USBDevice/USBMSD/SDCard.h"
43#include "libs/USBDevice/USBSerial/USBSerial.h"
9f0f2c8f 44#include "libs/USBDevice/DFU.h"
246fd409 45#include "libs/SDFAT.h"
61134a65 46#include "StreamOutputPool.h"
17c89e4d 47#include "ToolManager.h"
246fd409 48
073b1698
MM
49#include "libs/Watchdog.h"
50
582559c6 51#include "version.h"
61134a65 52#include "system_LPC17xx.h"
582559c6 53
a2f7633f
JM
54#include "mbed.h"
55
764b2de4 56#define second_usb_serial_enable_checksum CHECKSUM("second_usb_serial_enable")
82d1ceb3 57#define disable_msd_checksum CHECKSUM("msd_disable")
21320fc6 58#define disable_leds_checksum CHECKSUM("leds_disable")
f431d45c 59#define dfu_enable_checksum CHECKSUM("dfu_enable")
764b2de4 60
073b1698
MM
61// Watchdog wd(5000000, WDT_MRI);
62
d337942a 63// USB Stuff
5c84acba 64SDCard sd __attribute__ ((section ("AHBSRAM0"))) (P0_9, P0_8, P0_7, P0_6); // this selects SPI1 as the sdcard as it is on Smoothieboard
82414cb2 65//SDCard sd(P0_18, P0_17, P0_15, P0_16); // this selects SPI0 as the sdcard
eaf7b7eb 66//SDCard sd(P0_18, P0_17, P0_15, P2_8); // this selects SPI0 as the sdcard witrh a different sd select
82414cb2 67
5c84acba
JM
68USB u __attribute__ ((section ("AHBSRAM0")));
69USBSerial usbserial __attribute__ ((section ("AHBSRAM0"))) (&u);
45509e68
JM
70#ifndef DISABLEMSD
71USBMSD msc __attribute__ ((section ("AHBSRAM0"))) (&u, &sd);
72#else
8c6d9683 73USBMSD *msc= NULL;
45509e68 74#endif
7c3c5e0f 75
5c84acba 76SDFAT mounter __attribute__ ((section ("AHBSRAM0"))) ("sd", &sd);
a39e1557 77
ca3a28b4
MM
78GPIO leds[5] = {
79 GPIO(P1_18),
80 GPIO(P1_19),
81 GPIO(P1_20),
82 GPIO(P1_21),
83 GPIO(P4_28)
84};
a39e1557 85
9e089978 86// debug pins, only used if defined in src/makefile
9e089978
JM
87#ifdef STEPTICKER_DEBUG_PIN
88GPIO stepticker_debug_pin(STEPTICKER_DEBUG_PIN);
89#endif
90
8a1a44cb 91void init() {
2a1089e1
AW
92
93 // Default pins to low status
94 for (int i = 0; i < 5; i++){
ca3a28b4 95 leds[i].output();
82d1ceb3 96 leds[i]= 0;
ca3a28b4
MM
97 }
98
9e089978
JM
99#ifdef STEPTICKER_DEBUG_PIN
100 stepticker_debug_pin.output();
101 stepticker_debug_pin= 0;
102#endif
103
4464301d 104 Kernel* kernel = new Kernel();
a39e1557 105
577414f6 106 kernel->streams->printf("Smoothie Running @%ldMHz\r\n", SystemCoreClock / 1000000);
582559c6
JM
107 Version version;
108 kernel->streams->printf(" Build version %s, Build date %s\r\n", version.get_build(), version.get_build_date());
4cff3ded 109
21320fc6
JM
110 //some boards don't have leds.. TOO BAD!
111 kernel->use_leds= !kernel->config->value( disable_leds_checksum )->by_default(false)->as_bool();
112
f431d45c
JM
113 bool sdok= (sd.disk_initialize() == 0);
114 if(!sdok) kernel->streams->printf("SDCard is disabled\r\n");
115
45509e68 116#ifdef DISABLEMSD
82d1ceb3 117 // attempt to be able to disable msd in config
f431d45c 118 if(sdok && !kernel->config->value( disable_msd_checksum )->by_default(false)->as_bool()){
8c6d9683
JM
119 // HACK to zero the memory USBMSD uses as it and its objects seem to not initialize properly in the ctor
120 size_t n= sizeof(USBMSD);
121 void *v = AHB0.alloc(n);
122 memset(v, 0, n); // clear the allocated memory
123 msc= new(v) USBMSD(&u, &sd); // allocate object using zeroed memory
124 }else{
125 msc= NULL;
126 kernel->streams->printf("MSD is disabled\r\n");
127 }
45509e68 128#endif
82d1ceb3 129
82d1ceb3 130
2a1089e1 131 // Create and add main modules
4eb9c745 132 kernel->add_module( new SimpleShell() );
d3a6143b 133 kernel->add_module( new Configurator() );
0e8b102e 134 kernel->add_module( new CurrentControl() );
df27a6a3 135 kernel->add_module( new PauseButton() );
4a679a75 136 kernel->add_module( new PlayLed() );
201bcb94 137 kernel->add_module( new Endstops() );
1cf49da1 138 kernel->add_module( new Player() );
df930a5f 139
24584878 140
df930a5f 141 // these modules can be completely disabled in the Makefile by adding to EXCLUDE_MODULES
24584878
JM
142 #ifndef NO_TOOLS_SWITCH
143 SwitchPool *sp= new SwitchPool();
144 sp->load_tools();
145 delete sp;
146 #endif
df930a5f 147 #ifndef NO_TOOLS_EXTRUDER
ec6fde0b 148 // NOTE this must be done first before Temperature control so ToolManager can handle Tn before temperaturecontrol module does
24584878
JM
149 ExtruderMaker *em= new ExtruderMaker();
150 em->load_tools();
151 delete em;
df930a5f 152 #endif
c7689006 153 #ifndef NO_TOOLS_TEMPERATURECONTROL
ec6fde0b 154 // Note order is important here must be after extruder so Tn as a parameter will get executed first
24584878
JM
155 TemperatureControlPool *tp= new TemperatureControlPool();
156 tp->load_tools();
157 delete tp;
c7689006 158 #endif
df930a5f
JM
159 #ifndef NO_TOOLS_LASER
160 kernel->add_module( new Laser() );
161 #endif
65d97468
PA
162 #ifndef NO_TOOLS_SPINDLE
163 kernel->add_module( new Spindle() );
164 #endif
df930a5f 165 #ifndef NO_UTILS_PANEL
58d6d841 166 kernel->add_module( new Panel() );
df930a5f
JM
167 #endif
168 #ifndef NO_TOOLS_TOUCHPROBE
3779fd74 169 kernel->add_module( new Touchprobe() );
df930a5f 170 #endif
88443c6b
JM
171 #ifndef NO_TOOLS_ZPROBE
172 kernel->add_module( new ZProbe() );
173 #endif
ed866a4b
QH
174 #ifndef NO_TOOLS_SCARACAL
175 kernel->add_module( new SCARAcal() );
176 #endif
df930a5f 177 #ifndef NONETWORK
d4ee6ee2 178 kernel->add_module( new Network() );
df930a5f 179 #endif
1dc339ee 180 #ifndef NO_TOOLS_TEMPERATURESWITCH
e6b0fc38 181 // Must be loaded after TemperatureControlPool
1dc339ee 182 kernel->add_module( new TemperatureSwitch() );
183 #endif
81b547a1 184
4a679a75 185 // Create and initialize USB stuff
7c3c5e0f 186 u.init();
8a004d38 187
45509e68 188#ifdef DISABLEMSD
8c6d9683
JM
189 if(sdok && msc != NULL){
190 kernel->add_module( msc );
191 }
45509e68
JM
192#else
193 kernel->add_module( &msc );
194#endif
b813be45 195
7c3c5e0f 196 kernel->add_module( &usbserial );
764b2de4 197 if( kernel->config->value( second_usb_serial_enable_checksum )->by_default(false)->as_bool() ){
f431d45c
JM
198 kernel->add_module( new(AHB0) USBSerial(&u) );
199 }
200
201 if( kernel->config->value( dfu_enable_checksum )->by_default(false)->as_bool() ){
202 kernel->add_module( new(AHB0) DFU(&u));
764b2de4 203 }
7c3c5e0f
MM
204 kernel->add_module( &u );
205
a4bfde91
JM
206 // clear up the config cache to save some memory
207 kernel->config->config_cache_clear();
208
21320fc6
JM
209 if(kernel->use_leds) {
210 // set some leds to indicate status... led0 init doe, led1 mainloop running, led2 idle loop running, led3 sdcard ok
211 leds[0]= 1; // indicate we are done with init
212 leds[3]= sdok?1:0; // 4th led inidicates sdcard is available (TODO maye should indicate config was found)
213 }
82d1ceb3 214
33e4cc02
JM
215 if(sdok) {
216 // load config override file if present
217 // NOTE only Mxxx commands that set values should be put in this file. The file is generated by M500
218 FILE *fp= fopen(kernel->config_override_filename(), "r");
219 if(fp != NULL) {
220 char buf[132];
221 kernel->streams->printf("Loading config override file: %s...\n", kernel->config_override_filename());
222 while(fgets(buf, sizeof buf, fp) != NULL) {
223 kernel->streams->printf(" %s", buf);
224 if(buf[0] == ';') continue; // skip the comments
225 struct SerialMessage message= {&(StreamOutput::NullStream), buf};
226 kernel->call_event(ON_CONSOLE_LINE_RECEIVED, &message);
227 }
228 kernel->streams->printf("config override file executed\n");
229 fclose(fp);
230 }
231 }
8a1a44cb
JM
232}
233
234int main()
235{
236 init();
33e4cc02 237
82d1ceb3 238 uint16_t cnt= 0;
2a1089e1 239 // Main loop
4cff3ded 240 while(1){
8a1a44cb 241 if(THEKERNEL->use_leds) {
21320fc6
JM
242 // flash led 2 to show we are alive
243 leds[1]= (cnt++ & 0x1000) ? 1 : 0;
244 }
8a1a44cb
JM
245 THEKERNEL->call_event(ON_MAIN_LOOP);
246 THEKERNEL->call_event(ON_IDLE);
4cff3ded 247 }
4cff3ded 248}