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