make ok per line the default. can be disbaled (returning to legacy behavior by settin...
[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"
13320983 19#include "modules/tools/drillingcycles/Drillingcycles.h"
89b1a6eb 20#include "FilamentDetector.h"
3eca6882 21#include "MotorDriverControl.h"
88443c6b 22
3fceb8eb 23#include "modules/robot/Conveyor.h"
4eb9c745 24#include "modules/utils/simpleshell/SimpleShell.h"
cf44cb59 25#include "modules/utils/configurator/Configurator.h"
0e8b102e 26#include "modules/utils/currentcontrol/CurrentControl.h"
1cf49da1 27#include "modules/utils/player/Player.h"
35e7b158 28#include "modules/utils/killbutton/KillButton.h"
4a679a75 29#include "modules/utils/PlayLed/PlayLed.h"
35089dc7 30#include "modules/utils/panel/Panel.h"
d4ee6ee2 31#include "libs/Network/uip/Network.h"
61134a65 32#include "Config.h"
7af0714f 33#include "checksumm.h"
8d54c34c 34#include "ConfigValue.h"
dc3542cf 35#include "StepTicker.h"
35089dc7 36
2487f50b 37// #include "libs/ChaNFSSD/SDFileSystem.h"
4eb9c745
AW
38#include "libs/nuts_bolts.h"
39#include "libs/utils.h"
4cff3ded 40
40c831b8
MM
41// Debug
42#include "libs/SerialMessage.h"
a39e1557 43
7c3c5e0f
MM
44#include "libs/USBDevice/USB.h"
45#include "libs/USBDevice/USBMSD/USBMSD.h"
46#include "libs/USBDevice/USBMSD/SDCard.h"
47#include "libs/USBDevice/USBSerial/USBSerial.h"
9f0f2c8f 48#include "libs/USBDevice/DFU.h"
246fd409 49#include "libs/SDFAT.h"
61134a65 50#include "StreamOutputPool.h"
17c89e4d 51#include "ToolManager.h"
246fd409 52
073b1698
MM
53#include "libs/Watchdog.h"
54
582559c6 55#include "version.h"
61134a65 56#include "system_LPC17xx.h"
582559c6 57
a2f7633f
JM
58#include "mbed.h"
59
764b2de4 60#define second_usb_serial_enable_checksum CHECKSUM("second_usb_serial_enable")
82d1ceb3 61#define disable_msd_checksum CHECKSUM("msd_disable")
f431d45c 62#define dfu_enable_checksum CHECKSUM("dfu_enable")
55a2f359 63#define watchdog_timeout_checksum CHECKSUM("watchdog_timeout")
764b2de4 64
073b1698 65
d337942a 66// USB Stuff
5c84acba 67SDCard sd __attribute__ ((section ("AHBSRAM0"))) (P0_9, P0_8, P0_7, P0_6); // this selects SPI1 as the sdcard as it is on Smoothieboard
82414cb2 68//SDCard sd(P0_18, P0_17, P0_15, P0_16); // this selects SPI0 as the sdcard
eaf7b7eb 69//SDCard sd(P0_18, P0_17, P0_15, P2_8); // this selects SPI0 as the sdcard witrh a different sd select
82414cb2 70
5c84acba
JM
71USB u __attribute__ ((section ("AHBSRAM0")));
72USBSerial usbserial __attribute__ ((section ("AHBSRAM0"))) (&u);
45509e68
JM
73#ifndef DISABLEMSD
74USBMSD msc __attribute__ ((section ("AHBSRAM0"))) (&u, &sd);
75#else
8c6d9683 76USBMSD *msc= NULL;
45509e68 77#endif
7c3c5e0f 78
5c84acba 79SDFAT mounter __attribute__ ((section ("AHBSRAM0"))) ("sd", &sd);
a39e1557 80
ca3a28b4
MM
81GPIO leds[5] = {
82 GPIO(P1_18),
83 GPIO(P1_19),
84 GPIO(P1_20),
85 GPIO(P1_21),
86 GPIO(P4_28)
87};
a39e1557 88
9e089978 89// debug pins, only used if defined in src/makefile
9e089978
JM
90#ifdef STEPTICKER_DEBUG_PIN
91GPIO stepticker_debug_pin(STEPTICKER_DEBUG_PIN);
92#endif
93
8a1a44cb 94void init() {
2a1089e1
AW
95
96 // Default pins to low status
97 for (int i = 0; i < 5; i++){
ca3a28b4 98 leds[i].output();
82d1ceb3 99 leds[i]= 0;
ca3a28b4
MM
100 }
101
9e089978
JM
102#ifdef STEPTICKER_DEBUG_PIN
103 stepticker_debug_pin.output();
104 stepticker_debug_pin= 0;
105#endif
106
4464301d 107 Kernel* kernel = new Kernel();
a39e1557 108
577414f6 109 kernel->streams->printf("Smoothie Running @%ldMHz\r\n", SystemCoreClock / 1000000);
582559c6
JM
110 Version version;
111 kernel->streams->printf(" Build version %s, Build date %s\r\n", version.get_build(), version.get_build_date());
4cff3ded 112
f431d45c 113 bool sdok= (sd.disk_initialize() == 0);
bb270b88
JM
114 if(!sdok) kernel->streams->printf("SDCard failed to initialize\r\n");
115
116 #ifdef NONETWORK
117 kernel->streams->printf("NETWORK is disabled\r\n");
118 #endif
f431d45c 119
45509e68 120#ifdef DISABLEMSD
82d1ceb3 121 // attempt to be able to disable msd in config
f431d45c 122 if(sdok && !kernel->config->value( disable_msd_checksum )->by_default(false)->as_bool()){
8c6d9683
JM
123 // HACK to zero the memory USBMSD uses as it and its objects seem to not initialize properly in the ctor
124 size_t n= sizeof(USBMSD);
125 void *v = AHB0.alloc(n);
126 memset(v, 0, n); // clear the allocated memory
127 msc= new(v) USBMSD(&u, &sd); // allocate object using zeroed memory
128 }else{
129 msc= NULL;
130 kernel->streams->printf("MSD is disabled\r\n");
131 }
45509e68 132#endif
82d1ceb3 133
82d1ceb3 134
2a1089e1 135 // Create and add main modules
4eb9c745 136 kernel->add_module( new SimpleShell() );
d3a6143b 137 kernel->add_module( new Configurator() );
0e8b102e 138 kernel->add_module( new CurrentControl() );
35e7b158 139 kernel->add_module( new KillButton() );
4a679a75 140 kernel->add_module( new PlayLed() );
201bcb94 141 kernel->add_module( new Endstops() );
1cf49da1 142 kernel->add_module( new Player() );
df930a5f 143
24584878 144
df930a5f 145 // these modules can be completely disabled in the Makefile by adding to EXCLUDE_MODULES
24584878
JM
146 #ifndef NO_TOOLS_SWITCH
147 SwitchPool *sp= new SwitchPool();
148 sp->load_tools();
149 delete sp;
150 #endif
df930a5f 151 #ifndef NO_TOOLS_EXTRUDER
ec6fde0b 152 // NOTE this must be done first before Temperature control so ToolManager can handle Tn before temperaturecontrol module does
24584878
JM
153 ExtruderMaker *em= new ExtruderMaker();
154 em->load_tools();
155 delete em;
df930a5f 156 #endif
c7689006 157 #ifndef NO_TOOLS_TEMPERATURECONTROL
ec6fde0b 158 // Note order is important here must be after extruder so Tn as a parameter will get executed first
24584878
JM
159 TemperatureControlPool *tp= new TemperatureControlPool();
160 tp->load_tools();
bab4e1bd 161 delete tp;
c7689006 162 #endif
df930a5f
JM
163 #ifndef NO_TOOLS_LASER
164 kernel->add_module( new Laser() );
165 #endif
65d97468
PA
166 #ifndef NO_TOOLS_SPINDLE
167 kernel->add_module( new Spindle() );
168 #endif
df930a5f 169 #ifndef NO_UTILS_PANEL
58d6d841 170 kernel->add_module( new Panel() );
df930a5f
JM
171 #endif
172 #ifndef NO_TOOLS_TOUCHPROBE
3779fd74 173 kernel->add_module( new Touchprobe() );
df930a5f 174 #endif
88443c6b
JM
175 #ifndef NO_TOOLS_ZPROBE
176 kernel->add_module( new ZProbe() );
177 #endif
ed866a4b
QH
178 #ifndef NO_TOOLS_SCARACAL
179 kernel->add_module( new SCARAcal() );
180 #endif
df930a5f 181 #ifndef NONETWORK
d4ee6ee2 182 kernel->add_module( new Network() );
df930a5f 183 #endif
1dc339ee 184 #ifndef NO_TOOLS_TEMPERATURESWITCH
bab4e1bd 185 // Must be loaded after TemperatureControl
1dc339ee 186 kernel->add_module( new TemperatureSwitch() );
187 #endif
13320983
SM
188 #ifndef NO_TOOLS_DRILLINGCYCLES
189 kernel->add_module( new Drillingcycles() );
b4a89b87 190 #endif
89b1a6eb
JM
191 #ifndef NO_TOOLS_FILAMENTDETECTOR
192 kernel->add_module( new FilamentDetector() );
193 #endif
9b013d84 194 #ifndef NO_UTILS_MOTORDRIVERCONTROL
fc320ac5 195 kernel->add_module( new MotorDriverControl(0) );
3eca6882 196 #endif
4a679a75 197 // Create and initialize USB stuff
7c3c5e0f 198 u.init();
8a004d38 199
45509e68 200#ifdef DISABLEMSD
8c6d9683
JM
201 if(sdok && msc != NULL){
202 kernel->add_module( msc );
203 }
45509e68
JM
204#else
205 kernel->add_module( &msc );
206#endif
b813be45 207
7c3c5e0f 208 kernel->add_module( &usbserial );
764b2de4 209 if( kernel->config->value( second_usb_serial_enable_checksum )->by_default(false)->as_bool() ){
f431d45c
JM
210 kernel->add_module( new(AHB0) USBSerial(&u) );
211 }
212
213 if( kernel->config->value( dfu_enable_checksum )->by_default(false)->as_bool() ){
214 kernel->add_module( new(AHB0) DFU(&u));
f6193cbd 215 }
55a2f359 216
f6193cbd
JM
217 // 10 second watchdog timeout (or config as seconds)
218 float t= kernel->config->value( watchdog_timeout_checksum )->by_default(10.0F)->as_number();
219 if(t > 0.1F) {
220 // NOTE setting WDT_RESET with the current bootloader would leave it in DFU mode which would be suboptimal
221 kernel->add_module( new Watchdog(t*1000000, WDT_MRI)); // WDT_RESET));
222 kernel->streams->printf("Watchdog enabled for %f seconds\n", t);
55a2f359 223 }else{
f6193cbd 224 kernel->streams->printf("WARNING Watchdog is disabled\n");
764b2de4 225 }
55a2f359 226
f6193cbd 227
7c3c5e0f
MM
228 kernel->add_module( &u );
229
a4bfde91
JM
230 // clear up the config cache to save some memory
231 kernel->config->config_cache_clear();
232
73706276 233 if(kernel->is_using_leds()) {
21320fc6
JM
234 // set some leds to indicate status... led0 init doe, led1 mainloop running, led2 idle loop running, led3 sdcard ok
235 leds[0]= 1; // indicate we are done with init
236 leds[3]= sdok?1:0; // 4th led inidicates sdcard is available (TODO maye should indicate config was found)
237 }
82d1ceb3 238
33e4cc02
JM
239 if(sdok) {
240 // load config override file if present
241 // NOTE only Mxxx commands that set values should be put in this file. The file is generated by M500
242 FILE *fp= fopen(kernel->config_override_filename(), "r");
243 if(fp != NULL) {
244 char buf[132];
245 kernel->streams->printf("Loading config override file: %s...\n", kernel->config_override_filename());
246 while(fgets(buf, sizeof buf, fp) != NULL) {
247 kernel->streams->printf(" %s", buf);
248 if(buf[0] == ';') continue; // skip the comments
249 struct SerialMessage message= {&(StreamOutput::NullStream), buf};
250 kernel->call_event(ON_CONSOLE_LINE_RECEIVED, &message);
251 }
252 kernel->streams->printf("config override file executed\n");
253 fclose(fp);
254 }
255 }
dc3542cf
JM
256
257 THEKERNEL->step_ticker->start();
8a1a44cb
JM
258}
259
260int main()
261{
262 init();
33e4cc02 263
82d1ceb3 264 uint16_t cnt= 0;
2a1089e1 265 // Main loop
4cff3ded 266 while(1){
73706276 267 if(THEKERNEL->is_using_leds()) {
21320fc6
JM
268 // flash led 2 to show we are alive
269 leds[1]= (cnt++ & 0x1000) ? 1 : 0;
270 }
8a1a44cb
JM
271 THEKERNEL->call_event(ON_MAIN_LOOP);
272 THEKERNEL->call_event(ON_IDLE);
4cff3ded 273 }
4cff3ded 274}