559feb97e2
- Refactored system states to be more clear and concise. Alarm locks processes when position is unknown to indicate to user something has gone wrong. - Changed mc_alarm to mc_reset, which now manages the system reset function. Centralizes it. - Renamed '$X' kill homing lock to kill alarm lock. - Created an alarm error reporting method to clear up what is an alarm: message vs a status error: message. For GUIs mainly. Alarm codes are negative. Status codes are positive. - Serial baud support upto 115200. Previous baudrate calc was unstable for 57600 and above. - Alarm state locks out all g-code blocks, including startup scripts, but allows user to access settings and internal commands. For example, to disable hard limits, if they are problematic. - Hard limits do not respond in an alarm state. - Fixed a problem with the hard limit interrupt during the homing cycle. The interrupt register is still active during the homing cycle and still signal the interrupt to trigger when re-enabled. Instead, just disabled the register. - Homing rate adjusted. All axes move at homing seek rate, regardless of how many axes move at the same time. This is unlike how the stepper module does it as a point to point rate. - New config.h settings to disable the homing rate adjustment and the force homing upon powerup. - Reduced the number of startup lines back down to 2 from 3. This discourages users from placing motion block in there, which can be very dangerous. - Startup blocks now run only after an alarm-free reset or after a homing cycle. Does not run when $X kill is called. For satefy reasons
81 lines
2.3 KiB
C
81 lines
2.3 KiB
C
/*
|
|
report.h - reporting and messaging methods
|
|
Part of Grbl
|
|
|
|
Copyright (c) 2012 Sungeun K. Jeon
|
|
|
|
Grbl 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.
|
|
|
|
Grbl 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.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with Grbl. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#ifndef report_h
|
|
#define report_h
|
|
|
|
|
|
// Define Grbl status codes.
|
|
#define STATUS_OK 0
|
|
#define STATUS_BAD_NUMBER_FORMAT 1
|
|
#define STATUS_EXPECTED_COMMAND_LETTER 2
|
|
#define STATUS_UNSUPPORTED_STATEMENT 3
|
|
#define STATUS_ARC_RADIUS_ERROR 4
|
|
#define STATUS_MODAL_GROUP_VIOLATION 5
|
|
#define STATUS_INVALID_STATEMENT 6
|
|
#define STATUS_SETTING_DISABLED 7
|
|
#define STATUS_SETTING_VALUE_NEG 8
|
|
#define STATUS_SETTING_STEP_PULSE_MIN 9
|
|
#define STATUS_SETTING_READ_FAIL 10
|
|
#define STATUS_IDLE_ERROR 11
|
|
#define STATUS_ALARM_LOCK 12
|
|
|
|
// Define Grbl alarm codes. Less than zero to distinguish alarm error from status error.
|
|
#define ALARM_HARD_LIMIT -1
|
|
#define ALARM_ABORT_CYCLE -2
|
|
|
|
// Define Grbl feedback message codes.
|
|
#define MESSAGE_CRITICAL_EVENT 1
|
|
#define MESSAGE_ALARM_LOCK 2
|
|
#define MESSAGE_ALARM_UNLOCK 3
|
|
#define MESSAGE_ENABLED 4
|
|
#define MESSAGE_DISABLED 5
|
|
|
|
// Prints system status messages.
|
|
void report_status_message(uint8_t status_code);
|
|
|
|
// Prints system alarm messages.
|
|
void report_alarm_message(int8_t alarm_code);
|
|
|
|
// Prints miscellaneous feedback messages.
|
|
void report_feedback_message(uint8_t message_code);
|
|
|
|
// Prints welcome message
|
|
void report_init_message();
|
|
|
|
// Prints Grbl help and current global settings
|
|
void report_grbl_help();
|
|
|
|
// Prints Grbl global settings
|
|
void report_grbl_settings();
|
|
|
|
// Prints realtime status report
|
|
void report_realtime_status();
|
|
|
|
// Prints Grbl persistent coordinate parameters
|
|
void report_gcode_parameters();
|
|
|
|
// Prints current g-code parser mode state and active switches
|
|
void report_gcode_modes();
|
|
|
|
// Prints startup line
|
|
void report_startup_line(uint8_t n, char *line);
|
|
|
|
#endif
|