Commit Graph

4574 Commits (2c239b1bd3a7424edbbcfb96724c055bb701db0f)

Author SHA1 Message Date
Scott Lahteine a99470fbb0 Merge pull request from maverikou/panel_one
Added support for PanelOne from T3P3.
domonoky 5727cb3ed4 Cleanup TMC Stepper a bit.
Scott Lahteine a5bbd402bf Merge pull request from AnHardt/dummysensor
Extend the idea of dummy temperature sensors.
Scott Lahteine 1a7b0d9a37 Redo HAS_* macros to fix define error
Scott Lahteine 864dddc878 Macros to the top, a few HAS_* macros
alexborro 227ab8c665 Merge pull request from MarcelMo/patch-2
Support for simple customisable AutoZProbing area
Scott Lahteine fd1ea9d56f Move literal strings to language files
maverikou 8742b6bd56 Merge branch 'Development' into panel_one
Scott Lahteine aa9c1f1bed Better name for ADC macro
Scott Lahteine 9c9726d469 Cleanup of temperature code
- Reduce calls to millis()
- General cleanup of manage_heaters
- General cleanup of pid autotune
- Formatting here & there
- Macros to clean up and shrink ISR code (reduced by ~364 lines)
AnHardt c6d2ebe452 Extend the idea of dummy temperature sensors.
Added a second sensor and made them configurable.
Scott Lahteine c9a3eb0c1a Spacing in calculate_volumetric_multiplier(s)
Scott Lahteine 2af559cca3 Shared function for menu_edit_* and menu_edit_callback_*
Scott Lahteine df8c51528f Merge branch 'Development' into cleanup_ultralcd
Latest upstream changes
Scott Lahteine 517f411999 Spacing adjustment to menu_edit* macro
Scott Lahteine 4938ae5caf Add required backslash for macro expansion
Scott Lahteine e182cdebf9 Add required backslash for macro expansion
Scott Lahteine fa4c36df68 Fix menu callback issue wrt LCD_CLICKED
Scott Lahteine 0cf0c20532 Optimize calculate_volumetric_multiplier
domonoky 38500165ea First attempt at adding TMC Driver support. May need some cleanup.
domonoky b55995aae8 Introduce a layer of macro indirection to all stepper pins. This allows other stepper drivers to redefine them, so they can use SPI/I2C instead of direct pin manipulation.
kieranc 8ccdac9898 Enable PID debugging for heated bed
kieranc 29097b0ab2 Enable PID debugging for heated bed
kieranc 21bd4fd6db Enable PID debugging for heated bed
kieranc fb56aad898 Enable PID debugging for heated bed
kieranc 08c543f8fb Enable PID debugging for heated bed
kieranc c89413db1e Enable PID debugging for heated bed
kieranc 1c71e4751a Enable PID debugging for heated bed
maverikou a9e15aa503 Updated example configurations
Scott Lahteine 3ba47ea277 Remove test/demo multi=line code menu items
Scott Lahteine c1240f23dd Merge branch 'Development' into marlin_configurator
Latest upstream changes
alexborro a57869ba49 Dummy Thermistor Table for testing purposes
Am I the only one who always need to change the thermistortable.h to add
a dummy table??
Ok, it is done. Just set the thermistor to 999 and it will always read
25C. Great for Testing or Development purposes.
Maverikou 2e166f5337 Added support for PanelOne from T3P3.
Scott Lahteine 40ef472a25 Merge in encoder multiplier
Scott Lahteine 1c13cd604b Formatting in babysteps defines
Scott Lahteine 3a26804d80 Adapt to latest PID code and fix typos
Scott Lahteine 422582da71 Prep formatting for upcoming PR
Scott Lahteine 27ac3e985d Add options to example_configurations
Scott Lahteine 0d6a7a2df0 Merge with latest upstream changes
Scott Lahteine c7a97e18b7 Merge branch 'Development' into cleanup_ultralcd
Latest upstream changes
Scott Lahteine 6d5c13df74 Merge pull request from thinkyhead/fixup_temperature
Fix typos in checkExtruderAutoFans
Scott Lahteine 5b9e341222 Merge pull request from thinkyhead/fixup_ramps
Cleanup ramps boards
Scott Lahteine 57bc28b42c Cleanup and fix ultralcd.cpp
- Fix bug in lcd_control_temperature_menu
- Remove test menu-item left in from multi-line command feature
- Replace literals with translatable strings
- Reduce lcd_preheat code redundancy
- Reduce menu macro redundancy
- Clean up formatting
Scott Lahteine 4fcd4b444e Merge pull request from thinkyhead/fix_recent_issues
Fix implementation of PID menu items
Scott Lahteine 9c35ed149d Merge pull request from AnHardt/iss1492
Fix iss#1492
Scott Lahteine 430c4b6538 Replace missing backslash
Scott Lahteine 3aa5f98b64 Download all as ZIP, adjust layout on resize
Scott Lahteine a8939eec28 Readability of MENU_MULTIPLIER_ITEM
Last commit before bed.
Scott Lahteine 09e09b308e Tweaky spacing adjustments
Scott Lahteine e3fd3e8fa4 Fix typos in checkExtruderAutoFans
Scott Lahteine c610471b0c Add PID_PARAMS_PER_EXTRUDER conditional
Scott Lahteine 2d6fa9ce80 Proper implementation of PID menu items
- Make this work per 
wgm4321 b8e79dce89 Fix compilation errors when encoder multiplier is disabled
wgm4321 65e1fc71be Add encoder rate multiplier
Scott Lahteine 859c8d3fef Azteeg X3 overrides too
Scott Lahteine 7891eacf21 Merge branch 'Development' into fixup_ramps_boards
- Also apply cleanup for 
Scott Lahteine 1600506545 Merge remote-tracking branch 'upstream/Development' into marlin_configurator
Scott Lahteine 5d0c93ae10 Keep config boxes in view on wide screen
Scott Lahteine 335b7680c9 Tooltip code, widescreen layout, hide auto-expands
Slightly better layout for wide screens.
domonoky 15b73386b5 Add pin definitions for the Boards BAM&DICE + BAM&DICE Due
Scott Lahteine 08c236059e Merge pull request from thinkyhead/issue_1499
Bed leveling probe behavior issue?
Scott Lahteine f238c7428d Merge branch 'Development' into marlin_configurator
Latest upstream changes
Scott Lahteine da275c72ab Cleanup Github reply.data.content before atob()
MagoKimbra 159196d1e9 Reset Alert message when finish M600 command
daid 266ff227cf Merge pull request from docdawning/Development
Trivial spelling correction
DocDawning dfd4e74a5c Trivial spelling correction
AnHardt 6cdcd6c6d1 Fix iss#1492
Introduced lcd_strlen() and lcd_strlen_P().
Replaced the old functions where necessary.
Reworked language_ru.h.

Speeded up test for zero length string in cardreader.cpp
Scott Lahteine c033904693 Updated config file section markers
Scott Lahteine 84a87a5b1c Fix up configs a little
Scott Lahteine 63a5ff7ab9 Merge pull request from tommil/Development
Updated Finnish language file
Scott Lahteine efb0491d40 Merge branch 'Development' into issue_1499
Merging latest upstream changes
Scott Lahteine 8309b4f408 Merge branch 'Development' into marlin_configurator
Merging latest upstream changes
Scott Lahteine 961998cf91 Merge pull request from thinkyhead/issue_1493
Megatronics 3 servo pins
Scott Lahteine b71322e793 Issue – K8200 Z_ENABLE_PIN
- K8200 uses a non-standard RAMPS with Z_ENABLE=63 ??
- Assuming from previous input that 3DRAG is the same.
Scott Lahteine 978d114c73 Bed leveling probe behavior issue?
The `float` keyword should not be on these vars because they conceal
the outer vars, preventing them from obtaining known values before
being passed in `set_bed_level_equation_3pts`. Possibly related to
`Z_RAISE_BETWEEN_PROBING` not functioning.
Scott Lahteine 7c6236761a Merge branch 'Development' into issue_1493
Merging latest upstream changes
Scott Lahteine 9875352dd8 Merge branch 'Development' into marlin_configurator
Merging latest upstream changes
MarcelMo d28f5b9e82 Support for simple customisable AutoZProbing area
When probing PCB´s I had the problem that i needed auto-leveling for specific areas (it´s never the same size).
Not much code, but very useful.
Now I use simply G29 L5 R55 F5 B35 P3 to probe a 4x6cm PCB before milling.
I used int for values... might be wrong...
I hope this time I got the right development tree. (tried first with https://github.com/MarlinFirmware/Marlin/pull/1130/commits)
Tommi Lamberg 513ff94b89 Merge remote-tracking branch 'upstream/Development' into Development
Scott Lahteine 83cb702e72 Config sections, multi-field values, toggles, etc
- Auto-detect “switchable” items where possible
- Handle switchable multi-value fields
- Add standard sections to config form
- Add section markers to configurations
- Add value options to configurations
- Remove and re-add fields for loaded configs
- Preserve sections across configs
- Preserve non-added fields
- Style added fields wider & newline by default
alexborro afc737ca0c Fix CoreXY Homing Routine.
Fixed how stepper ISR figure it out when the head (extruder) is going to
Min or Max direction.
Added Homing to Max Endstops.
Scott Lahteine ec53c6309a More fields, options in config, fix tooltips
Scott Lahteine 68184af57b Merge branch 'Development' into marlin_configurator
Latest upstream commits
Scott Lahteine 7866fa161f Merge pull request from Natealus/Development
Compiling errors with 4 Extruders defined and Viki 2 Implementation
Natealus ea9e49b20d ARRAY_BY_EXTRUDERS 4th hotend PID parameters
Scott Lahteine d0ad8a978c Megatronics 3 servo pins
- Naive implementation, assuming the data sheet pin numbers correspond
to Arduino pin numbers.
Scott Lahteine e74138b2be More robust fetch code, download buttons
- Fetch code now handles github, local, or http: access
- Download button creates a time-stamped inline download
- More complete error messages
- Show warnings when approaching the hourly fetch quota (limit
reloading!)
- Added my test domain (where the _htaccess is deployed)
- `_htaccess` file added to set Access-Control-Allow-Origin “*”
- Marlin logo with css
- Limit selectable areas to avoid annoying selections
- Messages now persist until dismissed
- Default repo for files set to thinkyhead, ‘marlin_configurator’ branch
- Cosmetic changes
Tommi Lamberg 622a531d9c Fixed error in translation
Tommi Lamberg 290ab42d22 Updated Finnish translations
Jérémie FRANCOIS 22a7985445 reverted to upstream
Jérémie FRANCOIS b3bda57ca2 reverted to upstream
Jérémie FRANCOIS 9d75a56b56 Merge remote-tracking branch 'upstream/Development' into Development
Conflicts:
	Marlin/Configuration.h
	Marlin/Marlin_main.cpp
Tommi Lamberg 0a59fee763 Merge remote-tracking branch 'upstream/Development' into Development
Scott Lahteine eb5889b3da Merge pull request from AnHardt/en_first
#include "language_en.h" before the national language in language.h
kieranc b9ed873827 Enable PID debugging for heated bed
kieranc 0a19109476 Enable PID debugging for heated bed
Tommi Lamberg a4f939cc27 Updated Finnish language file
Scott Lahteine 32d4dd073f Merge pull request from AnHardt/iss1485
Fix for 
AnHardt c246026bda Sorry.
AnHardt 07e488cfae Fix for
Souko e7ecf14d0c Update ultralcd_st7920_u8glib_rrd.h
Fixed delay-times during Init. REPRAP_DISCOUNT_FULL_GRAPHIC_SMART_CONTROLLER won't get initialized on some Boards because delay was to short.
Scott Lahteine 52c3cf6d34 Fix a logging error
Scott Lahteine ba24a09f24 Use api.github to get Configurations
- Make api.github the default source for configurations
- Remove configurations from the configurator
- Continuation and enhancements
Natealus f4b0a40abb Additional fixes to temperature.cpp and found another missing line
Looks like INVERT_E3_DIR was missing in the configuration.h also as I
did a test compile with 4 extruders and Azteeg X3 Pro defined. So I also
added those lines too. Additional formatting to make the comments line
up better in that section.
AnHardt 3aac2df057 Now the oter way around.
Include of language_en.h now behind national language.

All "#define MSG_STR_*" now surrounded by #ifndef and #endif.
AnHardt 488633bf44 #include "language_en.h" before the national language in language.h
+ May decrease the workload for feature developers. They may omit to
update all the language files but "language_en.h". When loading _en
first, all new features give some display, but the new in English.

- May throw some additional warnings about redefinition during compile.
AnHardt 8e92729141 Make display language configurable in Configuration.h
Natealus 38a500d05c Viki 2 Implementation
I've insert the define and pointer entries for the Viki 2 and miniViki
from Panucatt in all of the example configs and main config. With these
additions and with pins done in the old single pin.h style...I was able
to get the display working fine save for needing to turn Delta Segments
per Second down. But that's a common graphics lcd issue being looked
into right now.

I need assistance in understanding how the new divided pins files fit
together because my previous attempts at trying to get it to work
appropriately didn't seem successful. This originally came from trying
to find out how to swap the XYZ Min and Max Endstop pins in the Azteeg
X3 Pro. It only comes with one set of connectors and they're Min
Endstops. My previous experience didn't turn out well trying to tell the
firmware to home to the Min Endstops so the best solution I found was to
swap the pins in the firmware. If I'm missing a conflict with a setup
other than delta please let me know, but it makes sense in my setup.
Natealus 697ee2dc50 Compiling errors with 4 Extruders defined
Here were a few changes that I had to make/add lines for the 4th hotend.
A compiling problem in the Temperature.cpp and missing lines in
configuration.h and configuration_adv.h. I added these lines in all of
the example configs too.
Jérémie FRANCOIS 85e5aa4011 Generalized enqueue_commands_P, and moved them to Marlin_main as they should
Scott Lahteine 4228758f1d Clean up and improve tooltips, show the name
Scott Lahteine 0116320d2c Strip slashes off the front of tooltips
Scott Lahteine 69240d41b0 Offset the timing of the pulsing animation
Scott Lahteine 78b9428f4e Avoid capturing disabled items in comments
Scott Lahteine 5d159851e5 Fix positioning of tooltip
Scott Lahteine c99f1de9f3 Fix tooltips blocking clicks
Scott Lahteine 1a548c1bc1 Find nearby comments and make them into tooltips
Scott Lahteine 90fa1345b0 Fix purge + refresh of define info
Scott Lahteine aa67b38a44 Fan speed and 4th extruder on graphical LCD
- Display fan speed 0-1 as “—“ and 254-255 as “100%”.
- Display 4th extruder instead of the heated bed
Scott Lahteine 7850ae2f4f Merge branch 'Development' into marlin_configurator
Merge latest Development
Scott Lahteine 2647402095 Use info.repl in updateDefineFromField, fix regex
Scott Lahteine 12a3975341 Close section tag, add String.prototype.lineCount
Scott Lahteine 4bb72f9480 Highlight the edited line
- Add a span to the edited text line to provide a highlight
- Scroll and highlight for switch checkboxes also
- Clean up initialization
- More API documentation
- Smarter handling of asynchronous file loading during init
Scott Lahteine 37c43a7ab3 Scroll to reveal on switches as well
Scott Lahteine 9c0adae3cd Scroll to setting position in file when edited
- Animate scrolling to the edited item’s position
- Sanity check file drops and show warnings
- Fix form init / refresh on new configuration drop
- Document the API methods that get/set defines
Scott Lahteine 4d341bb758 Copy configs into subfolder
Browsers may not want to load files outside the folder, but they may be
okay with these relative references within the folder.
Scott Lahteine 72856166a9 Fix bad typo in ConfigurationStore.cpp
Scott Lahteine b51204cc1c Add fieldsets and make them into tabs
Scott Lahteine 56769ba4f8 Make comment/uncomment a little neater
Scott Lahteine 94bebf31ac Pre-collect info about options on field init
- When initializing fields use the configuration to determine the format
- Cache the line for each option for fastest string compare / replace
- Add logging levels for debugging
Scott Lahteine 32aaadc301 Include minimized jQuery 2.1.3
Scott Lahteine 53f6bbdfe0 Try a stepper for the serial port
Scott Lahteine ac7a4358d6 Add a responsive file uploader
- Specify HTML5
- Allow drag and drop for loading configurations
Scott Lahteine 09a385d9b0 Add "use strict" to the top.
Scott Lahteine b2627200ea Get thermistors from config, add temp sensors
Scott Lahteine ef18bfdd3f An in-place browser-based configurator utility
- A web form with fields for configuration values
- Reads and parses standard config files
- Modifies configurations dynamically in-place
Scott Lahteine 3490a19103 Merge pull request from CONSULitAS/Development_K8200_de
K8200: Example Configuration.h fixed
CONSULitAS cfbb94a2a8 K8200: Example Configuration.h fixed
Example Configuration.h: fixed strange white characters preventing
compilation in lines 1 and 3 - oops
Scott Lahteine b65c5d8ec6 Merge pull request from AnHardt/iss1448-Menu
Unified menu selection - by hilighting - made first column avilable
CONSULitAS 0de5083aff K8200: Example Configurations readme.md updated
Example Configurations for K8200 readme.md updated
* readme.md: added description for german umlaut support on LCD
CONSULitAS c421ffd520 K8200: Example Configuration_adv.h back in sync
Example Configuration_adv.h for K8200 back in sync
* Configuration_adv.h: rebased and added missing changes for 4th
extruder
CONSULitAS 0575dd10de K8200: Example Configuration.h back in sync
Example Configuration.h for K8200 back in sync
* Configuration.h: rebased and added missing changes
* Configuration.h: updated comments for K8200
AnHardt f708884808 Introduced new function lcd_implementation_mark_as_selected()
New function now drops the prechar (select character) and makes the first
column usable for text.
Marking the line is now constantly made by highlighting (reverse).

Replaced selection code in:
lcd_implementation_drawmenu_generic()
_drawmenu_setting_edit_generic()
_drawmenu_sd()

with new function.
Scott Lahteine b6ca50a2cc Merge pull request from thinkyhead/cleanup_recent_merge
Apply some cleanup for recent merge
Scott Lahteine cc56f36870 Merge pull request from thinkyhead/issue_1453_redo
Apply fix for M600 filament change
Scott Lahteine 8663f4bbaf Apply some cleanup for recent merge
Combine 1/(rows+1) with u8g.getHeight() to get rowHeight and just use
that.
Scott Lahteine 0cb1029311 remove extra plan_buffer_line
AnHardt 9381bfe7f9 Fixes issue - Overlapping of long descriptions with values.
Scott Lahteine b97a950f53 Apply fix for M600 filament change
- Patch from  for delta movement plan
- Fix: Set X with code X instead of adding to X
AnHardt 2abf1ad940 Distribute recent changes in Configuration.h to the examples.
AnHardt 33f8580255 Merge branch 'lcd-width' into b-
AnHardt 0c24bb6cfc Adjust LCD_WIDTH to make better use of DOGM LCDs
AnHardt b1dbd765c6 Centralise definition of fonts for DOGM displays
Prework for issue  and 

Will merge in when pull request  is in.
AnHardt 65642592ee Added dualline version.
AnHardt f9cc1df00b Droped URL from bootsplash.
AnHardt c20606b8d7 Replaced some literal constants with defines
Replaced calculation to centre bitmap with fixed values.
Saved 20 bytes.
AnHardt 3602474c25 Replace solitaire use of u8g_font_5x8 font and replace with u8g_font_6x10_marlin
and win another 1694 bytes.
AnHardt f5fd94d62a Kick suspicious loop an win 72 bytes.
No visible impact.
Scott Lahteine b3973ed224 Fix HD44780 misspelled as HD44870
Scott Lahteine d8b7f29fa2 Merge pull request from thinkyhead/fix_M200_bug
M200 cleanup, normalization of EXTRUDER loops
Scott Lahteine 6d81968db5 Merge pull request from docdawning/Development
Normalized section headers, added some headers, added help URLs for newb...
DocDawning 5bb3933b21 Fixed n00bsauce
DocDawning d109cd940b Normalized all configuration files to include my new section headers and the like.
DocDawning 055c4beaf9 Normalized section headers, added some headers, added help URLs for newbies
Scott Lahteine 9dc5de6166 Hide code that makes veteran geeks go "aha!"
Scott Lahteine bd387068bb Apply loops for extruders elsewhere also
Scott Lahteine 4a146d584b Loop, since the pending feature can use an array
Scott Lahteine bca884bf72 Realized it's not a bug, but cleanup code anyway
AnHardt 2dd43a82b1 Ups. #else added
AnHardt 26e55471f8 Update example configurations.
AnHardt 85385be132 Removed now automatic define of DISPLAY_CHARSET_DOGM + improved description.
AnHardt 0e40408ee5 Make exemplaric use of new display charsets in language_en.h and languag_de.h
AnHardt 8dce5a6644 Improve new charset featur.
Select DOGM-displays automaticly.
Give hint where to find charsets.
Add '²' and '³' characters.
Scott Lahteine c009c81e65 make marlin-main the default
Scott Lahteine f4ebc02555 marlin url
Scott Lahteine 0af9a0bf57 url to firmware downloads
Scott Lahteine 5f8dd92905 toss in a fix for .ru
Scott Lahteine 3f3ad9b3ad typo
Scott Lahteine 07639053fb Add support for BQ Prusa i3 "Hephestos"
Philip Schell fb7c636ecf Avoid compiling error
Only a missing ","... now it will compile again
alexborro 787d6fb61a Update RUMBA pins file
Add FAN1_PIN and SERVO0_PIN
Scott Lahteine 5fd5105d44 Merge pull request from clefranc/Development
Fix nozzle in temperature menu
AnHardt 76bf93efcb Revert "get STR_THERMOMETER from ultralcd_implementation_hitachi_HD44780.h"
This reverts commit 4d5b0e2037.
AnHardt 4d5b0e2037 get STR_THERMOMETER from ultralcd_implementation_hitachi_HD44780.h
Christian Lefrançois 33408a4dfc Update ultralcd.cpp
Fix number of nozzle displayed in temperature menu.
AnHardt 6e6e3cf443 merged https://github.com/MarlinFirmware/Marlin.git
AnHardt b3ca430a20 Inducted the defined placeholders in the translation table.
AnHardt e045034c3f Included Configuration.h to read the defined charsets.
Defined the charsets plus a default.
AnHardt 27c638803e Defined three charsets.
Scott Lahteine 073c59c50a Clean up some formatting
- Also partial cleanup of Marlin_main.cpp with a smidgen of Doxygen.
AnHardt 9a4d4b3a2f translated Deltamenu
AnHardt 8aa6487b4b MSG_ENDSTOP_ABORT = 'Endstop abort' > 'Endstop Abbr. Ein'
AnHardt 666ad7106b Translated redundand: define MSG_INIT_SDCARD and MSG_CNG_SDCARD
AnHardt e5c45fbe8c Infoscreen messages end with a '.' if not to long.
MSG_NO_MOVE = 'Kein Zug.' > 'Motoren Eingesch.' hat mich grau Haare gekostet.
Die englisch Meldung will sagen - Du kannst jetz am Extruder arbeiten, die
Achsen sind bockiert, die Motoren sperren die Achsen weil sie unter Strom
stehen, weil sie eingeschaltet sind.
AnHardt 1e22137e27 MSG_STOP_PRINT = 'Druck stoppen' > 'SD-Druck Abbruch'
to work out that this can't be resumed.
AnHardt 05d2ebd118 MSG_WATCH > 'Beobachten' > 'Info'
AnHardt 06cba91c39 eye candy 2
AnHardt 9352c9547f MSG_SPEED = 'Geschw' > 'Geschw.'
AnHardt 0dfb0162f3 eye candy.
AnHardt 7222b27501 MSG_MOVE_AXIS = 'Achsen bewegen' > 'Bewegen'. Is Extruder an axis?
AnHardt a6f808c9b1 remove unused #define MSG_RETRACT
AnHardt 152fa579f5 MSG_SWITCH_PS_OFF = 'Switch Power Off' -> 'Netzteil Aus'
AnHardt 7a32b742f3 MSG_SWITCH_PS_ON = 'Switch Power On' ->'Netzteil Ein'
AnHardt 4e176d2ce8 MSG_SET_ORIGIN = 'Setze Nullpunkt' ->'Setze Null hier'
AnHardt 1f8c8ad3ed MSG_SET_HOME_OFFSETS = 'Set home offsets' ->'Setze Home hier'
AnHardt 0e8836ce5e MSG_AUTO_HOME = 'Auto Nullpunkt' ->'Home'
AnHardt 56d3e6615d MSG_DISABLE_STEPPERS = 'Stepper abschalt.' -> 'Motoren Aus'#
Scott Lahteine 1258980832 Merge pull request from bq/Development
Add bq Witbox 3D printer
Victor Andueza 766762a4dc Change url link
Scott Lahteine 7df9ca051c Merge pull request from thinkyhead/issue_1388_eeprom
Make EEPROM storage consistent
Scott Lahteine fe3810f073 yeah, what he said
Scott Lahteine 6137bbd484 use eeprom read correctly
Scott Lahteine 9bc9051405 Flag EEPROM write errors on serial output
- Also adds a language string for the error.
- Also adds SERIAL_EOL as an alias for SERIAL_ECHOLN(“”)
Scott Lahteine ff99ca3040 Fix alignment of Restore following PIDTEMP
Should be reading 4 x 4 PID values instead of 4 x 3
Philip Schell 6c285930cb Fixing wrong pin to heater extruder 2 <-> 3
Extruder 2 and 3 was swapped
Victor Andueza 0d4ce27b79 Add pins_WITBOX file
Victor Andueza 13118cde33 Add bq Witbox 3D printer
Scott Lahteine 093fedfde8 Make EEPROM storage consistent
Update ConfigurationStore to always write dummy values for disabled
options, including FWRETRACT, DELTA, and SCARA. Update the EEPROM
version to “V15.” Also fixes a buffer overrun with axis_scaling in
Config_ResetDefault.
Scott Lahteine 34377ee512 Merge pull request from thinkyhead/fewer_preheat_strings
Remove language strings that only add a number
Scott Lahteine 7378a7fef4 Merge pull request from thinkyhead/cleanup_servo
Formatting cleanup of quiet sources
Scott Lahteine 5fbef6bed2 Merge pull request from thinkyhead/rename_lastnr
Rename lastnr to autostart_index and...
Scott Lahteine 53eea611b8 Fix MSG_NOZZLE
Scott Lahteine d7211a5324 Changes for Portuguese too
Scott Lahteine 0a21727c0a Portuguese (pt) and Brazilian Portuguese (pt-br)
Scott Lahteine c90f2e77d8 Remove language strings that only add a number
This won’t reduce the string storage in the end, but it makes the
language files smaller. Also removed remaining unused strings.
Scott Lahteine 2ce4a102ee Add support for Megatronics 3 a la
Scott Lahteine ae4b348d77 Make sure _Ex_PINS is defined
Also fix analogInputToDigitalPin so it uses proper C hex notation
Scott Lahteine 80be6f3f91 tweak tweak
Scott Lahteine ebe78cb36f tweak
Scott Lahteine 82474fef8a Max endstop pins disabled by configuration
There’s no need to ask users to uncomment Max Endstop pins when they
have them. These will be set to -1 later if the endstop option is
disabled.
Scott Lahteine 8045e4d60d Add support for 4th extruder
 includes some changes to pins.h for a 4th extruder. This commit
applies those changes. It also deals with a possible problem with
SENSITIVE_PINS.
Scott Lahteine df4f3e7712 cleanup
Scott Lahteine b6ecbd8cc4 cleanup
Scott Lahteine 4e573134de Cleanup heading
Scott Lahteine 574a5ab72a Split up pins to make it more manageable
Hopefully this is helpful to organization and future expansion….
clefranc d55c62bf9f Update ConfigurationStore.cpp
Moved #endif to allow filament settings to print.
clefranc e779641c73 Update ConfigurationStore.cpp
Added PIDTEMP dummy write to align EEPROM read/write operation.
Scott Lahteine baac6e242d Merge pull request from AnHardt/bootsplash
repair Bootsplash
AnHardt 75cf302da3 example configurations changed to meet Configuration.h
Philip Schell 61fd45a0c2 Add 4th extruder
Philip Schell 2650be4921 Add 4th extruder
Philip Schell a9763d894e Add 4th extruder
Philip Schell 4949088302 Add 4th extruder
Philip Schell fc5204bd42 Add 4th extruder
Philip Schell 9834818ef7 Add 4th extruder
Philip Schell 8696963154 Add 4th extruder
Philip Schell ee8a7419f4 Add 4th extruder
Philip Schell e18403235d Add 4th extruder
Philip Schell 7baee555f4 Add 4th extruder
Philip Schell cebc7daf2a Add 4th extruder
Philip Schell ef4c7abb21 Update language_es.h
Add 4th extruder
Philip Schell 22e591518a Update language_de.h
Add 4th extruder
Philip Schell a20c35bb38 Update language_ca.h
Add 4th extruder
Jérémie FRANCOIS dd301be52d Added suport for multiline G-code commands in the LCD menus
AnHardt aa48056c03 Made centering of bootlogo work and removed contraproductiv setScale2x2() in dogm_lcd_implementation.h
AnHardt 0d219b3e14 Make centering of STRING_SPLASH work
AnHardt 59315330dd Remove definition of VERSION_STRING and replace where usend with STRING_VERSION
AnHardt 8c792c7b22 Make STRING_VERSION and VERSION_STRING the same
Scott Lahteine 865ca0ef04 Merge pull request from MagoKimbra/4th-extruders
All the additions look proper. I can't think of any other extruder-count-related items that you might have missed. So, with some optimism, I will merge this for testing.
MagoKimbra 3021f7f743 Fix PID_dT
Add PID_dT in temeprature.cpp
Scott Lahteine a7b02975b7 No TEMP1 or TEMP2 pins for TEENSYLU || PRINTRBOARD
Pins 2 and 3 are probably general-use pins, since the filament sensor
uses pin 2.
Scott Lahteine 6723388f7f Proposed fix to . Printrboard I2C LCD support
Scott Lahteine 03c9cb60e8 Rename lastnr to autostart_index and...
Replace instances of the number 13 with FILENAME_LENGTH where
appropriate.
MagoKimbra ef5959a705 Fix Temperature
Githun insert this line when i merge with actual Branch development...
MagoKimbra 3d4ee6c868 Merge branch '4th-extruders' of https://github.com/MagoKimbra/Marlin into 4th-extruders
Conflicts:
	Marlin/temperature.cpp
MagoKimbra 986e723eeb Add 4th extruder
Scott Lahteine f16bdd2ff2 Borrow from Ultimaker to fix MAX6675 SPI conflict
Changes to temperature.cpp from Ultimaker fork, intended to address
 and 
Scott Lahteine 06c3b37933 Formatting cleanup of quiet sources
Formatting for code-folding plus minor style changes to less active
code.
Scott Lahteine 23fcd1ecb2 Merge pull request from thinkyhead/cleanup_marlinserial
Formatting cleanup of quiet sources
Scott Lahteine fd78902194 Formatting cleanup of quiet sources
Scott Lahteine 5c1814383a Merge pull request from floyd871/Development
Show Custom M_Code for Z-Probe Offset when entering M503
MagoKimbra 0ebf896070 Add 4th extruder
Michael Neumann a9d7ab9530 Update ConfigurationStore.cpp
Done
Scott Lahteine 3a9a3e5ed8 Fix Issue – remove EXTRUDER1_Z_OFFSET
This define is not used.
Scott Lahteine 54d5b52a2e Merge pull request from beanz/use-bed-defines-not-extruder-ones
Code wont compile with extruder but without bed runaway protection defined.
Mark Hindess 0ce252ba7a This ifdef is for bed code so should use bed constants for testing.
Without this fix, the code wont compile with extruder but without bed
runaway protection defined.
Scott Lahteine 9040446780 Merge pull request from AnHardt/iss1394
removed function step_wait() from stepper.cpp
Scott Lahteine 25f79c5010 Merge pull request from CONSULitAS/Development-newBoard_K8200
Add: Board for Vellemann K8200 (derived from 3Drag)
Scott Lahteine 9ce75ab7de Merge pull request from roglio/Development
Fixing a build error for melzi and gfx display
Scott Lahteine 15a00a5a7c Add 1µs delay in other appropriate spots
AnHardt 23cb899c5a removed function step_wait() from stepper.cpp
removed function step_wait() from stepper.cpp because its used nowhere.
Scott Lahteine d9d4a78e0f Add proper delay in stepper.cpp
Issue  describes a delay that the compiler is optimizing out and
this solution.
CONSULitAS d1322dafc9 Add: Example Configuration for Vellemann K8200 - based on new BOARD_K8200
# Add: Example Configuration for Vellemann K8200 - based on new
BOARD_K8200 

* K8200: new folder in example_configurations for Vellemann K8200 (3Drag
clone - should work with 3Drag http://reprap.org/wiki/3drag, too. Please
report)
* K8200/Configuration.h/Configuration_adv.h: updated manually with
parameters form genuine Vellemann Firmware "firmware_k8200_marlinv2"
based on the recent development branch

I tested the changes on my K8200 with 20x4-LCD and Arduino 1.0.5 for
Windows (SD library added to IDE manually) - everything works well
CONSULitAS 3b50a5e2e6 Add: Board for Vellemann K8200 (derived from 3Drag)
## Add: Board for Vellemann K8200 (derived from 3Drag)

* Boards.h: updated comment for board 3Drag - K8200 removed
* Boards.h: added `BOARD_K8200` with ID 78

* language.h.: machine name and firmware URL for new board

* pins.h: added `K8200` to any `#if` with `3Drag` and corresponding
comments
Michael Neumann 2d454da3af Update ConfigurationStore.cpp
Show Custom M Code when entering M503
Scott Lahteine 4f35de991a Merge pull request from CONSULitAS/Development
Update Boards.h for Vellemann K8200 - comment only
roglio 22571ca13d Revert "Configuration for Aurora Z605"
This reverts commit 935ee968a7.
roglio 935ee968a7 Configuration for Aurora Z605
Still not fine tuned but working.
roglio ccdbeda526 Fixing a build error for melzi and gfx display
When a melzi board and a full gfx are both selected, the build fails
blaming for some missing defines.

This is a fix for the issue: now my configuration works.
CONSULitAS e13f159343 Update Boards.h for Vellemann K8200 - comment only
## Update Boards.h for Vellemann K8200 - comment only

* Boards.h: updated comment for board 3Drag - K8200 uses same board
CONSULitAS 51c7f2fd5a Revert "## Add: Example Configuration for Vellemann K8200"
This reverts commit 5333590ac2.
CONSULitAS 5333590ac2 ## Add: Example Configuration for Vellemann K8200
* K8200: new folder in example_configurations for Vellemann K8200 (3Drag
clone - should work with 3Drag too, please report)

* K8200/language.h: updated machine name and URL for K8200

* K8200/Configuration.h/Configuration_adv.h: updated manually with
parameters
form genuine Vellemann Firmware "firmware_k8200_marlinv2" based on the
recent development branch

* K8200/files by Vellemann: added folder with original files from
Vellemann homepage, since there is no GitHub fork you could link to by
them

I tested the changes on my K8200 with 20x4-LCD and Arduino 1.0.5 for
Windows - everything works well
Denis Chertykov ba3ac40b9d Remove hardcoded programmer option (-cwiring). Use variable AVRDUDE_PROGRAMMER.
Change default value of AVRDUDE_PROGRAMMER to 'wiring'.
daid 53f971095d Revert "Reduce PROGMEM warnings"
PxT 67b597ad46 Update printrboard pin assignments
Backported from Printrbot branch, allows the fan to work correctly.
galexander1 d4880a9e60 Revert "Move Sd library out into library"
Bo Herrmannsen ccdb086fc8 Merge pull request from PxT/patch-1
Fixes 
Bo Herrmannsen 5151db5c2f Merge pull request from msutas/patch-2
Improvement - G29 Option for Not Retracting Servo
Bo Herrmannsen 1746b2582b Merge pull request from Sniffle/Development
Rambo FAN_PIN documentation and servo support
Bo Herrmannsen 4b51b5a46d Merge pull request from odewdney/SDlib
Move Sd library out into library
Bo Herrmannsen f2cb4a3655 Merge pull request from thawkins/Development
fix avrdude upload in makefile
PxT 9fd4292923 Fixes
odewdney f84ff4ba7d Move SD Fat library out of main src
Bo Herrmannsen ab074dac17 Merge pull request from grob6000/independent_pid
Independent PID parameters for each extruder
Bo Herrmannsen d4a665694a Merge pull request from odewdney/Development
Reduce PROGMEM warnings
odewdney 9d9c859ac1 First move of SdFat library
Tim Hawkins 5045d17a39 fix avrdude upload in makefile
msutas 3a5a6f42fb Corrected the ABL grid option
G29 E was not retracting the probe on the last probe point when used with ABL grid. Corrected.
odewdney cd55a93a13 re-add blank line
odewdney 23bfe30036 moved include themister to temperature.c
odewdney 538859669d Removing compiler warnings for progmem
grob6000 bf2c923db5 Make multiple PID parameters a config option
* Adds config parameter `PID_PARAMS_PER_EXTRUDER` - allows single PID
parameters to be used where this would be preferable (e.g. dual
identical extruders)
* When disabled, will use `float Kp, Ki, Kd, Kc;` as before.
Preprocessor macros used to switch between.
* ultralcd.cpp defines extra menus for extra parameters only where
required
* M301 reports `e:xx` only if independent pid parameters enabled
* EEPROM structure still leaves space for 3 extruders worth, when undef
will save single parameter to all extruder positions, but only read the
first
* Switching off saves approx 330 B with no LCD enabled, 2634B with LCD
(RRD) enabled: this is significant.
* LCD modifications should be tested.
grob6000 0877aa0fe0 Merge remote-tracking branch 'upstream/Development' into independent_pid
msutas e0beb98fd3 Improvement - G29 Option for Not Retracting Servo
This change introduces an improvement to G29 command on Marlin.

Auto bed leveling operation's reliability is based on the repeatability of the Z-probe switch and the servo. This change introduces an option to G29 command. When the G29 command is sent with an "e" option, during auto bed levelling the servo is not retracted between probes which decreases the bias on auto bed levelling resulting from servo.

G29 command does the auto bed probing as it is.

G29 E command engages the servo on first probing point, probes all points and retracts the servo after probing the last point.

Please comment your opinions, test on your printer and check the code on a programmer's perspective. (I am not a good programmer.)
grob6000 7d32c7f36d Multiple PID parameter edit for ultralcd
* Depending on extruder count, will add menu items for ultralcd to edit
individual PID parameters for each extruder
* Added menu items to each language_xx.h
* Builds OK, but recommend testing with typical LCD
Steffen Vogel 69dc411ae0 Merge branch 'Development' of github.com:MarlinFirmware/Marlin into LogoLCD
Conflicts:
	Marlin/dogm_lcd_implementation.h
grob6000 3e2af67ce3 Fix R-H compatibility
* R-H reads incorrect M301 line from EEPROM output if more than one is
present. Reverted to original output format, using only E0 value.
grob6000 37c7e8300f Independent PID parameters for each extruder
* Variables Kp, Ki, Kd, Kc now arrays of size EXTRUDERS
* M301 gains (optional, default=0) E parameter to define which
extruder's settings to modify. Tested, works with Repetier Host's EEPROM
config window, albeit only reads/updates settings for E0.
* All Kp, Ki, Kd, Kc parameters saved in EEPROM (version now v14), up to
3 extruders supported (same as Marlin in general)
Scott Lahteine 326b925557 DOGLCD and LCD_PROGRESS_BAR to coexist
Small changes (and formatting to confuse the diff’er) which first
allows DOGLCD and LCD_PROGRESS_BAR to be enabled in tandem, then a
#warning (rather than error) that the extra progress bar / message
options don’t apply to graphical displays at this time. This leaves
open perhaps combining the progress bar and message area in some future
(or forked custom) graphical LCD display arrangement (at which time the
relevant variables may be moved into ultralcd.cpp with externs in
ultralcd.h). I also added a conditional error that the progress bar and
the filament display may not work well together.
Erik van der Zalm 1aade4a8e2 Merge branch 'Development' of https://github.com/MarlinFirmware/Marlin into Development
Erik van der Zalm 8a2e84e3f1 Possible fix for FWRETRACT with 0 zlift.
Steffen Vogel 905aab3b85 added missing #endif
Steffen Vogel b9cf1465a7 updated LCD bouts with new strings and bitmaps
new version is pretty generic and should work in most scenarios
Steffen Vogel c7632be5cc added high and low resolutions version of splash screen logo (saving code size)
Steffen Vogel 8f0dba7cbf adding string for bouts splash string to config
Bo Herrmannsen d94109e886 updated logo post and ver info
Bo Herrmannsen cd33b5b062 changed logo and ver info
logo is now 110 pixels wide and starts 9 pixels in from top left corner and also 9 pixels down from same corner... this will give a 9 pixel border all way round

ver info is placed centered and there is a 9 pixel from bottom of display to ver info
Bo Herrmannsen 9b6c1cfda6 removed unneeded lines in welcome msg
Bo Herrmannsen ffa09f86f4 moved ver info 5 spaces to the right
Alex Borro 2bbb68be8a Fix calculation of BAL grid fitting into the bed
The previous calc was wrong. Between N points there are only N-1 gaps,
not N.

So changing AUTO_BED_LEVELING_GRID_POINTS to
(AUTO_BED_LEVELING_GRID_POINTS-1)
Bo Herrmannsen 590caafa2d changed ver info
Bo Herrmannsen 3bb9b31515 changed boot logo a bit to test if fat wall goes away
Steffen Vogel da192c521f Merge pull request from andrewsil1/development
Fix grammar/typos in new Configuration.h option
Erik van der Zalm 3a30d45c2e Revert "issue 968 for dev branch"
andrewsil1 269ec9f87f Fix grammar/typos in new Configuration.h option
(For the SLOW_PWM_HEATERS option)
Todd Swindoll 506353892e Rambo Pin documentation and servo support
Updated pins reference and servo support.

cross referenced between Rambo 1.1, 1.2, and 1.3
Steffen Vogel 8d7bfd03d8 moved/renamed documentation stuff to top-level directory
Bo Herrmannsen 3c9e6b7b62 added link for pic to hex converter
Bo Herrmannsen 0e760274bd changed reprap logo to marlin logo
Bo Herrmannsen b291a422e9 added square png version of logo
406*406 pixels
Luis E Alvarado 7ae548cf34 Update Marlin Firmware URL
Erik van der Zalm 8f9067faa6 Added marlin logos. (Designed by Ahmet Cem TURAN)
Bo Herrmannsen addf52fd4a Merge pull request from DinoMesina/development
Some corrections and new features
Dino Del Favero 5cfe13f240 Correct some mistakes
Dino Del Favero c7e2d73039 Merge branch 'development'
ok
Alex Borro 422a958a34 Fix CoreXY speed calculation
For cartesian bots, the X_AXIS is the real X movement and same for
Y_AXIS.
But for corexy bots, that is not true. The "X_AXIS" and "Y_AXIS" motors
(that should be named to A_AXIS
and B_AXIS) cannot be used for X and Y length, because A=X+Y and B=X-Y.
So we need to create other 2 "AXIS", named X_HEAD and Y_HEAD, meaning
the real displacement of the Head.
Having the real displacement of the head, we can calculate the total
movement length and apply the desired speed.
Dino Del Favero 038fccd7a1 I have added some code in the "temperature.cpp" for have the possibility of control the time of the states with the heater drived by relays, with this feature now it is possible use PID function in conjunction with relay to control the temperature. I have made some tests and the temperature stay always in the range of +-1°C from the setted temp.
There is the possibility of turn on this features adding "#define SLOW_PWM_HEATERS" in Configuration.h
DinoMesina 6730335657 Update Configuration.h
Bo Herrmannsen 4ffecdbf7d Merge pull request from wgm4321/Development
Re-enable filament menu with recalc fix when enabling/disabling mm3
Steffen Vogel 672f764b4d replaced ASCII GPL v3 license by markdown version
moved new COPYING file to top-level directory to make it more visible and remove clutter from Marlin subduer
Steffen Vogel f25e793cff rename stepper lookup table scipt to be consistent with termistor lookup table script
Steffen Vogel df17a6a1b4 fix by proposed workaround (thanks gaby64)
Steffen Vogel f7e65935fb make use of power operator
Steffen Vogel 4e02aff9b5 automatically determine min/max temp for terminator
Steffen Vogel 81363bc441 more cleanups
Steffen Vogel 95f4a55820 refactored termistor table calculation to be in line with wikipedia's article about Steinhart-Hart coefficients
Steffen Vogel 21205cc3d8 more cleanups in the termistorTable generation script
Steffen Vogel fb0996b5db improved output aligment and precision
Steffen Vogel 538231edfd cosmetic whitespace cleanup and comments added/updated
wgm4321 067b509479 Re-enable filament menu with recalc fix when enabling/disabling mm3
wgm4321 a19f2f8ae7 Disable volumetric menu item due to missing recalc of of multipliers when enabled/disabled
wgm4321 f24dda9700 Revert "Make sure volumetric multipliers are recalc'ed during menu enable/disable of mm3"
This reverts commit dd7e4ee97f.
wgm4321 ec4681ab6b Revert "Add "Detailed Z Probe" menu item with ABL is defined."
This reverts commit 2b9722f387.
wgm4321 dd7e4ee97f Make sure volumetric multipliers are recalc'ed during menu enable/disable of mm3
wgm4321 2b9722f387 Add "Detailed Z Probe" menu item with ABL is defined.
Dan Royer 9472bbe51d issue 968 for dev branch
try, try again.

If 'OK' is garbled on sending PC won't receive it.  Both machines will
wait on each other forever.  This resends OK if nothing is heard from PC
for a while to avoid this bad case.
alexborro d2b6e62996 Merge pull request from philfifi/fix_temp_runaway
temp runaway: proper cast to prevent any overflow.
Philippe L 30248214c7 temp runaway: proper cast to prevent any overflow.
Bo Herrmannsen c5f138ea07 Merge pull request from alhirzel/Development
Define analogInputToDigitalPin only if needed
odewdney 652895d656 try different proproc for CI failure
Bo Herrmannsen 3d9f4ac757 Merge pull request from wgm4321/Development
Fix for cant compile when REPRAP_DISCOUNT_FULL_GRAPHIC_SMART_CONTROLLER ...
wgm4321 04fb34c7ff Add English defines for filament menu to non-English to prevent compile errors until translated
wgm4321 f8aa5ff771 Fix for cant compile when REPRAP_DISCOUNT_FULL_GRAPHIC_SMART_CONTROLLER defined
odewdney 39fae9e3a3 Fix progmem warning
Borrow code from https://github.com/arduino/Arduino/issues/1793
Alexander Hirzel f36fd3ddec Merge branch 'Development' of https://github.com/ErikZalm/Marlin into Development
Scott Lahteine b5e50cdd4e Move scripts and documentation to subfolders
Alexander Hirzel eed451e034 rework analogInputToDigitalPin definition
Lane Roberts 1f520a5a8c Due to the fix for , X and Y probe offsets must not be floats.
The compiler does not support comparing float values: "error: floating constant in preprocessor expression"
The loss in X/Y precision shouldn't matter for Z probes, as most microswitches or inductive sensors are larger than 1mm square anyway.
wgm4321 b32be2dc64 Fix syntax error caused by previous changes.
wgm4321 edac64e7d2 Add Filament menu and add Filament/Retract settings to config store.
Alexander Hirzel ecda6cdc0a Fix typo, PID_BED_POWER -> MAX_BED_POWER
David Forrest f3e503e725 temperature.cpp: Fix typo of PID_MAX to MAX_BED_POWER for the bed.
David Forrest 1d5d853c9a temperature.cpp: Fix typo of MAX_BED_PID to MAX_BED_POWER.
Bo Herrmannsen 63da6900b0 Merge pull request from vandarin/Development
Due to the fix for , X and Y probe offsets must not be floats.
Bo Herrmannsen a18b625534 Merge pull request from wgm4321/Development
Add Filament menu and add Filament/Retract settings to config store.
Alexander Hirzel ae12ad0d6c Fix typo, PID_BED_POWER -> MAX_BED_POWER
alexborro 80b17ab573 Merge pull request from drf5n/PID_CI_v2
temperature.cpp: Fix typo of MAX_BED_PID to MAX_BED_POWER.
David Forrest 625860f086 temperature.cpp: Fix typo of PID_MAX to MAX_BED_POWER for the bed.
David Forrest 6583bb781d temperature.cpp: Fix typo of MAX_BED_PID to MAX_BED_POWER.
Lane Roberts 2701dd8a17 Due to the fix for , X and Y probe offsets must not be floats.
The compiler does not support comparing float values: "error: floating constant in preprocessor expression"
The loss in X/Y precision shouldn't matter for Z probes, as most microswitches or inductive sensors are larger than 1mm square anyway.
Grogyan 6b82415c81 Update pins.h
Somehow the pin definitions for the MAX6675 Slave Select/Chip Select got changed back to the hardware SPI SS/CS.  
Pin 49 cannot be used as that is used by the SD card socket to detect if an SD card is present.
Pin 53 is the Hardware SPI SS, which is dedicated, nicely, to the SD card SS and therefore cannot be used as the MAX6675 SS
Pin 66 is in Aux2 port adjacent to the Hardware SPI interface port on RAMPS 1.4, and is currently not used for anything.
Bo Herrmannsen 692a01b1c7 Merge pull request from thinkyhead/fix_regressions
Fix regressions affecting compilation
Scott Lahteine 2ec2bf1564 Fix regressions affecting compilation
This fixes two regressions, caused by  and  .
Scott Lahteine e7db8ee9e5 ftostr32np > ftostr32sp
sp=space-padded, similar to: ns=no-sign
Scott Lahteine 10e1b6ef8b Least stack-usage self-contained ftostr32np()
This is the optimal code for a self-contained formatter, although the
original code is crafty in being smaller and simpler, and can be
evaluated as using the original output as a scratch pad for state,
making the final formatter more straightforward. While this code is
longer, all code-paths are minimal.
Scott Lahteine d1f21d1189 As it should be
Scott Lahteine 449dad71f2 Least stack-usage self-contained ftostr32np()
This is the optimal code for a self-contained formatter, although the
original code is crafty in being smaller and simpler, and can be
evaluated as using the original output as a scratch pad for state,
making the final formatter more straightforward. While this code is
longer, all code-paths are minimal.
Scott Lahteine a2109cb492 Patch to make Z look more like X and Y on UltraLCD
Bernhard Kubicek 3d1da45f3e Update Marlin.h
bkubicek d02daec08f fixed compilation
Caleb Anderson 991a74b75b Move delta calibration menu to sample delta configuration.
Turn off by default.
Bo Herrmannsen 67fd8f0727 Merge pull request from RobotCaleb/LanguageFix
Language Fix - Using the new language implementation wasn't behaving as expected.
Caleb Anderson 236db44669 Fix spacing
Caleb Anderson e6774fb7d2 Using the new language implementation wasn't behaving as expected.
No matter what LANGUAGE_CHOICE was set to it would always take the en branch.
I revamped it a bit to use a macro to create the language include file name. This required a slight tweak to the RU declaration since it's special-cased in a couple places in code.

This is an attempt to pull my changes from  over.
Caleb Anderson cb047e9070 Actual menu change. Moved menu logic to not be shown unless not currently printing. (untested but straight-forward, printer in a bad state currently)
Caleb Anderson 5b336a4cdb Delta calibration menu based on http://minow.blogspot.com/index.html#4918805519571907051
To test/enable, uncomment the #define DELTA_CALIBRATION_MENU in Configuration.h
Bernhard Kubicek 10ad9f1062 Addes servo0 pin ultimaker
Bernhard Kubicek f24c5d82e3 Update Marlin_main.cpp
fixed minor typo
Wurstnase 8a6f098cc6 Expand manage_inactivity
void manage_inactivity(bool ignore_stepper_queue=false)

standard is false so it is not necessary to change additional code. this
change should be better, hopefully nophead like this :)
Wurstnase d1995aec7a Rename ignore_blocks_queued
more speaking name
Wurstnase 4122de9d17 change filament issue
make a more general solution
wgm4321 d60efc3b5d Fix syntax error caused by previous changes.
wgm4321 cb12161191 Add Filament menu and add Filament/Retract settings to config store.
fmalpartida ec33df0554 Merge branch 'SAV-MkI_merge' into Development
Tested for SAV MKI and SAV 3D LCD on lewihe.
Matthew Schick 0468f81950 Update for pull request
Matthew Schick 6e42c9e305 Add fwretract settings to M503 output
alexborro 3afe66bb0c Fix issues ,
- Fixed issue when BAL area probing is shorter than it should be for
grid probing
- Warning when BAL activated with Delta Kinematics
- Fix XY_TRAVEL_SPEED when homing Z axis
Lukas Obermann 9eb6df17a7 Consider negative Z Offsets when auto bed leveling is active
Bo Herrmannsen c9f60183a9 Merge pull request from NarimaanV/Development
Fixed BABYSTEPPING feature
Bo Herrmannsen 0d957872a0 Merge pull request from gregrebholz/issue_1069
Fixes .  Added "auto fan" checks to PID_autotune.
Bo Herrmannsen 9c07d28bd6 Merge pull request from drf5n/PID_CI_v2
temperature.cpp: Add Conditional Integration to prevent excessive integral windup
Bo Herrmannsen 23e768dffa Merge pull request from chertykov/Development
Move initialization of errormagic[] and echomagic[] to Marlin_main.cpp
Scott Lahteine 2f467e2797 LCD Progress Bar
Denis Chertykov 050ca9ca13 Move initialization of errormagic[] and echomagic[] to Marlin_main.cpp
David Forrest cf52c48d19 Configuration.m: Set PID_INTEGRAL_DRIVE_MAX from PID_MAX from BANG_MAX.
Current defaults are all 255.  If it makes sense to reduce them, they should come down together, and
be in a  PID_INTEGRAL_DRIVE_MAX <= PID_MAX <- BANG_MAX relationship.
David Forrest 984177c40c temperature.cpp:Add PID Conditional integration on heated bed.
David Forrest c9b8435749 heater.c: Limit PID I term with conditional integration.
Greg Rebholz 7ecb7cbd46 Added "auto fan" checks to PID_autotune
NarimaanV 7667949aca Fixed BABYSTEPPING feature
Moved PSTR() macro to correct place which was causing the " initializer fails to determine size of '__c' " when attempting to compile with BABYSTEPPING enabled.
alexborro d74aabf259 Revert "Change Auto_Bed_Leveling to Auto_Bed_Compensation"
Bo Herrmannsen 60628864ca Merge pull request from thinkyhead/sd_freemem
Use SdFatUtil::FreeRam() for freeMemory() if there
Bo Herrmannsen 889d7ba218 Merge pull request from martin-pr/probing_z_speed
Split do_blocking_move() to XY and Z sections
Bo Herrmannsen 5e7bd2dc87 Merge pull request from chertykov/Marlin_v1
Fix syntax errors in #ifdef
Denis Chertykov b086394178 Fix syntax errors in #ifdef.
John Davis 39d28a9bbf Update qr_solve.h
Changed level to compensation
John Davis 6325968a39 Update qr_solve.cpp
Changed leveling to compensation
John Davis e99f24ff2f Update planner.h
Changed level and leveling to compensation.
John Davis ac204028e7 Update planner.cpp
Changed level and leveling to compensation
John Davis 4315c2547a Update Marlin_main.cpp
Changed level and leveling to compensation (except with "verbose_level" and "lcd_reset_alert_level").
John Davis f21c65918f Update Servo.h
Changed AUTO_BED_LEVELING to AUTO_BED_COMPENSATION
John Davis 58c4473bea Update Servo.cpp
Changed AUTO_BED_LEVELING to AUTO_BED_COMPENSATION
John Davis 825c46024d Update vector_3.cpp
Changed AUTO_BED_LEVEL to AUTO_BED_COMPENSATION
John Davis cfe80e1def Update vector_3.h
John Davis 7464d3c96a Update ConfigurationStore.cpp
Changed AUTO_BED_LEVEL to AUTO_BED_COMPENSATION
John Davis 81568c3c6d Update Configuration.h
Changed Auto Bed Level to Auto Bed Compensation
Bo Herrmannsen 03e489aaad Merge pull request from foosel/fix/issue_1147
Fixes commands not being acknowledged in the same order they are received in
Gina Häußge acc0e75279 Fixes commands not being acknowledged in the same order they are received
in

G0 to G3 were previously acknowledged in the get_command method, causing
them to be possibly acknowledged before commands coming after them that
were acknowledged in process_commands.

This patch fixes this, moving the acknowledgement of G0 to G3 to the
process_commands method as well. These commands are therefore no
longer acknowledged when the enter the cmd_buffer but instead only
acknowledged when the enter the plan_buffer.

Guaranteeing that commands are acknowledged in the same order in which
they were received by the firmware allows host software to be able to
track the life cycle of commands and such a better management of the
firmware's serial buffers as well as better internal command processing
and response parsing without having to depend on throwing an epic
amount of regular expressions against each line received back from the
firmware.

Fixes 
daid 17de96ace7 Merge branch 'Marlin_v1' into revert-1154-sd_sorting
Conflicts:
	Marlin/cardreader.cpp
	Marlin/cardreader.h
Scott Lahteine 6880e93b75 Happy configs
Scott Lahteine 3b1f186c0c Clean up configs
Scott Lahteine f83d0f2a68 Defines for electronics boards
Added boards.h which contains defines for all the board numbers, plus
some shorthand macros for less typing.
Bo Herrmannsen bd25e7393b Merge pull request from thinkyhead/split_language
Split up languages.h. Use ISO language codes.
Bo Herrmannsen 174f8d3631 Added example configs for printers from http://tvrrug.org.uk/
Scott Lahteine e970461adb Clean up, move unused to the bottom, add headings
Scott Lahteine 0c06e97e98 Split up languages.h, use ISO codes
Breaking up languages.h makes it easier to translate. Using language
codes makes it easier to select a language and sets the naming standard.
Bo Herrmannsen a9c334e8bc Merge pull request from thinkyhead/code_shrink
Shrink and Optimize
Bo Herrmannsen 842da54e68 Merge pull request from thinkyhead/fix_constants
A few constants where they belong
Scott Lahteine 07c6b5ab71 Using axis constants
Scott Lahteine 1857e611d3 Other small tweaks
Scott Lahteine 63e1665fa9 Reduce ultralcd.cpp redundancies
Scott Lahteine e69313fc2b Reduce dogm lcd code
Bo Herrmannsen bd22405412 Merge pull request from thinkyhead/sd_sorting
Wrap call to flush_presort
Scott Lahteine 49791949af Wrap call to flush_presort
Scott Lahteine 0450e83fa5 Use SdFatUtil::FreeRam() for freeMemory() if there
Scott Lahteine f21cce0b28 Rebase to Marlin_v1
Scott Lahteine e4b98011cf And one more...
Scott Lahteine 60598b4cdd A few constants where they belong
Bo Herrmannsen 280504e2e0 Merge pull request from alromh87/Marlin_v1
Support for Gen3 Monolithic electronics
Bo Herrmannsen 31ca3de72f Merge pull request from neildarlow/Marlin_v1
Activate LiquidTWI2 device detection and space-pad LCD status line.
Bo Herrmannsen e83cfc0a62 Merge pull request from thinkyhead/lcd_abort_message
LCD "Abort" Message
Bo Herrmannsen 0b310ab6c5 Merge pull request from xinfab/negative_values_in_menu
Negative values in menu
Bo Herrmannsen 91d740e128 Merge pull request from filipmu/Filament-Sensor
Display filament sensor data on a 20x4 LCD or Graphical LCD
alexborro ab355a90d3 Revert "SD Sort and Buffer"
Scott Lahteine d088b5f30f Remove debug echo
Scott Lahteine 1fad8e6a81 Proper long file name var
Scott Lahteine 29e854c535 Disable SDCARD_SORT_ALPHA by default
For legacy boards it’s better if this option is disabled.
Scott Lahteine 6599adc184 Polish up a little...
Scott Lahteine a12eec33e2 Completed SORT_USES_MORE_RAM implementation
For the MORE_RAM option we need to buffer both the short and long
names, even though long names are sometimes redundant. Worst case, all
the names are max length. We can save some RAM by not storing these. We
could save more RAM by only storing the visible part of the long name.
Scott Lahteine c9486ebb85 Improvements, more SORT_USES_MORE_RAM
With this option, always keeps the dir in RAM, doubling as a cache for
getfilename. A board with only 8K of SRAM is cutting it very close.
Scott Lahteine b6ffea612a Expand on More RAM concept, address minor bugs
Scott Lahteine 8196b36ad9 SD Card Alpha Sorting
First iteration of alphabetical sorting for SD cards, both
slow+efficient and fast+rammy. Option for folders to sort first, last,
or not at all.
Scott Lahteine cf749dbeda Completed SORT_USES_MORE_RAM implementation
For the MORE_RAM option we need to buffer both the short and long
names, even though long names are sometimes redundant. Worst case, all
the names are max length. We can save some RAM by not storing these. We
could save more RAM by only storing the visible part of the long name.
Scott Lahteine ae081d0fe0 Improvements, more SORT_USES_MORE_RAM
With this option, always keeps the dir in RAM, doubling as a cache for
getfilename. A board with only 8K of SRAM is cutting it very close.
Scott Lahteine 785143a013 Expand on More RAM concept, address minor bugs
Scott Lahteine 0cbbba08bd SD Card Alpha Sorting
First iteration of alphabetical sorting for SD cards, both
slow+efficient and fast+rammy. Option for folders to sort first, last,
or not at all.
Scott Lahteine 3ebfd29312 Print a message when printing is aborted
Messages in gcode files like “M117 Printing…” were not being cleared on
Stop Print.
Martin Prazak 2ef0669b19 Split do_blocking_move() to XY and Z sections to make sure that the Z homing feedrate is not exceeded
Neil Darlow 64139f5e5a Merge https://github.com/ErikZalm/Marlin into Marlin_v1
Bo Herrmannsen edfcf3b527 Toshiba Stepper Driver support
Tosh stepper drivers need to be driven slower, so the stepper code
was interleaved to separate the pin HIGH from the pin LOW. This adds
enough instructions to make it work, without needing nops.
Bo Herrmannsen c429a4b3ec Toshiba Stepper Driver support
Tosh stepper drivers need to be driven slower, so the stepper code
was interleaved to separate the pin HIGH from the pin LOW. This adds
enough instructions to make it work, without needing nops.
nothinman 1977b4490f Merge pull request from thinkyhead/lcd_wait_better
M0/M1 Message Fix
Scott Lahteine 7562183efc Skip over spaces first
nothinman 5a8b3a84ae Merge pull request from thinkyhead/lcd_wait_better
M0-M1 Enhancements
elgambitero 433ac29d31 Updated a bit of spanish language
Scott Lahteine 12b51d6060 Ignore S and P if no value >0 is included.
Scott Lahteine d12b24758a Clear LCD to welcome_msg if not printing
The welcome message is more appropriate than “resuming print” if
nothing is printing.
Scott Lahteine 3f54c9ba33 Relocate click ignore code into info screen
Scott Lahteine 92e21d3ee2 M0-M1 Enhancements
Allow M0 and M1 to include a message string. Ignore clicks on “Wait for
user” so that the Info Screen stays up.
Lionello Lunesu 0d35b1d0b8 Allow negative values in menus
Jonas 0d97dec434 Adaption of LCD info screen
Here comes a compile-time operation to match the extruder symbols on the
info screen to the set number of extruders in configuration.h.
When only one extruder is selected, the "1" on the symbol will not be
displayed.
Filip Mulier 3b1ab84536 Display Filament Sensor data on graphic LCD
Added support to show the filament width on the status line of the
graphic LCD.  The status will show for 5 sec and then switch over to
data.  Status can be seen by clicking the button.
Filip Mulier d84934d8c5 Display Filament Sensor data on 20x4 LCD
Changes to support displaying the real-time filament width and the
volume factor on a 20x4 LCD.  The data is displayed on the 4th line.
First the status message is displayed for 5 seconds, and then the
filament data is displayed.  The status message can be seen by
re-selecting the info screen in the menu.
Filip Mulier 5c8107bcdd Commented out FILAMENT_SENSOR #define
Commented out the FILAMENT_SENSOR define so that it is not enabled by
default.  Code does not work on all hardware variants.
David 377dfb182f Updated example configurations for Delta printers
Neil Darlow b81021f475 Merge https://github.com/ErikZalm/Marlin into Marlin_v1
Erik van der Zalm 724197454c Merge pull request from ch100/Marlin_v1
Fixed typo.
Erik van der Zalm 058e446531 Merge pull request from filipmu/Filament-Sensor
Support for a filament diameter sensor
Christian Inci 110c5dcf23 Fixed typo.
Signed-off-by: Christian Inci <chris.pcguy.inci@gmail.com>
Matt Stultz ca30aee903 Fix "add_homeing" to "add_homing" to match changes
Erik van der Zalm 0733825fb1 Merge pull request from Fourmi/Marlin_v1
Update line 627 ,wrong number on thermistortables
Fourmi af3e4d7510 Update line 627 ,wrong number on thermistortables
Wrong number on line 627 > i change number "12" by the correct number "13"
Soory
Erik van der Zalm aaaf8fe8dd Merge pull request from darkjavi/Marlin_v1
Added profile for RAMPS with 2 extruders and 1 fan, no heated bed
Erik van der Zalm b360306881 Merge pull request from WingTangWong/wing-fix-float-delta
Wing fix float delta
Erik van der Zalm ce85515428 Merge pull request from Fourmi/Marlin_v1
Add thermistor table
Erik van der Zalm 764921bdbf Merge pull request from Aldert/patch-1
Update motion_control.cpp
Erik van der Zalm c40c7b589b Merge pull request from thinkyhead/codeclean
Simple code cleanup. Rename "homeing" to homing.
Erik van der Zalm 0f2e0525df Merge pull request from thinkyhead/set-home
Proposed feature: Set Home Offsets
Erik van der Zalm 5ae02a361b Merge pull request from thinkyhead/round-up-xyz
Adjust the Z display to hide float rounding errors
Matthew Schick fb34265d75 Make hotend optional when compiling with lcd support
Signed-off-by: Matthew Schick <matthew.schick@gmail.com>
Scott Lahteine 6e343ef2f0 Adjust the Z display to hide float rounding errors
Scott Lahteine 2f6c57eadc Proposed feature: Set Home Offsets
Add an item to the LCD menu that applies the current axis position to
the “add_homeing” offset.
Scott Lahteine f989bd5435 Simple code cleanup. Rename "homeing" to homing.
Neil Darlow 6c5a460e65 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Aldert d1e4237e1d Update motion_control.cpp
G03 Full circle did not work (G02 is working correct)
Fourmi a664763e6f Update thermistortables.h
Add another thermistor table (13),it's a cartridge thermistor up to +300°C,use with Hotend "Simple ONE" & "All In ONE"

Thx
Fourmi b5dc228a7a Update configuration.h
Add another comment for thermistor 13 ,use with Hotend "Simple ONE & All In ONE"
Fourmi 3cbb2f56c6 Update configuration.h
Add another comment on configuration.h for the value of thermistor.
I make a pull request on thermistortables.h with my thermistor (12),but y see there is a comment on configuration with number 12 but it's not present on thermistortables.h ?

Thx
Fourmi c35736a140 Update thermistortables.h
Add another thermistor table,use with hotend "Simple ONE" & "All in ONE"
galexander1 cb4a6dd2dc Merge pull request from oliasmage/Marlin_v1
Corrected retract() call for use of auto probe without sled enabled.
Bracken Dawson 01e9b536cb Fix build for non-sled bed auto levelling
This function should only be used with sled, not all bed auto
levelling.
Wing Tang Wong 58eabd21fb Added ifndef
Wing Tang Wong 88d12a762a Added #ifndef DELTA wrapper to float delta
alexborro bf0ecedf60 Merge pull request from fsantini/EZ_fix935
Fix issue 935: error in matrix calculation
Javi 40ba644bb4 Added profile for RAMPS with 2 extruders and 1 fan.
modified:   Marlin/Configuration.h
	modified:   Marlin/pins.h
Charles Bell 3b8216bdd1 Corrected #endif and ifdef for Z_PROBE_SLED code.
Charles Bell 37799f70ba Corrected retract() call for use of auto probe without sled enabled.
Neil Darlow 1632e5e38a Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Filip Mulier fe3a09bbcf Correct analog sampling time for additional A to D sample
Adjusted the  #define PID_dT to reflect 10 A to D sample steps, vs
original 8.
Gina Häußge 1e9dc85148 Do not use translations for the serial console messages
The serial protocol has to stay machine readable, without having
to cope with a ton of different human language variants. So
just leave it at the original english version.

Should fix 
fsantini cf325ba240 Fix issue 935: error in matrix calculation
Erik van der Zalm 018b68a5c4 Merge pull request from cocktailyogi/SCARA_by_Yogi
Implemented SCARA-Maths
Erik van der Zalm dde61d8886 Merge pull request from OskarLinde/Marlin_v1
Fix lcd itostr3() to handle negative numbers
Erik van der Zalm 0fbfb1bf82 Merge pull request from bonm014/patch-1
Leapfrog controller board support
Erik van der Zalm 8340ca6e05 Merge pull request from Grogyan/patch-1
temperature.cpp fixes for SD card and MAX6675
Erik van der Zalm 9887555192 Merge pull request from darconeous/pull-requests/fwretract
FWRETRACT fixes
Erik van der Zalm 105571ec68 Merge pull request from midopple/Marlin_v1
With option DISABLE_INACTIVE_EXTRUDER the extruder is disable to early
Erik van der Zalm 68dd5e635e Merge pull request from oliasmage/Marlin_v1
Adding Z Probe via sled mounted endstop
Erik van der Zalm 25069ed4e9 Merge pull request from Roxy-3DPrintBoard/Z_PROBE_REPEATABILITY-with-correct-Defaults
Z probe repeatability with correct defaults
Filip Mulier 75b3a68b65 Revert "Change pinMode to SET_INPUT or SET_OUTPUT"
This reverts commit 1d0fe035f3.
Filip Mulier e3c88a5120 Filament sensor changes to config file
Update the config file for improvements and clarifying what diameter to
use in the slicer software.
Filip Mulier 62db9848d3 Improvements and bug fixes in sensor delay buffer for filament sensor code
Improvement to avoid reinitializing delay buffer with every print. Fixed
issues in buffer indexing and memory out of bounds due to floating point
imprecision.  Simplified the code by avoiding conversion to standard
diameter and 1cu mm extrusion, which caused complications in determining
mm extruded.
Florian Baumann 5908fd5cec Fix reseting CHDK pin to LOW
chdkActive was set to false regardless of (millis() - chdkHigh) being bigger than the CHDK_DELAY or not. So if (millis() - chdkHigh) wasn't bigger than the delay the first time, the CHDK would never be set back to LOW.

Also, don't return from the function, as there might be other stuff to do, after the CHDK check.
Roxy-3DPrintBoard 0adbc79571 Fix Default Configuration so Auto Bed Leveling is off
This snapshot has the Auto Bed Leveling turned off because most Marlin
users do not have that feature.
Roxy-3DPrintBoard 0091865583 Z_PROBE_REPEATABILITY test
Z_PROBE_REPEATABILITY test for Auto Bed Leveling.
Implemented as M48 with extra user specified options.
Full support at
http://3dprintboard.com/showthread.php?2802-Auto_Bed_Leveling-Z-Probe-Repeatability-code
Filip Mulier 85649a4549 Real-time filament diameter measurement and control
This feature allows the printer to read the filament diameter
automatically and adjust the printer in real time.  Added code to read
an analog voltage that represents a filament diameter measurement.  This
measurement is delayed in a ring buffer to compensate for sensors that
are a distance away from the extruder.  The measurement is used to
adjust the volumetric_multiplier for the extruder.  Some additional g
codes (M404, M405, M406, M407) are used to set parameters and turn
on/off the control. g code M221 is updated.  Pins for RAMPS1.4, RAMBO,
and Printrboard are identified for analog input.  The configuration file
is updated with relevant user parameters.
Filip Mulier 1d0fe035f3 Change pinMode to SET_INPUT or SET_OUTPUT
Original code is using WRITE from fastio, but original used pinMode to
set pin direction and did not use the fastio SET_INPUT or SET_OUTPUT.
This caused an issue with the rotary encoder interface to  boards based
on teensyduino, since for teensyduino pin numbers for fastio and the
usual Arduino IO are different.
Charles Bell e7707aedbc Commented out new #defines in Configuration.h.
Charles Bell 0a8dc0e96b Added documentation to the README.md for the sled Z probe option. CAB
Charles Bell d2fcb3ee56 CAB: Added code for Z-probe with Z endstop mounted on a sled.
Neil Darlow 3cd7dbcc45 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
daid c13a831ea1 Merge pull request from foosel/fix/checksum_truncation_bug
Fix for a wrong checksum truncation for certain commands
Gina Häußge 2d22902d08 Fix for a wrong checksum truncation for certain commands
Positioning of string terminator to truncate checksum from the commands
M23, M28, M30, M32, M928 and M117 was off by one, causing the last
letter of the actual command to be truncated instead of just the
checksum.

In case of the SD commands this caused checksummed commands targeting
existing files to fail since the last letter of the filename was
truncated.

In case of M117 this caused the last given letter not to be displayed.

This patch fixes the off-by-one error and sets the null terminator
on the exact position of the * starting the checksum instead of the
character before that.
cocktailyogi ad3b770c1a updated examples
cocktailyogi 2f4a20257c imported last Marlin changes
daid aacff0d361 Merge pull request from Dim3nsioneer/Marlin_v1
Implementation of FW extruder change retract
midopple 17aa67e4ea If the option DISABLE_INACTIVE_EXTRUDER ist active the extruder switch to early to inactive because there are some moves in the buffer. So the planner wait 32 moves to disable the unused extruder.
Robert Quattlebaum 1fd9a7d476 Fix for FWRETRACT on DELTA printers.
Fixes 
Neil Darlow 3f2c771d90 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Grogyan bcd039aa81 Update pins.h
Grogyan 82606354dd Update temperature.cpp
Enables both SD card and MAX6675 to talk with each other
Fixes also issue 
bonm014 32a6451ad8 Add leapfrog and dual Y/Z
I have added the pin set for the leapfrog and the support of dual Y and Z
bonm014 b5417be109 Update Configuration.h
Leapfrog added to the board list
bonm014 f244045245 Update pins.h
Leapfrog board added to the pin list
Pablo Clemente 2242a84218 Changed the declaration of the variable to Marlin_main.cpp to fix issue on commit
Neil Darlow 6e3406d228 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
alexborro 43c298a7a9 Add "Thermal Runaway Protection" feature
This is a feature to protect your printer from burn up in flames if it
has a thermistor coming off place (this happened to a friend of mine
recently and motivated me writing this feature).

The issue: If a thermistor come off, it will read a lower temperature
than actual. The system will turn the heater on forever, burning up the
filament and anything
else around.

After the temperature reaches the target for the first time, this
feature will start measuring for how long the current temperature stays
below the target minus _HYSTERESIS (set_temperature -
THERMAL_RUNAWAY_PROTECTION_HYSTERESIS).

If it stays longer than _PERIOD, it means the thermistor temperature
cannot catch up with the target, so something *may be* wrong. Then, to
be on the safe side, the system will he halt.

Bear in mind the count down will just start AFTER the first time the
thermistor temperature is over the target, so you will have no problem
if your extruder heater takes 2 minutes to hit the target on heating.
Pablo Clemente d86c3cf43c Changed the type of variable to bool, the name to "cancel_heatup", flags implementation and added this fix to M190 gcode too.
cocktailyogi f0cab611db optimised some math-code
Oskar Linde 269a068032 Fix lcd itostr3() to handle negative numbers
cocktailyogi fae7d08698 fixed wrong compiler-option
cocktailyogi 512f2a3136 restore Branch from Backup
sorry for that
Pablo Clemente cd3220d055 Inverted state logic for forced_heating_stop variable
Pablo Clemente 86b4b805d2 Fixed stop print LCD function on M104
Greg Tan 6e6e4e2143 Added thermistor table for the 500C thermistor shipped with the Pico hot end.
Neil Darlow 9d11b70436 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Gina Häußge 0de826160e M30 response is missing linefeed, "ok" therefore not on own line
This leads to the command not being acknowledged properly
by the firmware, leading to consecutive issues in host software
waiting for an acknowledgement.
Dim3nsioneer 3c927901a4 Implementation of FW extruder change retract
FW retraction is extended onto swap retraction invoked by 'G10 S1'.
Bookkeeping of the retract state of all extruders allows for having one
extruder fw standard retracted while another extruder is swap retracted.
An LCD menu item for the swap retract and recover length was added.
Dim3nsioneer 8a32c5395b renaming the disable inactive extruder feature
Dim3nsioneer 29e7639933 Add switch unused feeder(s) off
Having the non-active feeder motors powered on all the time is not
necessary. A feature to deactivate the unused feeder motors has been
implemented. The feature is enabled on default but can be switched off
in the configuration.
Justin Nesselrotte 07c0eeee99 Fixed a comment in the planner
David Forrest 09b84faa00 Configuration.h, pins.h: Add MOTHERBOARD 84 for Teensy++2.0
neildarlow efb6d61413 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
nothinman 38192cb5f3 Add M112 description to Marlin_main
nothinman aed5ec008a Merge pull request from DanNixon/estop
Implemented M112
Erik van der Zalm cfb98ef682 More coverity fixes
zaubara 92e14298b0 Fixes typo for lcd backlighting on I2C PCF8575
When using LCD_I2C_TYPE_PCF8575T (like Sainsmart I2C), the backlight
won't come on; the incorrect ifdef blocks the evocation of the backlight
functions.
Erik van der Zalm 9db9842aea Fixed error found by the free coverity tool (https://scan.coverity.com/)
===================================================
Hi,

Please find the latest report on new defect(s) introduced to ErikZalm/Marlin found with Coverity Scan.

Defect(s) Reported-by: Coverity Scan
Showing 15 of 15 defect(s)

** CID 59629:  Unchecked return value  (CHECKED_RETURN)
/Marlin_main.cpp: 2154 in process_commands()()

** CID 59630:  Operands don't affect result  (CONSTANT_EXPRESSION_RESULT)
/Applications/Arduino.app/Contents/Resources/Java/hardware/arduino/cores/arduino/Tone.cpp: 319 in tone(unsigned char, unsigned int, unsigned long)()

** CID 59631:  Missing break in switch  (MISSING_BREAK)
/Marlin_main.cpp: 1187 in process_commands()()

** CID 59632:  Missing break in switch  (MISSING_BREAK)
/Marlin_main.cpp: 1193 in process_commands()()

** CID 59633:  Out-of-bounds write  (OVERRUN)
/temperature.cpp: 914 in disable_heater()()

** CID 59634:  Out-of-bounds write  (OVERRUN)
/temperature.cpp: 913 in disable_heater()()

** CID 59635:  Out-of-bounds read  (OVERRUN)
/temperature.cpp: 626 in analog2temp(int, unsigned char)()

** CID 59636:  Out-of-bounds read  (OVERRUN)
/temperature.cpp: 620 in analog2temp(int, unsigned char)()

** CID 59637:  Out-of-bounds write  (OVERRUN)
/temperature.cpp: 202 in PID_autotune(float, int, int)()

** CID 59638:  Out-of-bounds read  (OVERRUN)
/temperature.cpp: 214 in PID_autotune(float, int, int)()

** CID 59639:  Out-of-bounds write  (OVERRUN)
/Marlin_main.cpp: 2278 in process_commands()()

** CID 59640:  Out-of-bounds read  (OVERRUN)
/Marlin_main.cpp: 1802 in process_commands()()

** CID 59641:  Uninitialized scalar field  (UNINIT_CTOR)
/Applications/Arduino.app/Contents/Resources/Java/libraries/LiquidCrystal/LiquidCrystal.cpp: 51 in LiquidCrystal::LiquidCrystal(unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char)()

** CID 59642:  Uninitialized scalar field  (UNINIT_CTOR)
/Applications/Arduino.app/Contents/Resources/Java/libraries/LiquidCrystal/LiquidCrystal.cpp: 45 in LiquidCrystal::LiquidCrystal(unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char)()

** CID 59643:  Uninitialized scalar field  (UNINIT_CTOR)
/Applications/Arduino.app/Contents/Resources/Java/libraries/LiquidCrystal/LiquidCrystal.cpp: 32 in LiquidCrystal::LiquidCrystal(unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char)()

________________________________________________________________________________________________________
*** CID 59629:  Unchecked return value  (CHECKED_RETURN)
/Marlin_main.cpp: 2154 in process_commands()()
2148                 }
2149               #endif
2150             }
2151           }
2152           break;
2153         case 85: // M85
   CID 59629:  Unchecked return value  (CHECKED_RETURN)
   Calling "code_seen" without checking return value (as is done elsewhere 66 out of 67 times).
2154           code_seen('S');
2155           max_inactive_time = code_value() * 1000;
2156           break;
2157         case 92: // M92
2158           for(int8_t i=0; i < NUM_AXIS; i++)
2159           {

________________________________________________________________________________________________________
*** CID 59630:  Operands don't affect result  (CONSTANT_EXPRESSION_RESULT)
/Applications/Arduino.app/Contents/Resources/Java/hardware/arduino/cores/arduino/Tone.cpp: 319 in tone(unsigned char, unsigned int, unsigned long)()
313         else
314         {
315           // two choices for the 16 bit timers: ck/1 or ck/64
316           ocr = F_CPU / frequency / 2 - 1;
317
318           prescalarbits = 0b001;
   CID 59630:  Operands don't affect result  (CONSTANT_EXPRESSION_RESULT)
   "ocr > 65535U" is always false regardless of the values of its operands. This occurs as the logical operand of if.
319           if (ocr > 0xffff)
320           {
321             ocr = F_CPU / frequency / 2 / 64 - 1;
322             prescalarbits = 0b011;
323           }
324

________________________________________________________________________________________________________
*** CID 59631:  Missing break in switch  (MISSING_BREAK)
/Marlin_main.cpp: 1187 in process_commands()()
1181         case 2: // G2  - CW ARC
1182           if(Stopped == false) {
1183             get_arc_coordinates();
1184             prepare_arc_move(true);
1185             return;
1186           }
   CID 59631:  Missing break in switch  (MISSING_BREAK)
   The above case falls through to this one.
1187         case 3: // G3  - CCW ARC
1188           if(Stopped == false) {
1189             get_arc_coordinates();
1190             prepare_arc_move(false);
1191             return;
1192           }

________________________________________________________________________________________________________
*** CID 59632:  Missing break in switch  (MISSING_BREAK)
/Marlin_main.cpp: 1193 in process_commands()()
1187         case 3: // G3  - CCW ARC
1188           if(Stopped == false) {
1189             get_arc_coordinates();
1190             prepare_arc_move(false);
1191             return;
1192           }
   CID 59632:  Missing break in switch  (MISSING_BREAK)
   The above case falls through to this one.
1193         case 4: // G4 dwell
1194           LCD_MESSAGEPGM(MSG_DWELL);
1195           codenum = 0;
1196           if(code_seen('P')) codenum = code_value(); // milliseconds to wait
1197           if(code_seen('S')) codenum = code_value() * 1000; // seconds to wait
1198

________________________________________________________________________________________________________
*** CID 59633:  Out-of-bounds write  (OVERRUN)
/temperature.cpp: 914 in disable_heater()()
908          WRITE(HEATER_0_PIN,LOW);
909        #endif
910       #endif
911
912       #if defined(TEMP_1_PIN) && TEMP_1_PIN > -1
913         target_temperature[1]=0;
   CID 59633:  Out-of-bounds write  (OVERRUN)
   Overrunning array "soft_pwm" of 1 bytes at byte offset 1 using index "1".
914         soft_pwm[1]=0;
915         #if defined(HEATER_1_PIN) && HEATER_1_PIN > -1
916           WRITE(HEATER_1_PIN,LOW);
917         #endif
918       #endif
919

________________________________________________________________________________________________________
*** CID 59634:  Out-of-bounds write  (OVERRUN)
/temperature.cpp: 913 in disable_heater()()
907        #if defined(HEATER_0_PIN) && HEATER_0_PIN > -1
908          WRITE(HEATER_0_PIN,LOW);
909        #endif
910       #endif
911
912       #if defined(TEMP_1_PIN) && TEMP_1_PIN > -1
   CID 59634:  Out-of-bounds write  (OVERRUN)
   Overrunning array "target_temperature" of 1 2-byte elements at element index 1 (byte offset 2) using index "1".
913         target_temperature[1]=0;
914         soft_pwm[1]=0;
915         #if defined(HEATER_1_PIN) && HEATER_1_PIN > -1
916           WRITE(HEATER_1_PIN,LOW);
917         #endif
918       #endif

________________________________________________________________________________________________________
*** CID 59635:  Out-of-bounds read  (OVERRUN)
/temperature.cpp: 626 in analog2temp(int, unsigned char)()
620       if(heater_ttbl_map[e] != NULL)
621       {
622         float celsius = 0;
623         uint8_t i;
624         short (*tt)[][2] = (short (*)[][2])(heater_ttbl_map[e]);
625
   CID 59635:  Out-of-bounds read  (OVERRUN)
   Overrunning array "heater_ttbllen_map" of 1 bytes at byte offset 1 using index "e" (which evaluates to 1).
626         for (i=1; i<heater_ttbllen_map[e]; i++)
627         {
628           if (PGM_RD_W((*tt)[i][0]) > raw)
629           {
630             celsius = PGM_RD_W((*tt)[i-1][1]) +
631               (raw - PGM_RD_W((*tt)[i-1][0])) *

________________________________________________________________________________________________________
*** CID 59636:  Out-of-bounds read  (OVERRUN)
/temperature.cpp: 620 in analog2temp(int, unsigned char)()
614         if (e == 0)
615         {
616           return 0.25 * raw;
617         }
618       #endif
619
   CID 59636:  Out-of-bounds read  (OVERRUN)
   Overrunning array "heater_ttbl_map" of 1 2-byte elements at element index 1 (byte offset 2) using index "e" (which evaluates to 1).
620       if(heater_ttbl_map[e] != NULL)
621       {
622         float celsius = 0;
623         uint8_t i;
624         short (*tt)[][2] = (short (*)[][2])(heater_ttbl_map[e]);
625

________________________________________________________________________________________________________
*** CID 59637:  Out-of-bounds write  (OVERRUN)
/temperature.cpp: 202 in PID_autotune(float, int, int)()
196       {
197          soft_pwm_bed = (MAX_BED_POWER)/2;
198          bias = d = (MAX_BED_POWER)/2;
199        }
200        else
201        {
   CID 59637:  Out-of-bounds write  (OVERRUN)
   Overrunning array "soft_pwm" of 1 bytes at byte offset 1 using index "extruder" (which evaluates to 1).
202          soft_pwm[extruder] = (PID_MAX)/2;
203          bias = d = (PID_MAX)/2;
204       }
205
206
207

________________________________________________________________________________________________________
*** CID 59638:  Out-of-bounds read  (OVERRUN)
/temperature.cpp: 214 in PID_autotune(float, int, int)()
208
209      for(;;) {
210
211         if(temp_meas_ready == true) { // temp sample ready
212           updateTemperaturesFromRawValues();
213
   CID 59638:  Out-of-bounds read  (OVERRUN)
   Overrunning array "current_temperature" of 1 4-byte elements at element index 1 (byte offset 4) using index "extruder" (which evaluates to 1).
214           input = (extruder<0)?current_temperature_bed:current_temperature[extruder];
215
216           max=max(max,input);
217           min=min(min,input);
218           if(heating == true && input > temp) {
219             if(millis() - t2 > 5000) {

________________________________________________________________________________________________________
*** CID 59639:  Out-of-bounds write  (OVERRUN)
/Marlin_main.cpp: 2278 in process_commands()()
2272               tmp_extruder = code_value();
2273               if(tmp_extruder >= EXTRUDERS) {
2274                 SERIAL_ECHO_START;
2275                 SERIAL_ECHO(MSG_M200_INVALID_EXTRUDER);
2276               }
2277             }
   CID 59639:  Out-of-bounds write  (OVERRUN)
   Overrunning array "volumetric_multiplier" of 1 4-byte elements at element index 1 (byte offset 4) using index "tmp_extruder" (which evaluates to 1).
2278             volumetric_multiplier[tmp_extruder] = 1 / area;
2279           }
2280           break;
2281         case 201: // M201
2282           for(int8_t i=0; i < NUM_AXIS; i++)
2283           {

________________________________________________________________________________________________________
*** CID 59640:  Out-of-bounds read  (OVERRUN)
/Marlin_main.cpp: 1802 in process_commands()()
1796             int pin_status = code_value();
1797             int pin_number = LED_PIN;
1798             if (code_seen('P') && pin_status >= 0 && pin_status <= 255)
1799               pin_number = code_value();
1800             for(int8_t i = 0; i < (int8_t)sizeof(sensitive_pins); i++)
1801             {
   CID 59640:  Out-of-bounds read  (OVERRUN)
   Overrunning array "sensitive_pins" of 28 2-byte elements at element index 55 (byte offset 110) using index "i" (which evaluates to 55).
1802               if (sensitive_pins[i] == pin_number)
1803               {
1804                 pin_number = -1;
1805                 break;
1806               }
1807             }

________________________________________________________________________________________________________
*** CID 59641:  Uninitialized scalar field  (UNINIT_CTOR)
/Applications/Arduino.app/Contents/Resources/Java/libraries/LiquidCrystal/LiquidCrystal.cpp: 51 in LiquidCrystal::LiquidCrystal(unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char)()
45     }
46
47     LiquidCrystal::LiquidCrystal(uint8_t rs,  uint8_t enable,
48     			     uint8_t d0, uint8_t d1, uint8_t d2, uint8_t d3)
49     {
50       init(1, rs, 255, enable, d0, d1, d2, d3, 0, 0, 0, 0);
   CID 59641:  Uninitialized scalar field  (UNINIT_CTOR)
   Non-static class member "_initialized" is not initialized in this constructor nor in any functions that it calls.
51     }
52
53     void LiquidCrystal::init(uint8_t fourbitmode, uint8_t rs, uint8_t rw, uint8_t enable,
54     			 uint8_t d0, uint8_t d1, uint8_t d2, uint8_t d3,
55     			 uint8_t d4, uint8_t d5, uint8_t d6, uint8_t d7)
56     {

________________________________________________________________________________________________________
*** CID 59642:  Uninitialized scalar field  (UNINIT_CTOR)
/Applications/Arduino.app/Contents/Resources/Java/libraries/LiquidCrystal/LiquidCrystal.cpp: 45 in LiquidCrystal::LiquidCrystal(unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char)()
39     }
40
41     LiquidCrystal::LiquidCrystal(uint8_t rs, uint8_t rw, uint8_t enable,
42     			     uint8_t d0, uint8_t d1, uint8_t d2, uint8_t d3)
43     {
44       init(1, rs, rw, enable, d0, d1, d2, d3, 0, 0, 0, 0);
   CID 59642:  Uninitialized scalar field  (UNINIT_CTOR)
   Non-static class member "_initialized" is not initialized in this constructor nor in any functions that it calls.
45     }
46
47     LiquidCrystal::LiquidCrystal(uint8_t rs,  uint8_t enable,
48     			     uint8_t d0, uint8_t d1, uint8_t d2, uint8_t d3)
49     {
50       init(1, rs, 255, enable, d0, d1, d2, d3, 0, 0, 0, 0);

________________________________________________________________________________________________________
*** CID 59643:  Uninitialized scalar field  (UNINIT_CTOR)
/Applications/Arduino.app/Contents/Resources/Java/libraries/LiquidCrystal/LiquidCrystal.cpp: 32 in LiquidCrystal::LiquidCrystal(unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char)()
26
27     LiquidCrystal::LiquidCrystal(uint8_t rs, uint8_t rw, uint8_t enable,
28     			     uint8_t d0, uint8_t d1, uint8_t d2, uint8_t d3,
29     			     uint8_t d4, uint8_t d5, uint8_t d6, uint8_t d7)
30     {
31       init(0, rs, rw, enable, d0, d1, d2, d3, d4, d5, d6, d7);
   CID 59643:  Uninitialized scalar field  (UNINIT_CTOR)
   Non-static class member "_initialized" is not initialized in this constructor nor in any functions that it calls.
32     }
33
34     LiquidCrystal::LiquidCrystal(uint8_t rs, uint8_t enable,
35     			     uint8_t d0, uint8_t d1, uint8_t d2, uint8_t d3,
36     			     uint8_t d4, uint8_t d5, uint8_t d6, uint8_t d7)
37     {

________________________________________________________________________________________________________
To view the defects in Coverity Scan visit, http://scan.coverity.com/projects/2224?tab=overview
Neil Darlow e541323741 Merge https://github.com/ErikZalm/Marlin into Marlin_v1
Alejandro Romero 1c9a70cee9 Support for Gen3 Monolithic electronics
Techzone Monotronics support, ignoring the tip manager and using fan connector as on Sprinter FW
TODO: Add support for tipmanager
daid 2acd3792fc Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
daid 8b4c4aa5c3 Add feature to check&retry CRC read errors on SD.
nothinman ce76843dc3 Merge pull request from Makible/5DPrint_D8_Board_Support
5DPrint D8 Controller Board Support
Cameron Lai ad5c8cbba9 Add safety limit for hot bed power in example configuration
Cameron Lai 6460709d92 Fix bug in PID Autotune report
Cameron Lai 105bebb466 Fix for pin mapping for SDSS pin and Fan pin, so Arduino library can be used
Cameron Lai 97ead2eccb Fix for microstepping pin mapping, not using Teensy pin mapping, but Arduino's default pin mapping so Arduino library can be used
Cameron Lai d85411f13a Revert "Fix for stepper microstepping"
This reverts commit eea3ba5588.
Cameron Lai 7c7f2d094e Revert "Fix for reading microstepping resolution"
This reverts commit 2715f6ddbf.
Cameron Lai e2d703377a Enable EEPROM by default for 5DPrint D8 Controller Board in example configuration
Cameron Lai 2715f6ddbf Fix for reading microstepping resolution
Cameron Lai 39e9b133f3 Add example configuration for Makibox printer, which uses the 5DPrint D8 Driver Board
Cameron Lai da6b536182 Add 5DPrint D8 Driver Board info and temperature table for Makibox hot bed
Cameron Lai 3a8e36f19e Add Digipot config for 5DPrint D8 Driver Board
Cameron Lai eea3ba5588 Fix for stepper microstepping
Cameron Lai 1cbcbb0971 Add makibox machine information
Cameron Lai 2fa514e88a Add port for 5DPrint D8 Driver board
nothinman b9126ab497 Merge pull request from MyMakibox/Marlin_v1
Update Marlin_main.cpp
MyMakibox 21ec6b88c3 Update Marlin_main.cpp
Added description of autotemp flags to M109
MyMakibox e4dc80d3d3 Update Configuration_adv.h
Corrected error in AUTOTEMP instructions
Neil Darlow 6adbdf42e0 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
whosawhatsis 27d544ac25 Speed up QUICK_HOME feedrate for diagonal move
Speed up the diagonal move while still keeping each individual axis at
or below its homing feedrate.
nothinman 013793bbe9 Merge pull request from koldoartola/Marlin_v1
Added new language (Basque-Euskera)
koldo artola e5b70237c7 Added new language (Basque-Euskera)
Added:
* new language (Basque-Euskera)
* some minor corrections for Spanish
* added 2 new constants for every language (required for a minor change
I am preparing to ultralcd.cpp)
Nutz95 ed6f4a71c5 fix wrong temptable index
Nutz95 3161740df9 This table is made for thermistor 3950 (can be found on ebay for cheap)
it's caracteristics are :

R25℃ ;100KΩ±1%

B Value(R25/50℃):3990K 1%
Dissipation Factor(mW/℃):1.1~1.6 In still Air
Thermal Time Constant(S):10~17 In Still Air
Operating temperature range:  (-50~+260°C)
Dimension:  1.8mm Dia X4.1mm
Lead Length  :30mm

This table was found on the following blogs:
http://cae2100.wordpress.com/2014/03/08/beta3950-thermistor-table-for-marlin/

and

http://microfabricator.com/articles/view/id/531ad7e59aad9d3131000000/beta-3950-thermistor-table-for-marlin
nothinman 086ff1644f Merge pull request from pixatintes/patch-1
Update language.h
nothinman 3ffc9651b1 Merge pull request from DerSchultze/Sanguinololu-servo
Added servo pin assignments to Sanguinololu
nothinman 357b87b498 Merge pull request from paciotti/patch-1
Configuration_adv.h
neildarlow 95ad6ec9a1 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Gabe Rosenhouse 27a7cf9fcf use existing strings
Gabe Rosenhouse d3f305332a Allowable range now includes default value
Gabe Rosenhouse b0aeac117f Adjustable Z probe offset, via custom M-code
Neil Darlow 73b380d8d2 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
nothinman c23376f2e7 Merge pull request from whosawhatsis/fwretract
FWRETRACT in mm/s
nothinman dfb98101e4 Change CONTROLLERFAN_PIN for board 35 to -1, as it would conflict with board's 33 extruder pin, causing burnout (it's the same board, just different number of fans/extruders, therefore should be pin-compatible)
nothinman f1501317ca Merge pull request from drf5n/therm3950
thermistortables.h: Add comments that table 60 uses beta=3950.
nothinman 9a5d23d96f Merge pull request from sakunamary/Marlin_v1
fix bug for dual extruders not working
nothinman 303ee67896 Merge pull request from whosawhatsis/M200
fix bug in M200 with multiple extruders
Tim 8759508319 fix bug for dual extruders not working
some guy find that marlin not working good for dual extruders delta .
when type T0 or T1 to active extruder and  E0 or E1  move causing XYZ
motion . so i locales the bugs and fix it , I have dry run the fix.
whosawhatsis a65564eef6 fix bug in M200 with multiple extruders
whosawhatsis aeaf9b9312 fix bug in M200 with multiple extruders
Neil Darlow 89f78b0b80 Allow use of either SD Card slot when LCD Panel is configured.
Preference is for Controller SD slot before LCD Panel slot when both are occupied.
David Forrest b0093a1513 thermistortables.h: Add comments that table 60 uses beta=3950.
pixatintes a3530d1141 Update language.h
Updated to latest version.
pixatintes 990e770e15 Update language.h
Added catalan language
Dan Nixon f643f4d674 Test and refactor
neildarlow bbe8fbe13d Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Dim3nsioneer c8cdd1fc6f Bugfixes for language option 6 (russian)
Dim3nsioneer 7395dafc1e semantic changes in language.h
Dim3nsioneer fad2a60ce6 Corrections for preheat extension in language.h
Ralf Schultz eecda434fb Sanguinololu servo pins set default disabled
Dim3nsioneer 944ced87c5 Extended Preheat options
Preheat LCD menus base on code by D-Base
Ralf Schultz 06709ad60e Added servo pin assignments to Sanguinololu
Dim3nsioneer 3906f27c46 Individual extruder flow rate
Extension of M221, Tune menu
Dan Nixon a38c90ee84 Added estop handling
ErikZalm a00cec8b71 Merge pull request from mattsch/optional_feedrate_multiplier
Add support for disabling encoder control for feedrate multiplier
neildarlow af8be9013b Merge branch 'lcd_detected' of https://github.com/whosawhatsis/Marlin into Marlin_v1
whosawhatsis 0ddee3c7db Prevent SD card insertion from causing a hang when using LiquidTWI2 device detection
Dan Nixon 272072fa20 Added M112
whosawhatsis aab61e63c3 FWRETRACT in mm/s
Firmware retraction now stores the retract and recover speeds in mm/s
instead of mm/min. This makes it match the units of the maximum
feedrate, and fixes problems with modifying the value via LCD control
panel. From gcode, the values are still taken in mm/min to match the
units of G1 and similar, and they are converted to mm/s before they are
stored.

I also lowered the default retract feedrate to make it less likely to
cause problems for geared extruders when the user hasn’t bothered to
set a reasonable maximum feedrate, though users should be setting both
of these values to suit their hardware.
Matthew Schick 6cd85e6008 Add support for disabling encoder control for feedrate multiplier
Signed-off-by: Matthew Schick <matthew.schick@gmail.com>
blddk 09af1b90b8 Added CHDK support
Added CHDK support to take pictures instead of doing an IR command, see more about how to use it here http://captain-slow.dk/2014/03/09/3d-printing-timelapses/
blddk 765b2da3d4 Added CHDK support
Added so M240 can be used to trigger CHDK instead of sending an IR signal, see more about CHDK here http://captain-slow.dk/2014/03/09/3d-printing-timelapses/
paciotti 881e348eed Update Configuration_adv.h
Increase Z_HOME_RETRACT_MM to 2mm default to avoid end stop not switching during retract.
neildarlow 5a332df47e Merge https://github.com/ErikZalm/Marlin into Marlin_v1
Tommi Lamberg 15d1b8d719 Fixed finnish translation
- Fixed Few finnish transalations
- Removed duplicate contrast define
neildarlow 7325d7102e Activate LiquidTWI2 device detection and space-pad LCD status line.
ErikZalm 7f76a0e064 Merge pull request from drf5n/PID_DEBUG
temperature.cpp: Fix PID_DEBUG compile error.
Erik van der Zalm fcd8524b6e Only increase EEPROM version for DELTA printers.
Jim Morris 8ea5665ee2 Merge remote-tracking branch 'origin/Marlin_v1' into add/M665-set-delta-configuration
Conflicts:
	Marlin/Marlin_main.cpp
David Forrest 8c4377dd63 temperature.cpp: Fix PID_DEBUG compile error.
ErikZalm fde8c2c310 Merge pull request from Cylindric3D/typofixes_upstream5
Various typo fixes  - only in comments, no code changes.
Cylindric fdce91192e Various typo fixes - only in comments, no code changes.
Cylindric d819c55395 Various typo fixes - only in comments, no code changes.
ErikZalm fd4542f33a Merge pull request from whosawhatsis/M200
autretract fix
ErikZalm e8291ed728 Merge pull request from Makers-Tool-Works/Marlin_v1
Clarify which PID values to enter
ErikZalm 465b654d24 Merge pull request from Cylindric3D/update_menu_plan
Update menu plan
ErikZalm 88506a80c3 Merge pull request from smiler/Marlin_v1
Fixed typo.
ErikZalm b514d3c87f Merge pull request from Cylindric3D/typofixes_upstream
Various typo fixes  - only in comments, no code changes.
whosawhatsis 77df0d689a autretract fix
I made these changes previously, but I can’t find the commit now. This
reapplies the changes to get auto retract working again.

Conflicts:
	Marlin/Configuration_adv.h
	Marlin/Marlin_main.cpp
ErikZalm cc5f1d475c Merge pull request from ellensp/Marlin_v1
Updated gen3+ board pins names to current convention
Cylindric 91759dede6 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into typofixes_upstream
Cylindric 557217fc05 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into update_menu_plan
RoyOnWheels aee63afccd Clarify which PID values to enter
Users can be confused as to which values to enter after a PID tune. Updating the message to help clarity it.
New message: "PID Autotune finished! Put the last Kp, Ki and Kd constants from above into Configuration.h"

Old message: "PID Autotune finished! Put the Kp, Ki and Kd constants into Configuration.h"
Gabe Rosenhouse 99f6326544 Remove unnecessary dependency on time.h from qr_solve.cpp
Fixed compiler errors on Ubuntu using arduino-core
Cylindric ea669cb504 Fix some extra and some missing tabs, to make the file consistent.
Cylindric b46a1b6360 Update the menu plan document with the current menu as per ultralcd.cpp.
Cylindric 3cc7626d1f Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into update_menu_plan
Gabe Rosenhouse 174b8d99d5 Simplify 3-point probing using new code only
Gabe Rosenhouse 3b718b816c better documentation
Gabe Rosenhouse 34fd59c370 ABL at any points
Cylindric 541155ea87 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into typofixes_upstream
alexborro 9fa328e5c8 Merge pull request from MissionSt/use_axis_enums
Use constants instead of numeric literals
Gabe Rosenhouse f308a8af91 update comment
Gabe Rosenhouse 357e31270a Prevent G29 without first homing in X and Y
If position is unknown, then G29 can be dangerous.
Gabe Rosenhouse d2d7d186b5 Use descriptive constants, more
Gabe Rosenhouse 2ccdf4f36d Use descriptive constants instead of numeric literals
Christian Axelsson c00383f286 Fixed typo.
Cylindric 60f72a78a9 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into typofixes_upstream
nothinman abba7a0003 Merge pull request from marcovannoord/Marlin_v1
Added dutch to language.h
Cylindric b868d668fa Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into typofixes_upstream
Marco 8212d8d543 Revert "Fixed small typo that would prevent compiling"
This reverts commit 51ae4881ab.
daid 46bae30573 Merge pull request from whosawhatsis/fwretract
Fwretract fixes, cleanup
Marco 51ae4881ab Fixed small typo that would prevent compiling
Marco 498d76fd79 Fixed some messages where the text shown on the screen was more than 17 characters
Jim Morris af9395ac2e Add M605 to dynamically set delta configuration
Save above configs in eeprom
fix docs in createTemperatureLookupMarlin.py
add missing azteegX3pro digipot settings in delta example config
nothinman fd42f0d226 Merge pull request from MissionSt/fix/syntax-error
Fix compile error
nothinman 96217bf36a Merge pull request from PxT/M114
Add whitespace to M114 output
Marco cf5c3b6610 Added dutch to language.h
Gabe Rosenhouse d1c64b9dc4 Fix syntax error introduced in 477b6fa1d
Cylindric 5d50819791 Various typo fixes - only in comments, no code changes.
nothinman 3f455889d0 Merge pull request from Cylindric3D/typofixes_1
Various typo fixes - only in comments, no code changes.
nothinman 4ddedb3b27 Merge pull request from Cylindric3D/typofixes_2
Various typo fixes  - only in comments, no code changes.
nothinman d4ba23bc28 Merge pull request from josefpavlik/Marlin_v1
Marlin v1
nothinman bbb424bd2f Merge pull request from MissionSt/makefile-fix-abl
Makefile fixes
Cylindric 8f0cee2a14 Various typo fixes - only in comments, no code changes.
Cylindric 08263ae66e Merge branch 'Marlin_v1' into typofixes_1
Gabe Rosenhouse 5bd09d26e2 Makefile works with auto bed leveling
Gabe Rosenhouse b45beeffd6 typo fix in Makefile
Paul Telford 306588925d Add whitespace to M114 output
whosawhatsis c43838bb1e disable auto retract by default
This should make it safe to enable FWRETRACT by default, with
autoretract (which should now be fixed) only enabled by M209. FWRETRACT
should probably now default to enabled (to make G10/G11 and M207-209
available, without changing functionality when they are not used), but
I’ll save that for another pull request/discussion.
whosawhatsis 99f0e44864 Move FWRETRACT defaults to configuration_adv.h
whosawhatsis 66e3869138 Fix autoretract
This takes the (now working) G10/G11 code and moves it to a function,
which is called by G10 and G11, and also called by G1 if autoretract is
enabled and a retract/recover move is detected.
whosawhatsis 2f2459c0db Fix G10/G11 Z-lift
Gabe Rosenhouse 8c5675c290 Use language.h instead of English literals for "bed"
Gabe Rosenhouse 0f7393a13e Refactor 'accurate' auto bed leveling to use probe_pt()
Gabe Rosenhouse c4fbb44d6d Refactor 3-point auto bed leveling to use probe_pt()
Gabe Rosenhouse ad2c6488c7 Add probe_pt(), useful for auto bed leveling
Peter c9c83a4560 Updated gen3+ board pins names to current convention
Mark Hanford ab0d3c4fb3 Various typo fixes - only in comments, no code changes.
Josef Pavlik 477b6fa1df move engaged from lcd console refreshes power off timeout
Josef Pavlik 831fc2a952 Pt100 and Pt1000 temperature sensors handling
nothinman 7dcd350941 A few changes to Russian, changed LCD strings to be <=17 characters.
daid c31bb2b7ad Only show the ZProbe offset when auto-bed-leveling is enabled.
daid 46f5bea19f Add configurable beep for UltiPanel.
daid d16a770855 Ultimainboard 2.x does not has a PS_ON pin.
daid 71bb3a8133 Add comments for Ultimainboard 2.0 configuration.
daid 9b7d87e885 Remove duplicate contrast define.
daid 816f0a678a Merge pull request from whosawhatsis/Marlin_v1
multiple FWretract fixes
whosawhatsis 6e43398509 G10/G11 bugfixes
Previous version was broken by using G92 E0 between retract and recover.
whosawhatsis d6c5c503d4 correct feedrate units in comments for M207/M208
nothinman 15d6116188 Merge pull request from cajun-rat/tidy
Use C++ initialization list
Martin Lukasik 0b9ecf3824 Language cleanup, part 1.
whosawhatsis b5ba5c1465 Merge branch 'Marlin_v1' of https://github.com/whosawhatsis/Marlin into Marlin_v1
whosawhatsis 78e7654601 Keep FWRETRACT values in terms of millimeters when using M200
for volumetric E units
whosawhatsis 3f6d44d40b Keep FWRETRACT values in terms of millimeters when using M200 for volumetric E units
Cylindric 363dc2f0e8 Merge branch 'Marlin_v1' into update_menu_plan
nothinman 5f797ca29f Updated Polish, changed default firmware URL to Marlin.
Mark Hanford 0778f5f028 Add missing entries to the new Aragonian language.
Mark Hanford 54bab3e0d0 Merge branch 'Marlin_v1' into localisation
Conflicts:
	Marlin/language.h
Mark Hanford bdd0211aeb Move strings in ultralcd.cpp into language.h.
Daniel Martinez c8e5a82d49 keep English as default lang.
Daniel Martinez f64592e362 Add Aragonese translation
ErikZalm ac74f45dc0 Merge pull request from MatixYo/patch-3
Update language.h
MatixYo 36086d3ca4 Update language.h
Updated Polish translations.
Cylindric 1781031f2d Update LCD Menu Tree with current options, based on ultralcd.cpp and language.h.
Jim Morris d485988bec fix typo
Jim Morris 8a1fd25363 Default is to not define digipot_i2c
Jim Morris 5097c57d3a Added pins for Azteeg X3 Pro under motherboard 68
Jim Morris b819fc53ca Add Azteeg X3 Pro as motherboard 68
Add digipot i2c control for MCP4451
Allow M907 to set i2c digipot currents in amps
Fix Makefile to allow Azteeg motherboards
Fix Makefile to allow Wire libraries only
Add beeper pin for Azteeg X3 Pro
ErikZalm e1ae7952eb Merge pull request from Opticalworm/Marlin_v1
Improved support for panelolu2 encoder and buzzer
David Forrest a5f53f0cf3 Heater wattage reporting for M105 using EXTRUDER_WATTS and BED_WATTS
Ronald 8d162e5bd7 Improved support for panelolu2 encoder and buzzer
I added #define for LCD_FEEDBACK_FREQUENCY_HZ and
LCD_FEEDBACK_FREQUENCY_DURATION_MS  which is used to alter the default
buzzer sound.

When selecting Panelolu2 in configuration.h:
- it automatically sets the correct ENCODER_PULSES_PER_STEP and
ENCODER_STEPS_PER_MENU_ITEM.
- if LCD_USE_I2C_BUZZER is defined it will also set the default
LCD_FEEDBACK_FREQUENCY_HZ and LCD_FEEDBACK_FREQUENCY_DURATION_MS

When selecting the sanguinololu 1284p the following is true:
- its now enables  LARGE_FLASH
- It enables the gcode M300 when the panelolu2 LCD_USE_I2C_BUZZER is
defined
whosawhatsis b2c11ba980 Change diameter code to 'D'
For some reason that I can’t figure out, the decimal is dropped when
using ’S’ for the code.

Also some minor code improvements to M200.
ErikZalm 61059385a3 Merge pull request from whosawhatsis/M200
M200 implementation
whosawhatsis 856edfcc0d Fixed math
This is why I wanted to sleep on the code I wrote while falling asleep
rather than immediately submitting a pull request.
ErikZalm 0d81ae77bc Merge pull request from drf5n/oversampling
temperature.cpp: Actually use OVERSAMPLENR in the oversampling calculation.
ErikZalm 84df13f7d1 Merge pull request from drf5n/lcdOnly
Enable basic ULTRA_LCD screen w/o encoders and menus.
ErikZalm 4c7e9502ad Merge pull request from drf5n/temptableRes
createTemperatureLookupMarlin.py: Add resolution comments and format for...
ErikZalm 652a0f6b5a Merge pull request from drf5n/tpins2
fastio.h: Add AT90USBxx_TEENSYPP_ASSIGNMENTS for teensyduino/Lincomatic/...
ErikZalm 96a0cdc541 Merge pull request from drf5n/maketeensy
Makefile: Update for Arduino 1.0.5 and Teensyduino dependent boards (HAR...
whosawhatsis d24df7af2c M200 implementation
David Forrest f0b8d5ba3d createTemperatureLookupMarlin.py: Change comment to refer to actual program name.
David Forrest 50f44d9249 createTemperatureLookupMarlin.py: Truncate to short after application of OVERSAMPLENR for improved resolution.
David Forrest f5b5dd8038 createTemperatureLookupMarlin.py: Add output of Steinhart-Hart coefficients.
David Forrest 76cf07c3f7 Configuration.h: Use OVERSAMPLENR in dT_PID definition.
David Forrest 476c7193d8 temperature.cpp: Use OVERSAMPLENR in oversampling calculation.
whosawhatsis f08bb8bb6a Previous commit borked.
whosawhatsis b1f8f492c6 Remove previous_millis_cmd update from extruder runout prevention code
This seems to defeat the purpose of previous_millis_cmd, preventing the
time elapsed from previous_millis_cmd from ever reaching
max_inactive_time or stepper_inactive_time while the heat was on.
whosawhatsis 8a5eaa3c9b Fix crash after home bug
Fixes a bug in the Extruder Runout Prevention feature that caused the
extruder to move back to “current_position” after a move if it was
activated while the move was in progress. For long home moves (which
are longer than the dimensions of the machine’s working area), this
would cause the machine to crash into the far end of its travel after
homing. This usually occurred on the Z axis, which could result in
damage to the machine if you don’t hit the reset button in time.
David Forrest 61a7256d42 Enable basic ULTRA_LCD screen w/o encoders and menus.
l.lefebvre fdac8f6cec Update ConfigurationStore.cpp
Unable to compile if ENABLE_AUTO_BED_LEVELING is not set (not set by default).
Alex Borro 05932e4458 Add Z Probe Offset to EEPROM and Ultra LCD
David Forrest 7216583b8b createTemperatureLookupMarlin.py: Add resolution comments and format for Marlin.
David Forrest e8e0697e48 fastio.h: Add AT90USBxx_TEENSYPP_ASSIGNMENTS for teensyduino/Lincomatic/Printrboard compatibility.
David Forrest 75f39fadfc Makefile: Update for Arduino 1.0.5 and Teensyduino dependent boards (HARDWARE_MOTHERBOARD=={8,81,82,83,84})
daid df194f75e1 Added PT100 support for Ultiboard2
daid 380144c20f Add Ultiboard2 electronics. With PWM current settings. For the few people that have this new board as experiment in their UM-Original.
fsantini 6ae7f7870d Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into ErikZalm
Conflicts:
	Marlin/Configuration.h
	Marlin/Marlin_main.cpp
Phil Wise 17d6d965dc Use C++ initialization list
This is the recommended approach for object initialization. The change
doesn't affect binary size (although in theory it could make it smaller).
Joseivaldo Benito Junior ce8b9c4fc5 Correct missing parameter from last upmerge
Signed-off-by: Joseivaldo Benito Junior <jrbenito@benito.qsl.br>
Joseivaldo Benito Junior 8e48e24c7f Update Delta example files
Signed-off-by: Joseivaldo Benito Junior <jrbenito@benito.qsl.br>
ErikZalm 46d2443c7d Merge pull request from IVI053/Marlin_v1
Minor improvements for encoder configuration, LCD entry for PSU controll and thermistor pins on RAMPS
- eed053dffb Revert "Made numbering of heat bed thermistor more logical as D8 is bed, D9 is Extruder 2 and D10 is Extruder 1, so T0 should be E1, T1 E1 and T2 bed to be sequential as MOSFET-Outputs"
This reverts commit b7eadb9f37.
Erik van der Zalm 8349fc89a4 Fixed planner bug
Francesco Santini da2a6f9a31 Accurate bed leveling: x loop inside y and zigzag motion
RicardoGA d29615dc0c Z and Y dual stepper drivers error
if you try to enable Z_DUAL_STEPPER_DRIVERS the error "You cannot have dual drivers for both Y and Z" shows even if you don't have defined Y_DUAL_STEPPER_DRIVERS and don't let you compile the firmware

to solve this problem i change this line:

#ifdef Z_DUAL_STEPPER_DRIVERS && Y_DUAL_STEPPER_DRIVERS

to:

#if defined (Z_DUAL_STEPPER_DRIVERS) && defined (Y_DUAL_STEPPER_DRIVERS)

now the error only show if you define both Z_DUAL_STEPPER_DRIVERS and Y_DUAL_STEPPER_DRIVERS
fsantini 5bde7fcb28 Minor code and comment polishing
- 20faff5935 Incorporate PS_DEFAULT_OFF for starting state on LCD menu entry
- e5d3044801 Added posibility to set ENCODER_STEPS_PER_MENU_ITEM in Configuration.h like ENCODER_PULSES_PER_STEP as it depends on it for usability
- b7eadb9f37 Made numbering of heat bed thermistor more logical as D8 is bed, D9 is Extruder 2 and D10 is Extruder 1, so T0 should be E1, T1 E1 and T2 bed to be sequential as MOSFET-Outputs
Michal Dyntar e8786bf110 Added support for Cheaptronic v1 electronic
fsantini cc2925b705 Implemented a least squares fit of the bed equation for auto bed leveling.
The code for the LSQ solver (qr_solve) is copyrighted by John Burkardt and released under LGPL here:
http://people.sc.fsu.edu/~%20jburkardt/c_src/qr_solve/qr_solve.html
(see qr_solve.cpp for further copyright information)
fsantini b64661070e Fixed the plane vector equation to a simpler one (only dependent on the normal)
Removed the calculation of the inverse matrix since the rotation matrix is orthogonal, therefore inverted == transposed.
Much simpler and mathematically robust.
Alex Borro 5c44f6c434 Bed Heater monitoring in Controller Fan
In some cases the Bed Heater FET heats up more then stepper drivers, so
this change add the bed monitoring to the controller fan. As soon as the
bed heater is turned on, the controller fan will run as well.
Alex Borro b33375d438 Z Axis Safe Homing when using Z Probe
Recommended for those who are using the Z Probe for Z Homing (as
Z-Endstop)

This feature has two changes:

1) Allow user to choose where the Z Probe will touch the bed when homing
all axis together (G28) by setting below defines:

Z_SAFE_HOMING_X_POINT
Z_SAFE_HOMING_Y_POINT

2) Prevents the user to perform Z Axis Homing when the Z Probe is
outsite bed.
Alex Borro 35905ea4f9 Allow heaters to stay full On when PWM=127
In previous version, even with PWM = 127, the system turns the FET off
and then on in the next cycle. This bevavior may increase the FET heat
dissipation.
It was fixed keeping the FET always On when PWM=127.
Erik van der Zalm a94e588765 Changed slow buttons behavior.
Erik van der Zalm 69af392554 Added HEATERS_PARALLEL (Request from reifsnyderb)
This allows a hot end with two heaters and a FET for each heater. This is useful if the FET is not capable of heating two heaters.
Erik van der Zalm 48a185d004 Fixed compile errors from bad commits.
ErikZalm 24d1f480b6 Merge pull request from shaggythesheep/newfeature-M226
Implement M226 - GCode Initiated Pause
ErikZalm 95b41413e6 Merge pull request from hugokernel/master
M80 - ATX Power On related modification
ErikZalm 59b96e323e Merge pull request from fmalpartida/SAV-MkI
Added support for BT on AT90USB devices, corrected LCD bug, added new board and LCD
ErikZalm 2433ee6fc8 Merge pull request from justuswilhelm/Marlin_v1
Fix servo control for Melzi v2.0
ErikZalm 3455a2bac2 Merge pull request from PrintToPeer/Marlin_v1
Add UUID support to M115 responses.
Richard Miles dc887ef99b Implement M226 - GCode Initiated Pause
Implemented M226 as described here:
http://reprap.org/wiki/G-code#M226:_Gcode_Initiated_Pause

Waits for pin to be become either HIGH, LOW or the inverse of what it
was before. Allows printing to pause until user interaction
Charles R c244eb860c If you have a switch on suicide pin, this is useful if you want to
start another print with suicide feature after a print without
suicide...
fmalpartida 7b556d2e96 Added BT support on AT90USB devices
Added AT90USB device BT connectivity support using second UART.
Kaz Walker a5e8575829 Add UUID support to M115 responses.
Daniel Benamy cab84e0e5b Add (correct) missing pin definitions for Y2
I tested this and it works.
fmalpartida 5b3f60ea2e Corrected LCD only error
If only an LCD is defined and no menu or keyboard defined, there is a
compilation error.

Added conditional compilation.
Justus Perlwitz 62d0b79023 Fix servo control for Melzi
fmalpartida b5a964fcc5 Initial SAV MkI (RepRap CloneWars board) integration.
Included support for BT dongle on AT90USB boards.
Added LCD Shift Register LCD control
Included support for RepRap Clone Wars project board (SAV MKI).
dumle29 f941203172 PS_ON configurable boot state
Allows the user to select wheter or not the PSU should be turned on or
kept in standby when marlin boots
whosawhatsis c79e3967b3 Make G11 not horribly broken
bkubicek d69822ed51 Fix '#'
since it can occure in comments.
bkubicek 2fb2a0a119 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
bkubicek 39d88bcccb preparation for hibernation
If a print is stopped, it would be nice in the future to write a file with the printer state, the filename of the print, and the position within the print.
this file could be read, to continue a previously stopped print.
not finished yet.
bkubicek ab965376ff Sub-file calls.
by overloading M32 it is now possible to execute gcode files from other gcode files, with a fixed recursion level.
This can be used e.g. for having a real start.g and end.g somewhere on the sd card, which are then called from the normal print file.
Another usecase would be to have macro-files for nozzle-change and layerchange.
I have not tested the speedwise performance. The testing was done with pronterface.

syntax:
normal call from sd card will open the new file and continue executing there.
M32 !/path/filename#
this however will call the new file and return to the caller file.
M32 P !/path/filename#
with the optional "S<position>" the  file starting position can be set.
this is for continuing prints from a previous location.
bkubicek b2cc27e5ea Added a magic character for sd buffering.
if a '#' is read now the buffer will be emptied before reading ahead.
This is so one can execute files from within gcode files, without messing the buffer with preread characters from the caller file.
# can not occure in sd files imho, because it should only occure within checksums in ther serial communication.
Yes, thats a lame argument. If you have a better idea please tell me. It has to be a character that one can type
on a keyboard manually.
Erik van der Zalm 8a08cca0f2 Added temperature status less.
Hopefully fixed viky button handling without braking other boards
Erik van der Zalm 667d278f54 Revert "Fix for Viki display"
This reverts commit 314fd13c39.
Erik van der Zalm bf27e79e74 Small BlinkM fix
Erik van der Zalm 87e28c0599 Added ifdefs to blinkm
Erik van der Zalm 24c6b2ab35 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
ErikZalm 6a803ba9c5 Merge pull request from timkoster/Marlin_v1
Added BlinkM support over i2c
Erik van der Zalm 457d8a0acb Fixed merge conflicts
Alex Borro 6f85a8c7aa Bed auto Leveling change: Raise Z before homing
- Added "Z_RAISE_BEFORE_HOMING" for raising Z the defined distance
before homing. This is useful to avoid Z-Probe collision when hotend is
near bed.

- Fixed the issue of Z not going bellow Z_PROBE_OFFSET when
"min_software_endstops" is true.
Now the Z_PROBE_OFFSET is not set in Z_MIN_POS, it is added after
homing.
Alex Borro dd3086d3f2 Show Temperature ADC values
If "SHOW_TEMP_ADC_VALUES" is defined in Configuration_adv.h, the M105
command will present, after tradicional temperatures, the ADC value read
from temp sensors. This is great for adjusting thermistor tables with
thermocouple.

From Pronterface you can see the ADC value and compare with a
thermocouple reading.. then you just need to create your own thermistor
table.

Since this merge doesnt change the original information, it doesnt mess
with PC software parsing (tested under Pronterface and Repetier-Host).
bkubicek 7fad13a1e2 Reverse SD card file name order.
This is _not_ automatically the cronological, since deleting a file will free
the filesystem descriptor for it, which then will be used by the next file copied on it.
Since this makes the auto0.g file very inaccessible, I put the option back, to have it in the prepare menu.

this should satisfy https://github.com/ErikZalm/Marlin/pull/373

as a reminder, auto0.g will be executed every time after a boot with sd card present and file present.
thereafter, if there is a file auto1.g this will be done. Thats IMHO the best place to put settings, and prepare heating.
I also execute again after each (now again via the prepare menu) before starting a new print/ after a failed one.
It for me 100% replaces any start.gcode form the slicers.
bkubicek b832f5b9f6 added delta tower babystepping. Its untested, but hopefully florian horsch will be able to try.
also, removed some trouble for compilation with corexy.
I think that babystepping is only possible in z for a delta tower.
not sure if it would be usefull to step individual motors on a delta, i don't own one
bkubicek c38b0855c8 I think that filament change is ready for the masses. I have tested very often with my ultimaker.
I strongly vote for it being a single gcode, because otherwise the triggering from the menu is terrible.
bkubicek d147a057ac Add the socalled "Babystepping" feature.
It is a realtime control over the head position via the LCD menu system that works _while_ printing.
Using it, one can e.g. tune the z-position in realtime, while printing the first layer.
Also, lost steps can be manually added/removed, but thats not the prime feature.
Stuff is placed into the Tune->Babystep *

It is not possible to have realtime control via gcode sending due to the buffering, so I did not include a gcode yet. However, it could be added, but it movements will not be realtime then.

Historically, a very similar thing was implemented for the "Kaamermaker" project, while Joris was babysitting his offspring, hence the name.

say goodby to fuddling around with the z-axis.
Erik van der Zalm bca353cc12 Fixed duplicate define in fastio.h
Alex Borro 253dfc4bc1 Bed Auto Leveling feature
Check the Readme for instruction how to enable and configure the feature
ErikZalm 1bda6bf862 Merge pull request from phq1910/patch-1
Update Configuration.h
ErikZalm c80aac1518 Merge pull request from phq1910/patch-2
Update pins.h
Erik van der Zalm 314fd13c39 Fix for Viki display
phq1910 4f7c6dfe35 Update pins.h
Include Pins cpu Sethi 3D
phq1910 57173739a1 Update Configuration.h
Include CPU Sethi 3D
Erik van der Zalm 0dca49a7c0 Added Azteeg X3 board.
Erik van der Zalm d8c2c810b4 Added info to the delta configuration files in the configuration.h file
Erik van der Zalm 9bc88f8bab Placed optional ENCODER_PULSES_PER_STEP in the configuration.h file
Erik van der Zalm 3ca1ca6869 Fixed missing ENCODER_PULSES_PER_STEP
Tim Koster 97b0da0c2e Removed #ifndef BLINKM
Tim Koster 61db046b32 Added #ifdef BLINKM around new code. Also refined BlinkM.h.
Richard Miles 77df2ab0e7 Make Y_DUAL_STEPPER_DRIVERS disabled by default
Richard Miles ed1ab42186 Added Y_DUAL_STEPPER_DRIVERS
Enables two stepper drivers to be used for the Y axis (useful for
Shapeoko style machines)
Each Y driver can be stepped in either the same way or in opposite
directions, accounting for different hardware setups (leadscrew vs. belt
driven)
Richard Miles f4a59e4ce5 Revert "Added Y_DUAL_STEPPER_DRIVERS"
This reverts commit 7ee275b620.
Richard Miles 7ee275b620 Added Y_DUAL_STEPPER_DRIVERS
Enables two stepper drivers to be used for the Y axis (useful for
Shapeoko style machines)
Each Y driver can be stepped either the same way or in opposite
directions, accounting for different hardware setups (leadscrew vs. belt
driven)
ErikZalm 6a1e980c6d Merge pull request from xoan/Encoder_Pulses_Per_Step
add ENCODER_PULSES_PER_STEP
ErikZalm 20076a8bd3 Merge pull request from GDV0/Marlin_v1
FIx compilation error when enabling SERVO_ENDSTOPS ()
Erik van der Zalm 3626b5ad8b Removed Delta from the default config file.
Changed EEPROM CHITCHAT behavior. M503 is always enabled.
Xoan Sampaiño bf7007d02f add ENCODER_PULSES_PER_STEP
GDV0 f17506c504 FIx compilation error when enabling SERVO_ENDSTOPS ()
Martin Lukasik acd8619809 Fan fix for Panelolu2+Sanguinololu.
George Roberts 595580556c Fixed bug that makes ulticontroller knob backwards introduced Feb 28 2013 by Robert.
Bug introduced in version 6beb42cdf6.
Robert did a good job of simplifying but messed up this chunk of code.

Looking at working version: 839bef6d5d
it seems there is no case where encrot3 should be defined as 2
because if ULTICONTROLLER is defined then NEWPANEL is also defined.
Tim Koster 88dfeefca3 Define BlinkM default disabled
Tim Koster 5350faf2a2 Merge https://github.com/timkoster/MarlinBlinkM into Marlin_v1
Tim Koster 7016cc9511 Added BlinkM support over i2c
Tim Koster 3b315b3da0 Added BlinkM support over i2c
Jim Morris f26f26b7bd Fix the example delta configuration as someone forgot to do it.
Peter Hercek 9aa2229077 add command M666 for adjusting delta printer endstop position
Robert F-C 9547fb9dfb Add duplication and auto-park mode for dual x-carriage support.
Steve Kelly 53614e5144 add pins for rambo lcd
Steve Kelly b42d24e31e add additional pins to avr2560 for rambo lcd
Nicolas Rossi b0c8120fcc Added feedrate setting in exemple config for manual moves from panel
Nicolas Rossi a54fe2d73c Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin.git into Marlin_v1
Conflicts:
	Marlin/Marlin_main.cpp
ErikZalm 7ea63d08df Merge pull request from iXce/avrdudeconfpath
Detect OS in Makefile to use the correct avrdude.conf path
ErikZalm 4187b637a5 Merge pull request from hg42/separate-INVERTING-macros-for-MIN-and-MAX-endstops
separate INVERTING for MIN and MAX endstops (6 #defines instead of 3)
ErikZalm 07e7de3600 Merge pull request from hg42/convert-PROTOCOL-macros-from-statements-to-expressions
convert PROTOCOL macros from statements to (multiple, comma separated) expressions
Guillaume Seguin c0c4c97db6 Detect OS in Makefile to use the correct avrdude.conf path
hg42@gmx.net 2ca983568d separate INVERTING for MIN and MAX endstops (6 #defines instead of 3)
hg42@gmx.net 3700f688f5 convert PROTOCOL macros from statements to (multiple, comma separated) expressions
daid a504c88346 Fix a bug where the PID controllers D action kicks in hard as soon as the PID controller starts.
Nicolas Rossi 394ed08f88 Added feedrate setting for manual moves from panel
Nicolas Rossi 9bf1cf1b22 Pre-calculate diagonal rod length squared
Nicolas Rossi 4623e78ce0 Added Honeywell thermistor 135-104LAF-J01
Brendan-csel d7f384f680 Skip SD menu refresh if nothing has changed
Brendan-csel abc8320a68 Save LCD_CLICKED before it is cleared
The SD card menu was refreshing so slowly that the button interrupt was clearing LCD_CLICKED before the menu items could check it.
Guillaume Seguin f4c3135c6d Add Panelolu2 pins for RAMPS1.3
Guillaume Seguin aae42c68f9 Update French translation in language.h
Guillaume Seguin 4d435c38a6 Add support of LiquidTWI2-based panels to Makefile
Use LIQUID_TWI2=1 as make argument to enable this support
Guillaume Seguin 6c42a3a339 Woops, fix logic
Guillaume Seguin 376d8af2c8 Report temperatures for all extruders
ErikZalm 434b6a05c1 Merge pull request from iXce/Marlin_v1
Report temperatures for all extruders in reply to M105
ErikZalm bdc2621119 Merge pull request from Brendan-csel/Marlin_v1
Fix for Viki LCD issues printing from SD card
ErikZalm 6965bd4e15 Merge pull request from njprossi/Marlin_v1
Fixed move from panel for delta bot 
ErikZalm a55b33e613 Merge pull request from iXce/panelolupinsramps13
Add Panelolu2 pins for RAMPS1.3
ErikZalm 8b34351537 Merge pull request from iXce/frenchupdate
Update French translation in language.h
ErikZalm 735e556724 Merge pull request from iXce/liquidtwi2_makefile
Add support of LiquidTWI2-based panels to Makefile
Brendan-csel d80aecda0a Skip SD menu refresh if nothing has changed
Brendan-csel be2dea1dc6 Save LCD_CLICKED before it is cleared
The SD card menu was refreshing so slowly that the button interrupt was clearing LCD_CLICKED before the menu items could check it.
Nicolas Rossi 55c287a69e Fixed move from panel for delta bot
Guillaume Seguin 1902d339b0 Add Panelolu2 pins for RAMPS1.3
Guillaume Seguin eb23a68e92 Update French translation in language.h
ErikZalm 1561c6df51 Merge pull request from wolfmanjm/delta-configuration
Setup Default configuration for Deltas if DELTA is defined
Guillaume Seguin 374bc99fa3 Add support of LiquidTWI2-based panels to Makefile
Use LIQUID_TWI2=1 as make argument to enable this support
Jim Morris ab624eac2a revert COnfiguratiuon to the same as head
Jim Morris 52f79ffeca add an example default configuration for delta style bots
Jim Morris b9d7ccf1cd Merge remote-tracking branch 'upstream/Marlin_v1' into delta-configuration
Conflicts:
	Marlin/Marlin_main.cpp
Guillaume Seguin d4d1540727 Use -fno-use-cxa-atexit to override gcc --enable-cxa_atexit
Guillaume Seguin 01ed99143c Woops, fix logic
Guillaume Seguin 76841450c8 Only display poweron/poweroff if PS_ON_PIN > -1
Guillaume Seguin 44f327d738 Uniformly reindent language.h
Guillaume Seguin 326d2db025 Update language.h so that all languages compile
Some strings still need translation, but at least everything compiles.
Guillaume Seguin 2cb716f513 Run Marlin/language.h through dos2unix
Guillaume Seguin 34da3a0a3f Merge github.com:ErikZalm/Marlin into Marlin_v1
Conflicts:
	Marlin/language.h
Guillaume Seguin 18199ff960 Merge github.com:ErikZalm/Marlin into Marlin_v1
Robert F-C fb5334f428 Fixed compile error when QUICK_HOME is defined.
As well a couple of minor changes to handling of extruder offset for
dual x-carriage mode.
Robert F-C c3568398b5 Disable DUAL_X_CARRIAGE by default
Robert F-C 39cd3dbdbe Remove dual x-carriage functionality that could/should be implemented in slicer
Also added a couple of missed merge lines in homeaxis() from previous
commit.
Jim Morris fb20ceabce enable soft endstops for delta
disable delta by default
Jim Morris d01ee7e7b5 fix zjerk being the same for delta as xy jerk
add more delta defaults
on delta make second home even slower
Robert F-C d7390e13d9 Support dual x-carriage printers
Dual x-carriage designs offer some substantial improvements for dual
extruder printing.
Jim Morris f3aa2a48e7 update max pos
Jim Morris 460751503e Added default configurations for deltas when DELTA is defined
Maik Stohn 9da94c247a fixed bad lcd commit from makr3d
#elsif does not exist #elif is correct
Erik van der Zalm 59004023fd Fixed typo
Erik van der Zalm 461dad6e05 Added : M32 - Select file and start SD print (Can be used when printing from SD card)
Untested
Erik van der Zalm c4a2077951 M109 and M190 now wait when cooling down if R is used instead of S.
M109 S180 waits only when heating.
M109 R180 also waits when cooling.
ErikZalm 8a2a3ef91d Merge pull request from iXce/Marlin_v1_lcd
Only clamp panel movements if software endstops are enabled
Erik van der Zalm 6397b3339c restored configuration.h defaults
Erik van der Zalm cdaaad3df1 Merge branch 'Marlin_v1' of https://github.com/makr3d/Marlin into makr3d-Marlin_v1
Erik van der Zalm e3bdefd873 fixed missing #endif
Erik van der Zalm a5be0c52c6 no message
Michael Mayer e509cdbeb0 added contrast control function for gLCDs
Michael Mayer 99b7e926e7 added MaKr3d Melzi board
Gabino Lopez 68be33b1fc Update language.h
I update the spanish Messages, now this compile for spanish language.
daid acb3271c9a Merge pull request from xifle/Marlin_v1
Fixes compiler warning for feedrate deadzone
xifle 61fe430d4f Should fix compiler warning for feedrate deadzone
Gord Christmas fde17d5720 Fix for ugly code compilation errors in SERVO_ENDSTOP checks
Guillaume Seguin aa65c20d1f Only clamp panel movements if software endstops are enabled
Erik van der Zalm ecf3ab5de4 Added thermistor 60 to configuration.h
Nicolas Rossi 2daa85918e Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin.git into Marlin_v1
Conflicts:
	Marlin/Configuration.h
	Marlin/Marlin_main.cpp
	Marlin/language.h
	Marlin/pins.h
	Marlin/ultralcd.cpp
Erik van der Zalm 2015989f84 Added DISABLE_MIN_ENDSTOPS
Christian Inci 648d45cfb2 Fix Pin Description Typo
Reverse 'Bed' and 'Fan' at the RAMPS 33 Description.

Signed-off-by: Christian Inci <chris.pcguy.inci@gmail.com>
ErikZalm 171719f18c Merge pull request from lajos/ultralcd_pid
ultralcd.cpp compile errors when !defined(PIDTEMP)
lajos b519af4f05 fixed another !defined(PIDTEMP) compile in ultralcd.cpp
lajos 7d03c52511 fixed compile error in ultralcd.cpp when PIDTEMP undefined
lajos 02dee80fa5 added Azteeg X1 motherboard
Henrik Brix Andersen 47dc70e3ec Fix location of avrdude.conf
Henrik Brix Andersen 1d258903bb Allow command line compilation when using BEEPER.
Erik van der Zalm e34c9981ab Delta disabled by default
Erik van der Zalm 26a441fc7d More 3Drag controller patches.
Erik van der Zalm ac975ed8c2 Merge branch 'deltabot' into Marlin_v1
Jim Morris caa848f943 fix homing for deltas
Erik van der Zalm 7ad12be763 Merge branch 'Marlin_v1' of https://github.com/codexmas/Marlin into codexmas-Marlin_v1
Conflicts:
	Marlin/Configuration.h
	README.md
Erik van der Zalm 408169aef4 Merge branch 'Marlin_v1' of https://github.com/BorisLandoni/Marlin into BorisLandoni-Marlin_v1
Conflicts:
	Marlin/Configuration.h
	Marlin/language.h
	Marlin/pins.h
Erik van der Zalm bd96d22bfb Merge branch 'Marlin_v1' into thinkyhead
Conflicts:
	Marlin/Configuration.h
	Marlin/Configuration_adv.h
	Marlin/Marlin.h
	Marlin/Marlin_main.cpp
	Marlin/Servo.cpp
	Marlin/language.h
	Marlin/pins.h
	Marlin/planner.cpp
	Marlin/ultralcd_implementation_hitachi_HD44780.h
	README.md
Erik van der Zalm 73f21cd5d6 Spanish updated so far.
Erik van der Zalm 6f4a6e531c Merge branch 'deltabot' into Marlin_v1
Erik van der Zalm 01edf22a10 Fix home_all_axis to make QUICK_HOME work with Repetier-Host which sends G28 X0 Y0 Z0 instead of G28. Thanks to Matt Schoenholz for reporting this issue.
Erik van der Zalm ff6fa09ecf Moved corexy implementation from stepper to planner
(Thanks iquizzle)
Erik van der Zalm c8dcc7c208 Allow increasing the software PWM frequency.
Erik van der Zalm 8b0d82e9db Removed "awaiting translation" for french
Erik van der Zalm 1e05d192ab Make the beep tone less offensive
Erik van der Zalm 373f3ecab3 Merge branch 'deltabot' of https://github.com/jcrocholl/Marlin into deltabot
Conflicts:
	Marlin/Configuration.h
	Marlin/Marlin_main.cpp
	Marlin/pins.h
kiyoshigawa f295712008 Trying to fix weird diff on ultralcd_implementation_hitachi_HD44780.h
kiyoshigawa 69b02031ca Fixed small error in lcd define statements.
kiyoshigawa 6a81291c57 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
This should fix issues with pull request 467, I hope.

Conflicts:
	Marlin/Configuration.h
	Marlin/Marlin.pde
	Marlin/ultralcd_implementation_hitachi_HD44780.h
BorisLandoni c1cb5977ee Update Configuration.h
BorisLandoni 8a5bd8a808 Update Configuration.h
BorisLandoni c1d7cf939e Update language.h
BorisLandoni 4c7d1436e9 Update pins.h
BorisLandoni 6588933c04 Update Configuration.h
Scott Lahteine 5dabc95409 Apply all changes from latest Marlin_V1
Diffed and merged, preserving my updates
Gord Christmas a733537ddd Missed some variable declarations
Integrated fixes from henrikbrixandersen pull request 
Gord Christmas f4f30c9d64 Added servo actuated enstop coding to allow G28 command to engage and retract a servo to specified angles.
Erik van der Zalm 79374f0b93 Merge branch 'reisnyderb' of https://github.com/ErikZalm/Marlin into Marlin_v1
Maik Stohn da05b3ba94 faster GLCD (ST7920 SW-SPI) implementation / fixes
- fixed long menu entries (>14 or >18 chars) caused overrun in dogm lcd
implementation
- fixed pin set problem when in interrupt
- much faster ST7920 SW-SPI implementation
- increased ST7920 framebuffer size for more speed
kiyoshigawa 4b19c8552e Fixing changed Configuration.h settings to be default values per ErikZalm Request.
Erik van der Zalm 971ec35135 Expanded M302 to allow setting the temp
Erik van der Zalm 5090c56651 More redundant temp sensor changes. (After testing and debugging by reifsnderb)
Guillaume Seguin 16b9239a26 Report temperatures for all extruders
ErikZalm a964b3cf3d Merge pull request from Gatulibu/Marlin_v1
Added support for Megatronics v2.0 and Minitronics v1.0
Maik Stohn e8572c5239 Fix: Long menu entries (>14 or >18 chars) caused overrun in hitachi display implementation
Maik Stohn 7ee70c2248 Fix: removed wrong ; at end of define
Gatulibu b78fa6bb70 Added support for Megatronics v2.0 and Minitronics v1.0
merged from code downloaded from reprapworld.com
Erik van der Zalm 9be61cdc02 Added redundant temp sensor
Erik van der Zalm 7231a20dba Put #ifdef around servo pins in pins.h. This allows the pins to be used for M42.
Alexander Kasimir e2ff536b03 Fixed typo in Comment
Robert F-C 40eb07bad4 Revert and extend previous change pin check change
Reviert previous change of #if BLAH_PIN > 0 to #if defined(BLAH_PIN) &&
BLAH_PIN > -1. Unfortunately some times pin 0 is used. For my sins I've
gone through and replaced all unsafe checks of #if BLAH_PIN > -1 with
the safe version.
Maik Stohn bd33cf4a9f fixed typo / added "const" to defines for newer gcc compatibility
ErikZalm 567291e734 Merge pull request from Banjer/Panelolu2_Melzi
Add Panelolu2 support for Melzi
Maik Stohn 8d80cbbf4c fix broken LCD commit #dfa549f268 from buildrob - GLCD/DOGM implementation was ignored
xifle 98d0d48191 fixed merge
xifle bbe67fca5a soft tab correction
xifle 9eeb711c96 Merged from Upstream Master
Bas Spaans 424101110c Add Panelolu2 support for Melzi
Robert F-C 0d4a9444c4 Merge remote-tracking branch 'upstream/Marlin_v1' into Marlin_v1
Erik van der Zalm 86cce025f4 Added #ifdef NUM_SERVOS to servo.cpp
xifle 03141a5ef4 LCD: Added Deadzone at 100% Feedrate
This adds a deadzone at 100% Feedrate when changing it at the status
screen/main menu. Prevents from unwanted feedrate-changing when
navigating back to the main menu and makes it easier to return to 100%.
Gord Christmas 28ada096e2 Adding servo documentation
Robert F-C 4121311b9d Change to LCD status indicators
The I2C LCD status indicators now indicate when the hotends or bed are
turned on at all (rather than just when they are in their heating phase)
Robert F-C dfa549f268 Merge remote-tracking branch 'upstream/Marlin_v1' into Marlin_v1
ErikZalm 64360164ad Merge pull request from codexmas/Marlin_v1
servosupport
ErikZalm 86405cdd11 Merge pull request from MStohn/thermocouple
BUGFIXES for temperature.cpp / add RUMBA thermocouple support
Erik van der Zalm 6c45c3f4e7 BariCUDA changes
Gord Christmas 96624f0f31 Forgot to include reference to Servo in makefile
Gord Christmas dc59f07d24 First attempt at refactoring of original servo code. Only adding servo support as a start to keep things simple.
Gord Christmas b668cb0516 Adding in clean copies of Servo library from Arduino 1.0.4
MaikStohn 95dff34b73 fixed wrong compare for min temp check of heater 1 and heater 2
MaikStohn 4cc6f9f6de fixed wrong pin initialization when using temperature 2 pin input
MaikStohn 61a48cc662 Add support for RUMBA thermocouple add on
MaikStohn 9cc15876be Add support for RUMBA thermocouple add on
ErikZalm c9cf2174dd Merge pull request from xifle/Marlin_v1
Fixed "Cooldown" Selection not reseting bed temp
Erik van der Zalm bd2cd4903e Added #ifdef BARICUDA around the BariCUDA changes
Jordan Miller 37f3199df3 fixed problems in planner with solenoids for BariCUDA when set to 0
Jordan Miller fbd899a37d Support for BariCUDA Paste Extruder derived from MakerBot Frostruder. Using Ultimachine RAMBo board. M126/M127 and M128/M129.
xifle 29bb8d7d4f Fixed "Cooldown" Selection not reseting bed temp
- enquecommand with multiple lines "\n" doesn't work -> M140 S0 didn't
get processed. So I wrote a new func for the cooldown which uses
setTargetHotend. In addition this does return to status page after
selection.
    - Added setWatch() to preheat-functions (Temperatur sanity check
would never have worked when preheating from the lcd panel)
Robert F-C 015d0594b0 Optimize menu selection for Viki rotary encoder.
The Viki LCD rotary encoder uses a different number of steps per
rotation. This fixes the seeming "missed" steps when selecting a menu.
gregor 2739c26c4f changes:
- changed the variables from keypad to reprapworld_keypad
- added a missing ifdef check
gregor 6fb9573157 added support for the reprapworld keypad
Tim Anderson 594193c908 Merge remote-tracking branch 'upstream/Marlin_v1' into Marlin_v1
Tim Anderson 1fa61c297e Turning off Control Panel by Default and Updating the link to the LiquidCrystal_I2C library to avoid confusion.
kiyoshigawa b27a59f41e Added support for Elefu RA Board and Elefu Control Panel
midopple a65a26d6b4 If CORE_XY is in use X and Y Axis had to be activated at the same time
midopple db2f157a22 Replace the <= to < in the Command M907, M350 and M351.
The for loop for Axis count over the Array.
Add a break after M907
Scott Lahteine a5cd582665 Support for 10 level deep SD folder hierarchy
Arnoud fc4ab05157 Solved minor bug in controllerFan()
Extruder 2 was checked where extruder 1 should be checked.
Scott Lahteine 0ef54f2f85 Make M303 silent when "S0" is sent
If S is left out perhaps it should be silent, but check the spec for
this M code.
Scott Lahteine a200521eab Added CUSTOM_MENDEL_NAME option to Configuration.h and language.h
Also cosmetic comment changes and spelling corrections in printed
messages
Martin Renold 1a397825f9 fix DEFAULT_AXIS_STEPS_PER_UNIT minor Z rounding error
Robert F-C 289c02eda4 Remove unnecessary pin initialization in stepper.cpp
(duplicates initialization in Marlin_main.cpp)
Robert F-C d5ad7a0814 Rework change to incorporate CONTROLLERFAN
Also refactor extruder auto fan logic to simplify further and now only
check every 2.5 seconds
Robert F-C c3cdaceab3 Merge remote-tracking branch 'upstream/Marlin_v1' into Marlin_v1
Robert F-C 1c127217df Make DOGLCD merge neater.
Robert F-C 7f57f28ccc Add lcd_buzz function to ultralcd.h so that non-LCD code can make use of lcd's buzzer.
Argument order of lcd_buzz was set to mirror that on tone(). Change
default M300 frequency to something audible.
Robert F-C 788d62bcc4 Merge remote-tracking branch 'upstream/Marlin_v1' into Marlin_v1
Conflicts:
	Marlin/Marlin.pde
	Marlin/ultralcd.cpp
	Marlin/ultralcd_implementation_hitachi_HD44780.h
Lukasz Stefanowicz d71f1e9bf6 Add (as an option) slower SD transfer mode
ErikZalm db5bb8546d Merge pull request from MStohn/Marlin_v1
128x64 RepRapDiscount Full Graphic Smart Controller support
daid 4b2ece159b Merge pull request from brackendawson/Marlin_v1
Make Gen7 1.4+ heater temp sensort pins match silkscreen.
Bracken Dawson d5ee2a5a62 Make Gen7 1.4 heater pins match silkscreen
MaikStohn 7ac6d7f78e FIX: Speedup - no explicit display clear needed in u8glib
MaikStohn 13596e8722 Added RepRapDiscount FULL GRAPHIC Smart Controller
MaikStohn 3a6abe1d6e Removed STB custom font hack from u8glib library and moved to marlin project
MaikStohn 16afbf9bfa FIX: adopted latest changes from hitachi implementation
daid303 34bca48b98 Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
daid303 ac52dcc174 Updated the card menu and watch messages to make it more informative.
Stefanowicz 31bb3fb297 Fix: Build error when EEPROM_SETTINGS is defined and PIDTEMP is undefined
daid303 c80a78bb70 Lower the default max E feedrate a bit. With the stepper fix this is much to high.
Simon Oliver 5d5909fc25 Fix failure to compile with heated bed: remove call to non-existant scaleBedPID().
Simon Oliver 93f0463b21 Allow Edit menu to call fn after edit; Fix PID Ki and Kd display in menus; Actually use changed PID and Max Accel values
Add new 'callback' edit-menu types that call a function after the edit is done. Use this to display and edit Ki and Kd correctly (removing the scaling first and reapplying it after). Also use it to reset maximum stepwise acceleration rates, after updating mm/s^2 rates via menus. (Previously, changes did nothing to affect planner unless saved back to EEPROM, and the machine reset).

Add calls to updatePID() so that PID loop uses updated values whether set by gcode (it already did this), or by restoring defaults, or loading from EEPROM (it didn't do those last two). Similarly, update the maximum step/s^2 accel rates when the mm/s^2 values are changed - whether by menu edits, restore defaults, or EEPROM read.

Refactor the acceleration rate update logic, and the PID scaling logic, into new functions that can be called from wherever, including the callbacks.

Add menu items to allow the z jerk and e jerk to be viewed/edited in the Control->Motion menu, as per xy jerk.

Conflicts:
	Marlin/language.h
Bart K 4fa2260a59 Fixed cardreader.h to resolve issue (Pull Request missing file)
Erik van der Zalm 038d405254 Corrected #endif in language.h
Dirk Eichel 443aaa30bf Removed GIT fragments
Seems that there was something wrong while merging
ErikZalm 7f622467fc Merge pull request from kefir-/m928_logging
M928 logging
ErikZalm 86867928ac Merge pull request from DDRBoxman/Marlin_v1
Add support for M300: Play beep sound
ErikZalm 9a38cad6f0 Merge pull request from STB3/GLCD_128x64_dots
Final task of the 128x64dots GLCD implementation
ErikZalm 7a5c474d91 Update Configuration.h
Dirk Eichel 4e448b700a Merged fetched files from Marlin_v1 branch
Pull requests:    
ErikZalm 9f2862ce48 Merge pull request from whosawhatsis/Marlin_v1
regenerated thermistor table 7
ErikZalm 9fb8bd5685 Merge pull request from whosawhatsis/bang-mode
Separate PID_MAX from BANG_MAX
Colin Edwards 0d075378d5 Add LARGE_FLASH define and enable it for some of the beefier boards
The LARGE_FLASH flag allows superfluous features to be excluded
on boards with less memory
Colin Edwards 9a1c90471f Ignore unused beeper pins
Colin Edwards 1a0f889803 Add support for M300: Play beep sound
Robert F-C 9322c408c6 Updated for LiquidTWI2 library version 1.2.3
The new version of the library means that PANELOLU no longer needs to be
defined in LiquidTWI.h (the library file can be used as is) and the new
version of the library also enables the buzzer on the Panucatt VIKI
panel.
whosawhatsis fd5b7e0cec Separate PID_MAX from BANG_MAX
This allows PID_FUNCTIONAL_RANGE to use a maximum duty cycle higher
than PID_MAX. This is useful for powerful heaters to heat quickly in
bang-bang mode, but use a lower duty cycle that is easier to stabilize
in PID mode.
blddk e5a853a3d0 Added automated extruder fan function
blddk 72419f69a9 Added rumba
blddk 91bea43332 Added rumba pinout
blddk d2b00fe486 Removed html and added rumba
Found some unwanted html at the bottom of the file which caused it to not be able to compile.
Also added rumba as machine.
Dirk Eichel 6c66cae694 GLCD init screen cosmetics
Dirk Eichel f3e0e5184d Add include selector between char. LCD and GLCD
Dirk Eichel 5d3862f9d1 Modified u8glib logo on welcome screen
Dirk Eichel 0b320f75e9 Removed debug code, add some comments
Dirk Eichel 5f1cd70122 Add code to lcd_update() for GLCD
This code selects between the routines for the GLCD or the char.
display.
Dirk Eichel a49c09a776 Add variable for animated fan, add float conversion w/o sign
A new variable was introduced to allow fan animation on the GLCD.
Add additional float to string conversion routine without sign
character. This is used for the coordinates visualisation on the GLCD.
Dirk Eichel 26d8863111 Add library selection between GLCD and char. LCD
Dirk Eichel 4a141a694f Marlin code for GLCD display
This contains the menues, status screen etc...
Dirk Eichel 83c790a020 Add bitmap graphics for GLCD
1. Marlin welcome screen
2. Status screen symbols 3 Extruders, heated bed, animated fan logo 1
3. Status screen symbols 3 Extruders, heated bed, animated fan logo 2
Dirk Eichel 233df9cca0 Add missing LF at the end of the file
Dirk Eichel bb0de75a92 Removed umwanted HTML code ath the end of the file
Sorry for that. This does not lead to compile errors. I removed the
unwanted code to make it clean.
Ryan Turner 7c47e7162d Adding Maker's Tool Works heated bed thermistor
daid af78d0cbfa Merge pull request from illuminarti/Fix_E_Speed
Fix step rate bug (especially for retraction)
Dirk Eichel 9a78f321a4 Add pins for Motherboard variant 64
These definition contain also the definition for the graphics LCD.
Dirk Eichel 5de25ccd20 Add Motherboard variant 64 - STB V1.1
Definition for the graphic LCD are already in it, they will not harm the
configuration as they are only defined constants
daid d6ce63c49c Merge pull request from STB3/Marlin_w_STB_Board_support
Add STB board support to Marlin (next step towards graphic LCD implementation)
Ketil Froyn f036be7c4e Clean up tab/whitespace from last commit
Ketil Froyn 07e11c7cf5 Add command M928 to enable logging to file of received gcode commands
daid 92782f9252 Merge pull request from illuminarti/Fix_E_Speed
Fix step rate bug (especially for retraction)
whosawhatsis 6a61a3c0b4 missing comma in last commit
whosawhatsis f0aee4101a regenerated thermistor table 7
Generated with createTemperatureLookup.py. The old table crapped out at
270C, which was a problem for polycarbonate.
Nicolas Rossi aba67e2449 No bed config for RAMPS
The motherboard 35 is a config without bed with this pins setting :
D8 Extruder
D9 Fan
D10 Controller Fan
Nicolas Rossi 6504e96165 Turn off power supply off-load
Disable the high current output and wait a little before to turn off,
because the interrupting capacity of the PSU is unknown.
Could be a function if needed by other.
Nicolas Rossi 86bf911139 Toggle menu for PSU from LCD pannel
From the prepare menu, accessible when is not printing, you have the
possibility to turn off the PSU when is on et vice versa.
From the host, you can turn off or turn on the PSU then the menu is
updated accordingly.
From the LCD message, the printer status is reported ready or off
respectively when the PSU is on or off.
Robert F-C 7bad72359c Support encoder click on PANELOLU2 being read through I2C
This change also handles the case where the pause/stop/restart button on
the VIKI is not used. Make LCD I2C buzz sound the same as the normal
buzz (300ms is too long for quick feedback).
Robert F-C 1daf2f3256 Number of extruders is not an advanced configuration - it is a basic property.
Robert F-C f1263d3f88 Further reduce code by using precompiler logic
Dirk Eichel 140e095c6e Add pins for Motherboard variant 64
These definition contain also the definition for the graphics LCD.
Dirk Eichel b2c1c64fb1 Add Motherboard variant 64 - STB V1.1
Definition for the graphic LCD are already in it, they will not harm the
configuration as they are only defined constants
Dirk Eichel ceb5ee38af Replaced corrupted language.h file on local PC with current from ErikZalm/Marlin
Dirk Eichel 8efd4cfd73 fixed merge conflict
Robert F-C 372e12f83f Implement automatic extruder/cold-end fan control based on temperature
This change allows fan outputs to automatically turn on/off when the
associated nozzle temperature of an extruder is above/below a threshold
temperature.
Multiple extruders can be assigned to the same pin in which case the fan
will turn on when any selected extruder is above the threshold.
It also makes the M42 command compatible with the M106/M107 command.
The majority of the logic in this change will be evaluated by the
compiler at build time (i.e, low code space requirements).
Robert F-C 6beb42cdf6 Attempt to address Bernhard's comments
Refactor configuration to try to make items clearer (what defines a
panel vs what is user changeable).
Robert F-C 839bef6d5d Fix Configuration.h file to not define LCDs be default.
Also fix compile time check in Marlin.pde
Robert F-C 1292d735ba Converge all I2C LCD branches (PANELOLU2, VIKI & PCF8575)
This includes refactoring the buttons code to remove a large amount of
non-pin dependent duplication from pins.h.
daid303 4eb81a69e6 Only compile the new extruder offset code if you have multiple extruders.
daid 3e9cd334a4 Merge pull request from dob71/jeff
Hotend offset handling for multi-extruder machines
MendelMax 67710df9f3 Made i2c mode wok with the hardware I am able to test (ywrobot / sainsmart i2c LCD 2004)
Removed incorrect LiquidCrystal_I2C Library
Bob Clough b6209c86dd Added import of Wire Library to make I2C LCD support compilable
Bob Clough 2b567d1df5 Added I2C port expander support to HD44780
Bob Clough 06272f463d Added Config variables for activating I2C LCDs and setting type and address
daid303 de3dec7215 Also show the tune menu when USB printing.
Denis Bakin 73d41c10b9 Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into jeff
Conflicts:
	Marlin/language.h
	Marlin/thermistortables.h
daid 63da4dc59a Merge pull request from DanieleSdei/Marlin_v1
Marlin v1, alignment of the Italian language
Daniele Sdei 82e28851bd Italian language: SD-Card change and SD-Card init
Daniele Sdei aed5965ad8 Italian language: remove space and some fix
codenamepawel d360846dd4 Update Marlin/language.h
Update Polish language 	#define MSG_RESUMING "Wznawiam drukowanie"
daid303 2f60e324dc Fixed
daid 5e2abfcdcd Merge pull request from STB3/Marlin_with_SD-Card_Change_Menu
Add SD-Card change and SD-Card init. for electronics equipped with LCD Display
Dirk Eichel a0d4e8e78e Add Messages for SD Card init. & change
mfeherpataky bbf0cc1379 Update Marlin/ultralcd_implementation_hitachi_HD44780.h
Fix to a bug that I just introduced - sorry. Forgot about offset of string length.
Dirk Eichel c8f1fbd9d8 Add SD-Card change and SD-Card init.
Add SD-Card change and SD-Card init. for reprap electronics without
SD-Chard change detect pin.
mfeherpataky 71ddb8dc60 Update Marlin/ultralcd_implementation_hitachi_HD44780.h
Use all available characters in narrow LCDs < 20 characters.
mfeherpataky d2c547c407 Update Marlin/ultralcd_implementation_hitachi_HD44780.h
Fix to a minor bug with hardcoded LCD_WIDTH that draws edited values outside of the 16 characters width LCDs.
Denis B 70871715e4 Added support for extruder offset handling
The extruder offset can be specified in the configuration
file or adjusted on the fly using the "M218 T# X# Y#" command.
The EEPROM support is not yet merged in.
The "T#" command can take option "F#" that specifies the feedrate
at which the printing head should be re-positioned. If not
specified the re-positioning move is not preformed immediately,
but the coordinates are adjusted for the printer to properly
position the head when the next movement happens.
Denis B 49b2ddc8c1 Cleaned up non-standard characters
Bernhard Kubicek f8876a7958 Merge pull request from kintel/skip_longfilenames
Also skip .files and _files with long filenames. I think its better than before. If somebody dislikes it, or wants additional configuration, it can be done in a future step. Thanks, Marius, and nice to have you helping!
daid 18fcc367d2 Merge pull request from Banjer/Melzi_LED_PIN
Chenged LED_PIN for Melzi boards, added comment about broken versions of...
Bas Spaans 19ce90fe02 Added comment about M42 usage (clean)
Bas Spaans 00fed0a703 Revert "Extended comment explaining M42 usage"
This reverts commit 01541ee64c.
Marius Kintel e06d820909 Also skip .files and _files with long filenames
Bas Spaans 01541ee64c Extended comment explaining M42 usage
Marius Kintel f24f02e212 compile fix: quickStop() needs stepper.h
Bas Spaans 12c41423ad Fixed typo in comment
Bas Spaans 0995eaa492 Chenged LED_PIN for Melzi boards, added comment about broken versions of the Sanguino libraries
Bernhard 1d06b10962 Added a feature to have filament change by gcode or display trigger.
[default off for now]
syntax: M600  X[pos] Y[pos] Z[relative lift] E[initial retract] L[later retract distance for removal]

if enabled, after a M600, the printer will retract by E, lift by Z, move to XY, retract even more filament.
Oh, and it will display "remove filament" and beep like crazy.

You are then supposed to insert a new filament (other color, e.g.) and click the display to continue.
After having the nozzle cleaned manually, aided by the disabled e-steppers.
After clicking, the printer will then go back the whole shebang, and continue printing with a fancy new color.
daid303 408b349a84 Fixed . Commented out the wrong pin definition, but explained why it is there.
Daniele Sdei 9ecb267b63 Merge remote-tracking branch 'upstream/Marlin_v1' into Marlin_v1
Daniele Sdei 3cf59f6f9a add RepRapPro Huxley thermistor tables
daid c1730e2b08 Merge pull request from yuroller/sanguino_panelolu
Panelolu pin assignment for sanguinololu
Yuri Valentini 86358dd6cd Panelolu pin assignment for sanguinololu from http://reprap.org/wiki/Panelolu
daid303 0f3f5d083d Minor cleanup of the new FAN_KICKSTART code.
daid 6ec56fa923 Merge pull request from KevinOConnor/FanKick
Add feature to briefly run the cooling fan at full speed when it first starts.
daid 965baf2683 Merge pull request from daid/Marlin_v1
Finnish language
Kevin O'Connor 3d91bd486c Add "kick fan" feature - briefly run fan at full speed on start.
Add a feature to run the cooling fan at full speed for a small period
(default 100ms) when first starting the fan.  Some fans wont reliably
start spinning at low power, and many fans have issue with the PWM at
low power.  However, once the fan starts spinning it can reliably be
set to a wide range of PWM values.
Kevin O'Connor 3f2f94ef28 Be consistent in setting of the fan PWM.
Always set the FAN PWM value in check_axes_activity() and always use
the value of the active move if a move is active.
Henry Palonen 7f30039d2a + Finnish translation
daid303 14e1d495ef Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
daid303 bbe7d3d0fe Fixed
daid 7ce509b9a7 Merge pull request from yuroller/MakefileSanguino
Makefile sanguino
Yuri Valentini 9c34c4f05b fixes for ramps compilation using installed arduino ide
daid303 442ade15a6 Move Gen6 stuff into a proper location.
daid 5fd4582cc8 Merge pull request from Drakelive/Marlin_v1
Fixes issues # 216 and # 135 for Gen6 and Gen6 Deluxe board
daid303 8b88e3b386 Fixed , Fixed .
daid 27843388c6 Merge pull request from njprossi/Marlin_v1
Power signal control definitions for other power supplies
daid303 921273baa0 Added optional feature to stop printing when an endstop is hit. Made the Z display on the LCD in 3.2 format instead of 3.1. Added LCD message when and endstop is hit.
Yuri Valentini 7d20ec706e Added libraries from Arduino 1.0.3 for sanguino build
Nicolas Rossi 437eb3bafc Initialize PS_ON at startup
Nicolas Rossi f3c1fc70a9 Power signal control definitions for ATX and others
Yuri Valentini dad7691df9 makefile for sanguino standalone compilation
Erik vd Zalm 6752cb2d9c PID now per extruder. Fixed typo
Erik vd Zalm 0ac452e252 Disable is now multi extruder compatible. M84 got a T option.
Johann Rocholl 9e7b5056a0 {X,Y,Z}_{MIN,MAX}_POS are actually in Gcode coordinates.
Daniele Sdei 5f82f03ff3 Add italian MSG_RESUMING.
daid303 5e3873c8db Add german MSG_RESUMING.
daid303 01aac2a142 Small changes on the LCD panel, let the speed control work better, line up the parameter edit the same as the menu, remove some unused defines, and remove the Z from the 10mm move menu.
daid303 b69cb9fbd9 Change the end of SD cart print message from minutes/seconds to hours/minutes.
daid 30254e3388 Merge pull request from jcrocholl/Marlin_v1
Automatically set *_MIN_PIN and *_MAX_PIN according to *_HOME_DIR.
daid303 38ee395ac7 Replace the 1ms delay for 2 nops to get a 100ns delay.
daid303 5df5e4c4a2 Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
daid303 a95dcd74e7 Fix some of the duplicated PSTRs, saving 500bytes of flash with LCD on.
Johann Rocholl 8caf5d252d Remove bogus blank line.
Johann Rocholl 1c2ecddae4 Fix typo (# missing before define).
Johann Rocholl 6dfb8a2187 Fix home_all_axis to make QUICK_HOME work with Repetier-Host which sends G28 X0 Y0 Z0 instead of G28. Thanks to Matt Schoenholz for reporting this issue.
Johann Rocholl 3b2e5027e5 Merged updates from Marlin_v1.
Johann Rocholl b39f5d614a For boards with only one endstop per axis, automatically set *_MIN_PIN and *_MAX_PIN according to *_HOME_DIR.
oni303 ab09fa4bbf fixed pwm generation at pin D12 and D13 when one of them is used as FAN_PIN on Sanguino, added soft pwm entry for FAN_PIN in temperature.cpp
Sergey Taranenko 5697451c72 fix lcd class
Sergey Taranenko 58e806f3fa Fix the russial translation.
Sergey Taranenko 50a5ce1dc4 deduplicate messages
daid303 6123a00e64 Fix the german translation.
daid303 7c21716886 Fixed
daid303 ae1bc83350 Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
daid303 596a7e1904 Fix compiling for Arduin < 1.0.0
Daid b264317fa0 Reverted the patch by KevinOConnor, as it crashes some versions of avr-gcc and caused linking issues.
Daid 673577a31b Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
Daid 23022f1a82 Updates to Makefile to compile for Teensy.
daid 96e9db8919 Merge pull request from KevinOConnor/CompilerFlags
Add additional optimization flags to Makefile
daid303 08356361ac Fixing a problem with heated beds not working without PID and BED_LIMIT_SWITCHING
daid303 047d037f8c #ifdef fix for
Kevin O'Connor 0908458381 Use gcc "-fwhole-program" optimization.
Use "whole program" and "link time optimization" features of gcc.  The
whole-program optimization enables the compiler to evaluate the entire
firmware for optimization instead of just one code file at a time.
This leads to better overall optimizations.
Kevin O'Connor 16fbb455ef Use linker "--relax" option.
The "relax" option enables the linker to convert certain "call"
instructions to the smaller "rcall" instruction.  This reduces the
size of the resulting binary.
daid303 f30b46b2a8 One more fix for , I really should get a heated bed to test with.
daid303 65c3f1ffcd Most likely fixing
daid303 7577717b59 Fixed
daid303 1a8f54cea1 The big LCD code update. This splits the display and menu implementation. Paving the way for future different displays. It also makes it easier to modify the menu structures while keeping everything consistant. Note that this most likely breaks the translations, which need to be updated.
daid303 6731c094ee Fix compiling with just an 16x2 LCD and no buttons.
daid303 b99a928a80 Fix the M117 (display message on LCD) when used over USB with checksums.
daid303 55ba90ac19 Add PID functional range setting. With high powered heaters the current functional range of 10 degrees causes high overshoots as the PID needs to kick in before the temperature hits 10 degrees below target.
daid303 5ff5cee8ce Fix the sensitive pin definitions, there where analogue numbers in the digital pin list. Also made M42 without a P function on the LED_PIN (which was otherwise a useless pin definition)
daid303 8b58edc70e Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
daid d0319d45af Merge pull request from jcrocholl/Marlin_v1
Fix endstop pins for Printrboard
Johann Rocholl ca409e5531 Fix X/Y/Z_MIN_PIN for Printrboard.
Johann Rocholl 1f45cb0a51 Fix typo in MANUAL_HOME_POSITION (plural S missing) and improve comments.
Johann Rocholl 931a0052ea Fix typo in MANUAL_HOME_POSITION (plural S missing) and reduce BLOCK_BUFFER_SIZE because 64 wasn't working for some reason.
daid303 46ec4b648c Added some missing Mxxx comments to M commands. Fixed the unsetting of the timer dividers for the fast PWM fan.
Daid 724f5aa36b Update on makefile for moved Arduino addons.
daid303 6d9dfa96c3 Move the Arduino related stuff out of the Marlin tree, as they are not directly related to Marlin functionality but addons for the Arduino IDE. Also split up the addons for pre 1.0.0 Arduino and post 1.0.0 Arduino.
daid303 3fb07d9b8d Add MINTEMP/MAXTEMP error to LCD, and fix temperature bug with more then 1 extruder.
Johann Rocholl 8e2519e88b Add realtime delta geometry in Marlin_main.cpp.
Johann Rocholl cec7283b21 Enable QUICK_HOME for deltabot.
Johann Rocholl 2292441f0c Use X/Y/Z_MAX_PIN instead of X/Y/Z_MIN_PIN for top endstops on deltabot.
Johann Rocholl c430906d3b Deltabot settings and configuration adjustments.
daid303 82c8724b33 Fix compile with PID_DEBUG
daid303 9b160972a1 Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
daid303 e036750bdf Use the disable macros on initialization. Which fixes a bug when there is no pin defined for stepper enabled (motherboard 4)
Daid fcd9de72ef Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
Daid 32d4373e0f Add printrboard and brainwave to Makefile.
daid b3ddbcee2a Merge pull request from jcrocholl/Marlin_v1
Add Printrboard and Brainwave to pins.h and fastio.h
Daid 29435dfb4b Proper avr for Sanguino in Makefile.
daid303 52158dffcc Big temperature code update. No longer converts back and forwards between temperature and raw sample value. Reducing complexity, removing code. Also named some variables better. While keeping the safety intact and functionality the same.
Daid ca7acbe6d9 Allow specification of which arduino hardware subvariant in Makefile.
Johann Rocholl 33247733e0 Teensylu and Printrboard use different analog pins for thermistors.
Johann Rocholl 621c24a10f AT90USB is only defined after pins.h is included.
Johann Rocholl 6cba11f087 Stop redefining MOTHERBOARD and #define AT90USB instead. Also put #ifndef AT90USB around the HardwareSerial_h trick, so now Printrboard / Brainwave support compiles on Arduino 1.0.2 as well.
Johann Rocholl 4d351b4846 Improved formatting and comments for consistency.
Johann Rocholl a30007caa4 If fastio.h is not messed up then Teensylu and Printrboard are actually using the same pins.
Johann Rocholl 6aa87a7b67 Use the same fastio.h definition for AT90USB1286/7 and AT90USB646/7.
Johann Rocholl b1c38d4c82 Avoid compiler warnings (redefined MOTHERBOARD) in Arduino 1.0 and greater.
Johann Rocholl 42e21bb06e Add support for Printrboard (from https://github.com/lincomatic/Marlin) and Brainwave (from https://github.com/metrix/Sprinter).
Johann Rocholl ce4b5bbeaa Add AT90USB646 support from Sprinter to fastio.h.
Daid f413aa33b3 Small makefile change, posibility to add defines on the commandline, and fix compiling with watchdog enabled when using the Makefile.
daid303 587154c01b Fix the WATCHPERIOD implementation. It did not work correctly in a multi extruder setup, it did not work after 32 seconds after startup (int16 used as millies timestamp). And it did not work if you gave an M104 or M109 when the target was already around the target setpoint. So on average, it did not work at all. The new implementation should be robust in detecting a failure to heat up.
daid303 1f27870d41 Fix compiling the watchdog error message when the manual reset watchdog is used.
daid303 c5d4225804 Mistake there, not sure why I did that. My bad.
daid303 529748894c Minor changes in the temperature code for some cleanup.
daid303 4e26ecc940 The Partial release message (which does not really tell you anything) overwrites the final print time on the LCD, which is a real shame. So I removed the message.
daid303 c421774422 The Partial release message (which does not really tell you anything) overwrites the final print time on the LCD, which is a real shame. So I removed the message.
daid303 16078e47d4 Fixed
daid303 6a9bee27cc Changed the naming of some LCD functions, so the names match better what the function does. Also moved around some prototypes for general cleanup.
daid303 94ea26ff46 Some minor changes on code style. And a bugfix where the counters for positioning in the stepper where wrong depending on compiler settings. (Caused strange values to reported back with M114 and endstop triggers). Also fixed compiling with FWRETRACT enabled.
daid303 6c51fe5039 Fix the bug where the SD percentage calculation is wrong when the file is larger then 42MB
brupje 57429cb9fe Fix for keypad
daid303 97fa2a9c30 Few simple fixes that save RAM, as static strings are stored in RAM by default.
Daid c94ca24adc Fixed
Daid 99e9554edd Some fixes in the Makefile to support Arduino 1.0.0 or higher and added the Rambo. Still needs some more work for the different arduino hardware variants.
Erik vd Zalm dbbf050005 More rambo fixes
Erik vd Zalm f934d0ef5b Merge remote-tracking branch 'tonokip/Marlin_v1' into Marlin_v1
Conflicts:
	Marlin/Configuration.h
Erik vd Zalm e48dfcc2b3 Tmp copy before merge
Erik vd Zalm b98fb17fe9 Small FREQUENCY_LIMIT changes
daid bce67ec2c9 Merge pull request from gege2b/Marlin_v1
Added french translation
Gege 9b1d2483a0 I hope last changes to french translation
Gege b1adc567da Correction to french translation (non-ASCII chars only)
Gege 0807d82af0 Correction to french translation (plain text only)
Erik vd Zalm 5cd7a90b32 Added new temperature lookup table creation tool. This one uses stein hart-hart equations.
You need 3 temperature resistance:combinations. This gives a better result then using beta.
gege2b bb119739b0 Added french translation
daid df8dd5ac21 Merge pull request from nothinman/Marlin_v1
Added automatic build numbering.
MaikStohn 2b7b1e52b1 allow marlin internal 0°C represenation
Martin Lukasik 2f771b3979 Added automatic build numbering.
daid 9bebe9b631 Merge pull request from nothinman/Marlin_v1
Added Polish translation. Cosmetic changes to English.
daid303 a2032afa3a Fixed
Martin Lukasik 6a55ca8370 Added Polish translation. Cosmetic changes to English.
daid303 8f20562f49 Fix some of the crowded code style. And fixed the conditional.
daid303 43018a48c4 Fix for a few -Wextra warnings.
daid303 72586eb30a Solved few warnings.
daid303 7a02ba361c Header multiple include protection should match the filename, not just _ARDUINO_H, which is almost bound to go wrong some day.
daid303 f4a89ec776 SDCARDINSERTED is always defined, and thus we do not need the #ifdefs.
daid303 57834776ad Made the 2nd speed lookup table condition more explicit.
Daid caa2b25b40 Fix Gen7 compile if you have avr-libc version 1.7.1 or higher. See http://code.google.com/p/arduino/issues/detail?id=604
daid303 a27fef8750 Store the pre-heat constants outside of the ULTIPANEL define, so we can use them when storing EEPROM in a build without the ULTIPANEL.
daid303 789be03b4f Update on makefile, should make it easier to compile for different boards without changing the makefile. (Still missing Arduino 1.x.x support).
daid303 40ce057a3e Fixing issue
daid303 625ac81acc Yes, makes sense, lets NOT use the value directly from the configuration define but modify it before setting it. This will not confuse people (including me) at all!
daid303 ffc69537aa Update on some comments, make the MOTHERBOARD list complete again.
daid303 71efcfc648 Most likely fixing issue .
daid303 04be9d6001 God damn. Sorry, my mistake, forgot to add this file.
daid303 c17da4b707 Add ConfigurationStore to the Makefile.
daid ccd9fd0dc3 Merge pull request from jothan/lcdfix
Lcd fixes
Jonathan Bastien-Filiatrault 46b9988e26 Search and replace failure.
Jonathan Bastien-Filiatrault 0f73afb0b0 Avoid defining overriding definitions for the RepRapDiscount Smart
Controller. Remove common definitions. Harmonize declaration order.
Jonathan Bastien-Filiatrault 36b452c7ac Remove abbrs.
YanFM 332344bd43 Update Marlin/language.h
Included Portuguese language
daid303 e6c1cadea0 Set the watchdog to a 4 second timeout, as with 1 second it can timeout during SD card init.
daid faea7d72b8 Merge pull request from buildrob/Marlin_v1
Clean up special serial port cases
daid303 12a4d60e18 Fix the EEPROM storage, no longer inline it at multiple locations, and remove the template.
Jonathan Bastien-Filiatrault 9606f4d04f Include Marlin_main.cpp in source files.
Jonathan Bastien-Filiatrault 3cbaad9288 RepRapDiscount Smart Controller pin definitions.
Robert F-C 99692dc99e Clean up special serial port cases
Assume SERIAL_PORT 0 if not defined. Collapse un-numbered register
special case. Clarify comments.
daid303 5a998558a9 Update suggested by Robert F-C.
daid303 f6ff0ab767 signed/unsigned fixes.
daid303 5d471e0f34 Also reset the PID values to defaults. Fixes
daid303 d3ebc34958 Hopefully also support chips with a single UART in MarlinSerial now.
daid303 b6ff45254e Better explain the watchdog "problem" and rename the config define so it explains that the feature belongs to the watchdog.
daid303 7e348fcb5f By mistake enabled the watchdog by default. This should be off by default.
daid303 06b58a9c4f First cleanup. Moved all code to cpp files, so there are no dependencies on pde files. And no more odd requirement to cat files together. (Still need to fix the Makefile). Also cleaned up some defines and made defines upper case as by C coding conventions.
daid 539f3b3fe4 Merge pull request from brackendawson/Marlin_v1
Use the right pins for Gen7 1.4
Robert F-C 65c9a0728f Set default serial port back to 0.
Robert F-C ab9d183024 Make serial port configurable.
This change makes the choice of serial port configurable so that
wireless capability can be easily added by connecting Bluetooth modules
(such as BlueSmirf or JY-MCU) to the expansion port pins.
Bracken Dawson f5631a89e8 Add dummy Emergancy Pin to Gen7 1.4
Change required after pulling from ErikZalm.
Bracken Dawson a4f9e1ebf2 Merge git://github.com/ErikZalm/Marlin into Marlin_v1
Bracken Dawson 2873d67b17 Put bogus temp override back in Gen7 up to 1.3
Took out the ifdef when I split 1.4 out and forgot to permanently
define it for <=1.3.
ErikZalm a7e40b2903 Merge pull request from setar/Marlin_v1
Fix num of digits on LCD for E and Z axis.
MaikStohn 6ed02c86be Fixed wrong code (will not even compile when EXTRUDERS>2)
Sergey Taranenko 2a67363e27 Fix ‘prog_uchar’ definition in LiquidCrystalRus.cpp
Sergey Taranenko 205304ddee Merge git://github.com/ErikZalm/Marlin into Marlin_v1
Erik vd Zalm 58bca87c72 fix LCD temp bed artifacts on power up ' B022/0.) -> B022/000 '
Erik vd Zalm febeb43197 Revert "fix LCD temp bed artifacts on power up ' B022/0.) -> B022/000 '"
This reverts commit cb02c2f9d8.
Sergey Taranenko 8178dec4c3 Fix num of digits on LCD for E and Z axis.
The number of steps per mm often contains 4 digits before the decimal point and does not require precision greater than 0.1
ErikZalm 70f57a6844 Merge pull request from setar/Marlin_v1
fix LCD temp bed artifacts on power up ' B022/0.) -> B022/000 '
ErikZalm ff14199e58 Merge pull request from jothan/Marlin_v1
Create an explicit rule for building applet/Marlin.cpp.
Daniele Sdei 695938ba3f Italian language support
Sergey Taranenko cb02c2f9d8 fix LCD temp bed artifacts on power up ' B022/0.) -> B022/000 '
Jonathan Bastien-Filiatrault e4a5e333ef Generalize.
Jonathan Bastien-Filiatrault e10d3136c8 Create an explicit rule for building applet/Marlin.cpp.
It would seem that the pattern matches do not work when the source
file is created when make is running. The result of this is that it is
necessary to run "make" twice to build the firmware.

This adds an explicit rule without a pattern match for building
applet/Marlin.cpp it corrects the make behaviour at the cost of adding
a little redundancy in the Makefile.
ErikZalm 9f089756b7 Merge pull request from setar/Marlin_v1
Added Russian translation
brupje 326423719f Add support for Megatronics
brupje d07b6e93d5 Add support for Megatronics
Sergey Taranenko efcc28d347 Fix check for include LiquidCrystalRus.h
Sergey Taranenko cfc193cdac Enables support the Cyrillic alphabet for LCD
Sergey Taranenko 24bcc9647d Added Russian translation
Mark Finn bf7e453d02 Unwanted artifacts from unclean merge of bed-pid tree
ErikZalm 36a746d7d5 Merge pull request from markfinn/pidbed
PID for heated bed
elgambitero df09e2adce Spanish updated
elgambitero ddf6603d81 Spanish language updated. Bug fixes on dialogs.
elgambitero 4bf8b1aeee fesfas
drakelive be1e099f1b Union whit Erick version
elgambitero 7afd202b89 New dialogs translated to spanish. Bug fixes.
Dialogs from M119 translated, and "Set Preheat" dialogs adapted to the
screen size.
elgambitero ebc4601185 Some new dialogs translated to Spanish
drakelive c8ea9b0e58 Merge branch 'Marlin_v1' of https://github.com/Drakelive/Marlin
drakelive ca7ca4572e primo commit
johnnyr 8016f058bc fix max endstop pins
Mark Finn d197f8504b clean up and changes from testing
Mark Finn eb06a886c4 missed
Mark Finn 04631d2250 cleanup for pull
Mark Finn 0a5ad3ab85 move comment to correct place
ZetaPhoenix 8ac5b29e02 Changes to M119 response for easier visual comparison
Changed to report on individual lines with "TRIGGERED" or "open" instead of "H" or "L" on one line as H&L could be confused with logic levels High and Low which may be wrong if using inverted logic.  Added strings to language.h.

Fixed typo "deu" in English language that was fixed in  but got added back in via 9f7f7354f5
ZetaPhoenix c6caa45ae2 Limit Switch locations based on MIN/MAX limits and homing direction
fixes 
Added statements to set the limit switch positions to the maximum travel if homing in the positive direction as well as bed center at (0,0) if defined.
Relocated code based on feedback.
ZetaPhoenix dc566d654f fixes
Added statements to set the limit switch positions to the maximum travel if homing in the positive direction as well as bed center at (0,0) if defined.
ErikZalm ba898faa7d Merge pull request from gwelchc/patch-2
Slight modification for byte savings
ErikZalm 0152ee71a5 Merge pull request from gwelchc/patch-1
Binary representation for characters in ultraldc.pde
G. W. C. 6ccbfeb80c Update Marlin/Marlin.pde
Added function 'setTargetedHotend' that turns into a function an operation repeated 3 times through the M-codes processing.

This modification saves a few bytes that can be used to add support for new commands.
G. W. C. c433142abf Update Marlin/ultralcd.pde
The joris' char drawins are expressed in binary so to show their content's in a more visual fashion.

This is not a code modification as much as a readibility modification.
andrey-vasilyev 1d389ad3a8 Fix M81 not working reliably on Gen7
Some discussion of the issue is here http://forums.reprap.org/read.php?181,118329,page=1
Mark Finn 9698f4ea64 bed pid
Conflicts:

	Marlin/Configuration.h
drakelive e5c39b7c2a commit
ZetaPhoenix e8c92e0a95 Missing #else in temperature.cpp prevented reading bed temp when TEMP_BED_PIN <7. Thanks to Leland Wallace for helping me track this down via "Sesame Street" coding (what is not like the other)
drake bf2071871c Merge branch 'Marlin_v1' of https://github.com/Drakelive/Marlin
drake fc32e20881 first commit
Erik vd Zalm abf0693e8e Added KILL_PIN -1 to gen7 boards
Erik vd Zalm 47319cf64e Fixed typo in SF arc fix code.
Erik vd Zalm e358a2d7af Added fix for SF Arc Point fillet procedure
ErikZalm 044a64a1fb Merge pull request from Justblair/Marlin_v1
Added PDF file containing Menu Tree for documentation purposes.
Drakelive d728e35658 Update Marlin/pins.h
tonokip 1c1fddc7ac Added support for the Rambo reprap electronics board. Added Mcodes to set
motor current and microstepping pins.
Blair Thompson dcd3e8a211 Tidy up
Blair Thompson ddd9d0cfd4 Added PDF file containing Menu Tree for documentation purposes. Source xlsx document included.
Erik vd Zalm 0e58ef6805 Some dialogs are corrected
Erik vd Zalm 0e89022cc3 Correct temptable_55 name.
Bracken Dawson 47d4f55bc0 Fix Gen7 1.4 pinout
Gen7 1.4 uses very different pin assignments, might as well make a new
section and remove some of the conditionals from each. It's easier to change
your pin assingment this way if like me you don't wire it exactly to plan.
elgambitero 6cd150842f Update Marlin/language.h
Some dialogs corrected and Default language set to 1
elgambitero 299c18596f Update Marlin/language.h
Some dialogs are corrected
ErikZalm b86336c3f5 Merge pull request from daid/Marlin_v1
Long filename support for LCD display
daid b69e75c89a Added long filename support.
stohn 1d224cc031 merged with upstream and FIXED AGAIN bad translation commit
PLEASE BE MORE CAREFUL WHEN SUBMITTING NEW TRANSLATIONS

When you add new menu items / messages always copy them to ALL
languages (just use english)
stohn 06c03fe2f0 new method for message for making KILLED message visible
The cli(); at the start of the kill() function also stops the internal
arduino timer which stops updating of millis() which prevents the
display of the "KILLED." message.
The new function updates the display directly without checking any
timers.
daid 87ff61a8a6 Fix for
Blair Thompson aacbebbebe Added Menu Options to the Main-> Control->Temperature Submenu that allow the user to set new values for the ABS and PLA preheat function. EEPROM updated so that these settings can also be committed to EEPROM memory.
stohn 31873ec707 changed int to long to overcome overflow of number display
- related bug reports: Issue , Issue 
stohn de0448343f added KILL_PIN support / cleaned up manage_inactivity function definition
stohn 69961dbba3 fixed incorrect menu messages from last commit...
- removed several multiple definitions of same message
- fixed definition of missing messages in german and spanish
- tweaked german translation (a lot)
- added note about changing and testing this file
Blair Thompson 6c050b8440 Fixes error introduced at commit aee475aa55 which caused the sketch not to comile for language option 1. Several defines were removed but still referenced in ultralcd.pde
Blair Thompson b9f9f8f7d3 The pre-heat ABS and PLA options in the LCD Menu were broken a while back. The pre-heat worked fine, but the cooling fans were not switching on as intended. This is now fixed.
elgambitero d38b96fff1 Update Marlin/language.h
Erik vd Zalm 9f7f7354f5 Set default language 1
elgambitero aee475aa55 Update Marlin/language.h
Spanish language included. It features the LCD screen messages and a small part of the Serial messages.
Erik vd Zalm 9083966c22 Do not use feedrate multiiply on Z and E only moves.
Erik vd Zalm 5406c533db Disable FAST_PWM by default. On some systems it does not work ok.
Erik vd Zalm f92dc91c3d Enable M503 also when eeprom is disabled
James Adams 35a1dd081f no message
James Adams 5131ab19ca Fixed Retract in LCD Menu
James Adams 96f4f90cb3 Added pause and retract lcd menu items
James Adams e10355500d Updated Language.h with pause, resume, and retract
ErikZalm a97c006bbf Merge pull request from kobaan/Marlin_v1
Updated german translations in language.h
ErikZalm f062794a0d Merge pull request from Enchiridion/Marlin_v1
Added support for dual Z axis stepper drivers
ErikZalm 57468d3c21 Merge pull request from Dabble63/Marlin_v1
Add Duty Cycling to the Heater Bed
Dabble63 6b45e9f167 Add Duty Cycling to the Heater Bed
Ian Jackson adee81170d M206: save values in eeprom
Really, we should have a way to adjust the XYZ homing of a machine in
the eeprom.  So as the second stage of this, make the M206 home offset
parameters subject to the M500/M501/M502/M503 eeprom commands.

Bump the eeprom version to "V06".

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
Ian Jackson 1dba212e18 HOMEAXIS: make into a function
Replace the large macro HOMEAXIS with a function.  This avoids the
compiler generating three copies of largely identical code.  The
saving is 724 bytes of program memory.

We make use of XYZ_CONSTS_FROM_CONFIG to provide convenient
array-shaped access to MAX_LENGTH, HOME_RETRACT_MM and HOME_DIR.

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
Ian Jackson 7bb326d389 eeprom: provide smaller code for SERIAL_ECHOPAIR
SERIAL_ECHOPAIR implies, eventually, two calls to MYSERIAL.print.  One
of these has FORCE_INLINE for a per-character loop, and both involve
constructing a method call rather than a simple function call.

Produce better and smaller code by providing three specialised
functions serial_echopair.  This saves 672 bytes of program memory
(with EEPROM_SETTINGS and SDSUPPORT enabled).

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
Ian Jackson 957e966d2d M206: always use homing ("homeing") offsets
Previously the parameters set in M206 would only be used if a G82
command was sent with specific axis home values.  This limits its
usefulness.

Really, we should have a way to adjust the XYZ homing of a machine in
the eeprom.  So as the first stage of this, make M206 affect every
home command.  The values set using M206 are now added to the
configuration variables [XYZ]_HOME_POS.

This is achieved by replacing all uses of [XYZ]_HOME_POS in the code
by a new home_pos[] which includes the adjustment.  We also have to
adjust the uses of [XYZ]_{MIN,MAX}_POS similarly - see below.


To allow axis_is_at_home to be written as a function taking an axis
index rather than a macro taking an axis letter, we provide
constant arrays in program memory containing the values of
[XYZ]_{MIN,MAX,HOME}_POS from the compiled-in configuration.

This is done with some helper macros to deal with the declaration
(XYZ_CONSTS_FROM_CONFIG) and definition of the inline function which
does the program memory access.

We also introduce the overloaded function read_pgm_any, whose
instances are produced with DEFINE_PGM_READ_ANY, which allows the
access functions to automatically produce the correct type.

The type- and pointer-massaging code in the access function boils
down, when compiled, to a simple program memory access.


A question arises: if the M206 offset is set, should this adjustment
to the home position shift or change the possible range of movement
permitted by the software endstops ?

The documentation in Configuration.h describes these limits as:
    // Travel limits after homing
Since this is a file containing physical limits, and actual suggested
values for these configuration parameters appear to include a certain
amount of slop, I've taken the view that these should be regarded as
nominal physical distances from the limit switches, and that the
permissible travel should be unaffected by M206.

So for example with the (rather unrealistic)
  #define X_HOME_DIR -1
  #define X_MIN_POS -20
  #define X_HOME_POS 0
  #define X_MAX_POS 100
no matter the setting of M206 X, the machine would be permitted
to move from 20mm "beyond" the limit switch trigger point in
the negative X direction and 100mm away from the limit switch in
the positive X direction, for a total travel of 120mm.

With M206 X-10 that would be considered to correspond to X coordinates
-30 to +90.  With M206 X+10 that would be considered to correspond to
X coordinates -10 to +110.


fixes  (in ErikZalm/Marlin).

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
Ian Jackson faccb35850 software_endstops: use *_MIN_POS and *_MAX_POS for arcs
If [XYZ]_HOME_POS and [XYZ]_MIN_POS aren't 0, these corrections are
wrong.  Use the same logic as in Marlin.pde:prepare_move: ie, clamp to
[XYZ]_{MIN,MAX}_POS.

While we're here, put this cut-and-paste code in a function
clamp_to_software_endstops.

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
Ian Jackson 3f15b7c7b8 Makefile: Better display of size (device memory usage)
Run avr-size with the --mcu=... -C option as well.  That reports how
much actual device program and data memory is used along with a
percentage fullness.

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
Ian Jackson 0c35facc94 Makefile: support V=1
Often it can be useful to see the actual commands being run by make.
Other projects (eg, the Linux kernel) support this with a "V=1" make
parameter.  Do the same here.

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
Ian Jackson 71404eef29 .gitignore: Add *~, *.orig, *.rej, move to root directory
Move the .gitignore out of the Marlin subdirectory so it applies to
the whole tree, and add some missing patterns.

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
Ian Jackson a873541ef6 Marlin.pde: include comment for emacs mode
Emacs by default doesn't recognise a ".pde" file as C++ source code.
Add the annotation to the top of the file to make it work.

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
Enchiridion 50cde90324 Added support for dual Z axis stepper drivers
kobaan 603a5e25b3 Updated german translations in language.h and eliminated a few double lines.
Chris Palmer 538189cc19 Fixed soft limits when the origin is in the middle.
HOME_POS is now always where the endstop is and can be outside the limits.
The limits are now defined by MIN_POS and MAX_POS rather than HOME_POS and MAX_LENGTH.
The Z is axis now homed first if direction is away from the bed.

Saguinololu limit pins change from MIN to MAX according to the homing direction.
ErikZalm 686011a548 Fixed typo
Erik van der Zalm cd57bf305b Merge git://github.com/daid/Marlin into Marlin_v1
Added invert step pins to corexy code
Erik van der Zalm ea2c19f978 Added CoreXY support (Thanks Ilan Moyer)
Erik van der Zalm aa65fe22ed decoupled axes sucessfully at least on pure x or y jog
daid 12de8fff81 Support step motor controllers with active low step pins.
Erik van der Zalm b67dacdc8f Fixed AD595 define
Bernhard d3002ef741 corrected retract
Bernhard 0c123950e9 __ header file replace
Bernhard bf077125b9 added firmware retract. disabled by default
Bernhard 0e5e249ab5 added individual pullup setting option to have finer control in case there is a special z-min sensor, for example
Bernhard Kubicek 6b14f95b3e Merge pull request from linagee/Marlin_v1
Marlin v1
Bernhard Kubicek c7ce99d495 Merge pull request from daid/Marlin_v1
Add M401 - Wait for user to press button on LCD (with optional timeout) minor fix in M115.
Bernhard Kubicek b7fc14bc65 repaired thermistortable_6 by graphcial fitting of the off-slope values. see issue 179. Erik, I know you asked for no changes, but this file probably is not related and hopefully allright.
ErikZalm 9e1021efbe Fixed SL bug.
Daid e9bec9b6fe Fixed E1_ENABLE pin for Ultimaker. This was wrong for the 1.5.4 and 1.5.3 PCB (I cannot check the 1.5.6)
linagee fbd282b3ba Update Marlin/Configuration.h
linagee 2e8c5049c5 Update Marlin/thermistortables.h
linagee 2d0d8e5272 Small correction.
Daid 4d7fe7115f Changed M401 to M0/M1 as suggested, so they match normal CNC stop commands.
linagee 9e9db65c3f Update Marlin/thermistortables.h
linagee bd966ef389 Update Marlin/thermistortables.h
linagee 775da3f103 Added top ratings and extended to ADC=1 for table 3 and 5.
linagee 96a4baa0be Update Marlin/thermistortables.h
linagee 2aa9f7b131 Update Marlin/thermistortables.h
linagee c4490f5f3d Update Marlin/Configuration.h
linagee dd9144994e Tested May 19 - It works! Verified with separate thermocouple TM-902C also.
linagee 4c37d0d9f1 Extended range above 250C. (Operating range states up to 300C)
Daid b59724e42b Add strigification for extruder amount in M115 report.
Daid 16413bb8f2 Last M401 update, refresh the LCD during an M401 wait.
Daid b3941fce5c Update after testing
Daid d494688565 Do not initialize in the header file.
Daid 516ec90242 Add M401 - Wait for user on LCD button press
Daid 7244aa7eb7 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
linagee de2ca3b2e8 Grammar correction.
linagee c2fc466e1b Update Marlin/Configuration.h
linagee 241f5a4c0e Update Marlin/thermistortables.h
linagee 9f9f498491 Update Marlin/Configuration.h
Erik van der Zalm e31bef31ad Limit PID autotune PWM to PID_MAX
ErikZalm b2a9ccdb97 Merge pull request from MaikStohn/Marlin_v1
Marlin v1 - BUG FIXES / CORRECTIONS
Erik van der Zalm d459fb41b7 Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
ErikZalm 804e0d6117 Merge pull request from guanix/Marlin_v1
Melzi support
Erik van der Zalm ba96059203 add additional dropsegments test
zittix fbd91ab0b5 Fixes for bad call to abs()
MaikStohn b51c06e2b3 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
MaikStohn 159ae90874 bug fix for scrolling of main menu when using SMALL_DISPLAY (2 lines only)
MaikStohn e48f5aa6a7 fixed typo
MaikStohn 1efe9ab497 changed encoder pos from int to long to fix problems setting x/y/z/e stepps_per_mm using the lcd menu
Guan Yang 602c8ee02b Melzi support
Daid 279d00da9f Fixed #if for Ultimaker.
Bernhard Kubicek 451f9cc6d1 Residual in the comments: there are no more mm/minutes but only mm/sec in the planner buffer.
Erik de Bruijn e3fe1f0d00 Made a more granular configuration possible PREVENT_LENGTHY_EXTRUDE. You can now decide to allow/disallow large length of extrusions to be executed.
Turning off the protection might be beneficial to those who want to do fast and long reversals.
Erik de Bruijn d88205d89d Suggestion to improve (TODO), no actual code changed
Erik de Bruijn 5aa80e6c05 Made language.h more flexible. Automatically do the right defines based on MOTHERBOARD == 7 ? "Ultimaker" : "Mendel"
MaikStohn b657a18449 Revert "magic PROGMEM defines to avoid hundreds of wrong GCC warnings"
This reverts commit 3682d9bd5b.
MaikStohn d188ae4c9d added missing declaration of buttons_init()
This is required when moving the buttons_init() function to the
lcd_init() function
MaikStohn 3682d9bd5b magic PROGMEM defines to avoid hundreds of wrong GCC warnings
MaikStohn 032df0b2c6 Moved LCD initialization out of constructor
Since the class "MainMenu" was used within a static variable the
initialization of the object (constructor call) was done before Arduino
library startup. It always caused a crash when using AVRStudio with
JTAG debugger (caused from calling the LCD initialization / the lot of
I/O work / the stack used during this calls). By moving the LCD_INIT
out of the constructor and using an explicit call inside of Arduino
setup() implementation immediately fixed all problems and the JTAG
debugger runs fine.
MaikStohn bd1ad7c76a explicit includes to make it compile with AVRStudio/Eclipse
MaikStohn 060b38de5c delete obsolete and wrong code
"i" runs from 0 to 4 but "add_homeing" array size is 3 only. On the
other hand the calculated value gets overwritten by either one of the
if choice.
MaikStohn 789ba02d43 fixed typo in comment
Erik van der Zalm 1874cb71a6 Added option to increase the FAN PWM frequency.
Erik van der Zalm 6a5a34e0ff Small cleanup
Erik van der Zalm e3821bd86f Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
Erik van der Zalm 02af69911e Added temperature window to M109. This is needed for systems with no overshoot PID.
ErikZalm e203b8c754 Merge pull request from daid/Marlin_v1
Added 2nd extruder temperature LCD readout and setting.
ErikZalm 362ddc4efc Merge pull request from Atntias/patch-1
adding M120 and 121 for turning on and off the endstops only for homing
sefi c27081aa4a Fix to allow M120/M121
sefi e11e072eca adding M120 and 121 for turning on and off the endstops only for homing function
Daid 8e68c6cf89 Show proper temperature for extruder 2
Daid 8503b78876 Added support for 2nd extruder temperature to UltraLCD
Logan Bowers 3eacb4c16d Wrap the call to turn off the bed heater in a #if to prevent a compile error on boards that do not have a bed heater
Bernhard e4d2138dbd reinitialize the lcd, if the SD card is inserted or removed. It seems that LCDs can confused by electrical discharges from time to time.
Since a removal or insert of the sd card takes a long time in firmware, just reinitializing the lcd does not hurt.
actually, it solves a problem with the UltiControlle
Bernhard 464b755918 added support for the UltiController
Bernhard 44fd8d46d2 fixed quickhome
Bernhard 33bb044d7c fixed catsting to (int)e in serial error messages.
see https://github.com/ErikZalm/Marlin/issues/148
ErikZalm c2557abc03 Merge pull request from triffid/fix-makefile
make should rebuild if configuration or Makefile is changed
Erik van der Zalm 67cf105bc6 Fixed AUTOTEMP (M109 S215 B260 F1 starts autotemp)
Changed SLOWDOWN. IF this does not work ok OLD_SLOWDOWN is the old algo.
Erik van der Zalm 8aee9d51b6 Disabled disable_heater in PID_autotune.
Daid 414408b2d0 Fix for wrong systax in #ifdef.
Michael Moon 77d503fa13 Fix Makefile
Erik van der Zalm cf7c8c458f Fixed MAX6675
grrf 03b0850e63 This breaks temperature readout for pronterface!
tgiphil ad8bc71d3e - Fixed a typo
Erik van der Zalm 46feae79c6 Fixed typo in arc
Erik van der Zalm 4ca2f336f0 Changed default MINIMUM_PLANNER_SPEED -> 0.05
Fixed small bug in arcs
M105 prints now actual_temp/target_temp
Erik van der Zalm ae0bf8068b Fixed arc offset.
Erik van der Zalm 0c1b863755 Ignore ":" in comments.
Erik van der Zalm 63aec3c56e Replaced Kill by Stop. If the printer is stopped. Fix the error and use M999 to restart.
Moved the PID_dT in the Ki and Kd calculation from the configuration.h to temperature.cpp
ErikZalm 8b785f75a6 Merge pull request from buserror-uk/for-upstream
For upstream
Tommy Cheng 520f1a54a8 Fix compilation error when PIDTEMP is undefined and ULTIPANEL is defined.
Michel Pollet 5550e893d5 New board variant, Open Motion Controller
Open Hardware board currently used by the group build of http://tvrrug.org.uk
The board can be found at http://solderpad.com/folknology/open-motion-controller/

Signed-off-by: Michel Pollet <buserror@gmail.com>
Michel Pollet aa6e6e914e Makefile: Redone
+ Removed most explicit pathnames, use the standard make "VPATH" to let
make find the files for itself.

+ Added a "hardware variant" variable that allows compiging Sanguino and
Gen7 as well as "generic" arduino.

+ Allows overriding the MOTHERBOARD define from the Makefile

+ Removed the 'preprocessor' bit that wasn't needed, now just "include" the
files that are needed, since it allows gcc to show the right file/line
when displaying error/warnings.

+ Uses gcc's own dependency generator to generate the .d files, and
and include these instead of self-patching the makefile

Signed-off-by: Michel Pollet <buserror@gmail.com>
Bernhard 0183e6332a made prepare->autostart independent of current folder.
Bernhard 1532200435 found error in filenames.
One array was too short. This had nothing to do with long filenames, other than if they were 12 characters exactly, which could only happen if the extension and the text before were filled completely
Erik van der Zalm b985e4a134 Fixed compile errors in ultralcd when no ultra_lcd is selected.
Erik van der Zalm 2e749d60c3 Added DISABLE_MAX_ENDSTOPS
Erik van der Zalm 33f5697888 PPID tune exports more constants.
Erik van der Zalm b44055cc51 Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
Erik van der Zalm f5eae52098 Added more manage_inactivity checks
ErikZalm 19a47dae4a Merge pull request from Justblair/master
Better pin configuration for rotary encoder in RAMPS boards
Erik van der Zalm 910f4e77a2 Added 20MHz support.
ErikZalm 7cefad3744 Merge pull request from bgamari/Marlin_v1
Make F_CPU dependence of stepper.cpp more explicit
Erik van der Zalm 87ff2f8867 Added CONTROLLERFAN. (Controlling a fan to cool down the steppper drivers)
Erik van der Zalm 387fe51a56 Do not disable steppers when there are moves in the queue.
Erik van der Zalm 421264e58a Fixed typo
Erik van der Zalm 15ad923310 Removed !!!. Stupid arduino bootloader can't handle this.
Erik van der Zalm 61e09e6be2 Added FAN_PIN -1 checks
Erik van der Zalm 87c4e06c24 Corrected active_extruder when autotemp is used.
Erik van der Zalm 7b1e295f34 Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
Erik van der Zalm c077316b2b Added PID autotune. (experimental)
M303 Starts autotune. Wait till the Kp Ki and Kd constants are printed.
Put these values in Configuration.h
Ben Gamari 49b228c4b3 Add instructions to regenerate speed_lookuptable when changing F_CPU
Ben Gamari 96509494f0 stepper: Clarify comment on timer-counter configuration
Ben Gamari 6d7e6a11fc Add create_speed_lookup
Tommy Cheng ce07c9186d While Waiting for hotbed to warm up via M190, LCD Display and Click Encoder input freeze until target temperature is reached.
Erik van der Zalm 116dc86b8a Fixed type in e-jerk
Blair Thompson 02ee9e3d30 Changed Pin Assignment for the RAMPS motherboard so that LCD and Rotary encoder are all wired to AUX-4
This simplifies wiring for those with RAMPS 1.3 and 1.4 boards.
Erik van der Zalm e056bf8081 Added E-Jerk
Erik van der Zalm 4deeffbc88 Added missing defines to the german section.
Translation still needed.
Erik van der Zalm 632528aa95 merging with SCUBA82
Erik van der Zalm aac7aa3bf0 Queued fan control. Issue
Christian Thalhammer fde51084f3 set SD file delete to M30; switch printime output to M31
Erik van der Zalm 21e2bae063 Changed (corrected?) SD_card comment handling.
Erik van der Zalm e509bbf636 Merge branch 'Marlin_v1' of github.com:ErikZalm/Marlin into Marlin_v1
Erik van der Zalm 072011a3ef Added current_block = NULL to quickStop()
ErikZalm 2422a857a1 Merge pull request from haxar/Marlin_v1
make analog2tempBed return a precise celsius reading for BED_USES_THERMISTOR, ...
Erik van der Zalm f598077af3 Removed vc files
Erik van der Zalm cb0c84e075 Merge remote-tracking branch 'justblair/master' into Marlin_v1
ErikZalm 1d5809d458 Merge pull request from daid/Marlin_v1
Made plan_buffer_line arguments const...
Erik van der Zalm ed951b1977 Fixed RAMPS 1.2 support (Found and fixed by rrhb)
Blair Thompson 4879de08e8 The percent complete for the SD file statistic sits squint. Changed "lcd.Setcursor (7,2);" to "lcd.Setcursor (10,2);".
The percent complete now lines up with the temperatures and Z-axis position figures, nicer to read and nicer to look at IMHO.
Blair Thompson f278e1c00f This is in my opinion a much better way of dealing with SD cards than my previous fix.
Instead of adding a momentary switch to fake the insertion of the card I have modified the ultralcd menu item:

Card Menu -> Refresh

to reinitialise the card providing that the SDCARDDETECT pin has been set to -1 in the pins.h file.  This requires one less switch on the front panel and the refresh menu item is in the most relevent place for a user who wishes to inert a card and then print from it.

It also means that the "Card inserted" messages do not bother the users of these card readers (they dont make sense for users without SCCARDDETECT)
Blair Thompson 046a8e0039 Added more defines to the language.h file so that nowe most of the text strings are now configured via this file. Still got some hunting down to do to complete this task.
haxar 79a466ca26 make analog2tempBed return a precise celsius reading for BED_USES_THERMISTOR, complementing changes to analog2temp in d15f01e
Christian Thalhammer 5f3a422e68 added M31 - delete file from sd card
Christian Thalhammer fa2e3a40e9 fixed LCD manual z axis move Feedrate to 70 (was 1700)
Christian Thalhammer a92b3afe64 added german translation;Menue should be in english.. sounds better
Christian Thalhammer 9fa586bbed fixed languages; Preheat_PLA and Preheat_ABS was not defined for non
english
Daid 00d33e6b82 Typo fix
Daid 7d124478fa Only protect the heater pins for the defined extruders.
Changed the way the extruder pins are defined so it doesn't create extra -1 entries in the list.
Daid 3d83109028 Fixed general 16x2 LCD build without SD support.
Christian Thalhammer cb02914687 Merge remote-tracking branch 'upstream/Marlin_v1' into Marlin_v1
Christian Thalhammer 10bf2bb8e1 -
Daid d47b666630 Merge branch 'Marlin_v1' of git://github.com/ErikZalm/Marlin into Marlin_v1
Daid 88d289caa1 Made plan_buffer_line arguments const, which optimizes better and fixes the RUNOUT_PREVENTION feature.
Erik van der Zalm b4833d55c2 Fixed HOME_POS in combination with G28 X0 or G28 Y0
Erik van der Zalm c6f2ec3c82 remove stop_heating_wait
Erik van der Zalm b48d67ce10 Fixed homing
ErikZalm 071eec7aa7 Merge pull request from phord/09469add5560ca8a676c42e4bcd499868c33f0dd
Clean up and add some trace info
ErikZalm 1ebe7d1ab6 Merge pull request from phord/tempfix
Add explicit #define for bogus temp override
Phil Hord b65ef8d66c Add support for upcoming Gen7 v1.4
V1.4 moves thermistor power to the always-on 5v line.
The BOGUS_TEMPERATURE_FAILSAFE_OVERRIDE is no longer
needed on this board.  Add a new motherboard type to
support this feature.
Phil Hord 740f0c7690 Add explicit #define for bogus temp override
The code to ignore the "bad thermistor reading failsafe"
suicide function depends on the existing of the PS_ON pin
feature.  But in some boards this shouldn't be the case
Fix this by adding an explicit definition to make our
intentions more clear and separable.
Phil Hord ba8500a236 pins.h: Define Z_MAX_PIN for Gen7 board
The Z_MAX_PIN value was defined as no-value, but this causes
the compile to fail.  Fix this by setting the Z_MAX_PIN to the
correct value (which happens to be 0 for pin PB0/DIO0/0).
Phil Hord 09469add55 Add board reset reporting (from Repetier-Firmware)
Phil Hord f3101e96d9 Add suitable .gitignore to avoid build noise
Phil Hord 245dca4bee Makefile: generic pde=>cpp rule
This adds flexibility to the makefile by allowing different pde
targets to be specified for different needs.
Erik van der Zalm 97d42ca2b2 SDSUPPORT default disabled
Changwoo Ryu 7b14953c99 Fix build on Sanguino based boards with ATmega1284P
Daid 286d5003fa Fixed compiler warning for Sanguino compile
ErikZalm 66d50562b6 Merge pull request from iXce/Marlin_v1
Fix Makefile
Erik van der Zalm 27f595a444 Changed version => RC2
Erik van der Zalm 018c567abf Moved SLOWDOWN function. (jetty840)
Included AD595 calibration options. (daid)
Erik van der Zalm 4fbda5c3f5 Merge remote-tracking branch 'daid/Marlin_v1' into Test
Erik van der Zalm ce714fe306 Fixes in pins.h
Erik van der Zalm 35e57bf149 Added gen6 deluxe.
Erik van der Zalm 84ea2d61e8 Moved gen7 boards to motherboard type 10, 11 and 12.
Split ramps1.3 in Sprinter like config and multiextruder config.
Guillaume Seguin adc108d79e Correctly build the produced applet/Marlin.cpp source
Erik van der Zalm 5aa9c41ab1 Changed comment mode for detection.
Added M221 extuder multiply factor.
Erik van der Zalm 00690f7ffd Fix cast warning in Gen7
Erik van der Zalm 01d28c18ab Fixed casting warning in sanguino
Blair Thompson 2fd8c248fe Added Fan control to the pre-heat settings.
I find that the PID routine works better when the cooling fan is switched on
at the beginning of a warm up routine.  Otherwise when you enable the fan
just before a print, you have a delay as the PIDre-adjusts.

This should also be safer as most cooling fans are directed at the hot -ends
thermal barrier!
Blair Thompson d9f2f509d5 Added new menu items under the prepare submenu.
Instead of a single pre-heat, now there is pre-heat ABS and PLA options
Added defines to the configuration file to adjust preheat temperatures for both
Erik van der Zalm ae3e7586c6 Added HOME_POS. This adds the posibility to make the center 0
Updated the Xsteps ... settings via the LCD menu
Erik van der Zalm df1437bd86 Changed display format for some numbers.
Erik van der Zalm 8816ef1c64 Small fixes after merge
Erik van der Zalm d298dd121f merged SBUBA82 and Justblair
Erik van der Zalm 2cc9a89830 Merge remote-tracking branch 'SCUBA82/Marlin_v1' into Marlin_v1
Erik van der Zalm a0a1f81913 various changes
Christian Thalhammer 8a8ea50f33 fixed manual axis movement lcd option
Blair Thompson b976692d0f Removed VS project files for tidyness stakes
Blair Thompson fe940a142d Added a structure that will allow easy translations/modifications to the LCD menu.
Signed-off-by: Blair Thompson <mail@justblair.co.uk>
Christian Thalhammer b3fb09a20c change preheat to ABS values of nozzle 227 and be 105 �C
next try for manual axis movement
Blair Thompson a05a261b72 Added a workaround. Ramps SD card does not have sdcarddetect. My temporary solution is to add a momentary swtich
that pulls down the SDCARDDETECT pin and mimicking the pull and reinsert ofa a SD card
Blair Thompson 1b6765ed12 Updated the pin config for RAMPS 1.3 to include ultimaker new style LCD/Rotary Encoder interface
Christian Thalhammer 1ff99ae25f ATMega1284P support for Arduino IDE
replace $ARDUINO_HOME/hardware/tools/avr/etc/arduino.conf with this file
Christian Thalhammer e661578c84 support for GEN7 1.1,1.2 and 1.3
Daid 73344e69c1 Added temperature offset/gain settings for AD595.
Christian Thalhammer d309565b56 Merge remote-tracking branch 'upstream/Marlin_v1' into Marlin_v1
Conflicts:
	Marlin/Configuration.h
Christian Thalhammer 0e3631ff4b smaller changes
Erik van der Zalm fa2e1be0ca changed default EXTRUDE_MINTEMP to 170.
Erik van der Zalm 7699f250e3 Fixed small merge bug
Erik van der Zalm 11518a987f merged with triffid fork
Erik van der Zalm 13e185d330 removed unused HEATING_EARLY_FINISH_DEG_OFFSET
Simplified stepper inactive time
Erik van der Zalm b58eae7657 Corrected e-length calculation in planner
daid 2a77c84c8f Updated SERIAL define to MYSERIAL, because Arduino 1.0 defines SERIAL as 0.
Erik van der Zalm d47a3e5950 Changed check i mtion_conrol
if (millimeters_of_travel == 0.0) => if (millimeters_of_travel < 0.001)
(thanks mooselake)
Erik van der Zalm f87c80889f Fixed M109 timer overflow (reported by triffid)
Erik van der Zalm 154de69c02 Print configuration.h version during startup (thanks hairykiwi)
Erik van der Zalm 6ef8459494 Corrected distance calculation. (thanks jv4779)
Erik van der Zalm 598eb1d4f1 Fixed compilation for gcc-4.6.2 with avr-lib-1.8.0 (thanks daid)
Erik van der Zalm 9173a5713b Teensylu support.
Erik van der Zalm da040fd393 Fixed ultimaker heater 1 pins. (Thanks daid)
Erik van der Zalm bdb70c0509 Warning for 10k thermistor
Erik van der Zalm 5113513cb2 RC 1
Erik van der Zalm d8a0c6450f Split the configuration file in two parts.
One for common settings.
One for advanced settings.
Christian Thalhammer 4cc8e37bf1 lcd menue "move_axis" added
Christian Thalhammer b5fae1104b fixed sUICIDE_PIN disable
Erik van der Zalm f9c5333f97 Made "stop heating wait" optional.
Default off.
Erik van der Zalm 292ddd2edb Fix Z_LATE_ENABLE
Christian Thalhammer 25cd8af536 added arduino ide GEN7 support Files
Christian Thalhammer 14702089ee -disable TEMP Min MAX Kill while using PS_ON Pin
ON GEN7 there is no temperature reading when power is off.. so Marlin
would kill itself. There seems to be an update from "Traumflug" on GEN7
using standby VCC for thermistors.
Christian Thalhammer b51e8bf7e5 -disabled CARDDETECT if PIN is set to -1
- redo disable Beeper if PIN is set to -1
Christian Thalhammer 3183a14755 -added Configuration for GEN7 which worked for me
Christian Thalhammer 5edef148fe -disalbe beeper if BEEPER_PIN = -1
Christian Thalhammer 13e2ad2831 - added info for using GEN7 configuration
Christian Thalhammer 59cc5f889e - added support for ATMega1284P
Christian Thalhammer a11f3b2d2f - Pins for modified GEN7 assigned
- Added support for ATMega1284
Erik van der Zalm abb7e63906 fixed z-disable bug.
Erik van der Zalm 9f139d6e0e Added MAX6675 support. (Thanks to gregfrost)
Needs some work to remove the blocking in read max6675.
Erik van der Zalm e45e5c68bb Added support for Gen3+ (Pins file only)
Added late z enable. (blddk request)
Only calculate look ahead if >2 moves in buffer.
Removed some FORCE_INLINE to save memory.

Signed-off-by: Erik van der Zalm <erik@vdzalm.eu>
Michael Moon 9c918a497b more work on Makefile - actually rebuilds if Makefile or Configuration.h are altered, also much cleaner output
Michael Moon ab01658fd2 local configuration stuff- WATCHPERIOD causes breakage, disable. few other misc changes
Michael Moon 42bedb3f60 PROGMEM elements must be const
Michael Moon a991bde523 enable auto-reset before programming, disable afterwards
Michael Moon 3e575533c5 get M81 working
Michael Moon 2ae2ead97b help residency not overflow
Michael Moon 71dc82e0b4 my local configuration
Michael Moon 5aadc2f5ca cardreader needs to include some other files
Michael Moon 8d0916af13 allow Marlin to actually compile with Makefile pulled from Sprinter and a few other modifications
haxar 6cc6029d7a M109 EOL fix when TEMP_RESIDENCY_TIME is undefined; printer interface (pronterface) could not see target extruder heater temperature to continue print
Bernhard 157aa7f2fd m115 eol fix
Bernhard 7aeb45303d small mistake
Bernhard cee5f9020a added suicide pin for a power supply to the arduino that is only active if the arduino is holding high for an output.
Bernhard 3814bbb529 made sd code only compile with SDSUPPORT defined. safes 10k of codespace
Bernhard 729cde4475 fix autostart failure if in wrong directory
Bernhard 396270a0de fix duplicated definition of MOSI MISO pins in case motherboard==33
Bernhard 11f2dafc4e one step closer to a functional makefile..
Bernhard 8463e39a4a starting with sanguino arduino 1.0 compatibility
Bernhard 2bc160a978 add wiring.h, that can be used to overwrite:
arduino-0023/hardware/arduino/cores/arduino/wiring.h
this is necessary if the avr libraries are recent, but arduino is old. Alternative: newer arduino
Bernhard 57f9359a41 simplified the includes, makefile now works with arduino23
Bernhard 3c1a4aac2b header file simplification
Bernhard 212515148e added m240 photography support. default off
Bernhard 6735025428 cooldown
Bernhard 415aadf704 lcd panel bed support
advance and ultipanel not any more in default config
Erik van der Zalm 554cc1718d Fiexed E_ENABLE_PIN errors
Erik van der Zalm 617968ab76 G92 fix
Erik van der Zalm 84d9cf7339 merging
Erik van der Zalm e017228569 Merged multiple extruder support.
Soft PWM. (Sanguinololu can also have PID temperature control)
Interrupt save WRITE for addresses > 0x0FF
Bernhard 3320a5b37d make autotemp compatile for use without pid
Bernhard 06411d5c9e ultralcd can now also stop the wait loop for the hot-end m109 heating when stopping sd prints.
Bernhard 82c99625fa instant stop of sd prints from the panel.
Bernhard 01001b89d2 repaired nozzle runout prevention to not collide with automatic stepper disabeling.
Bernhard 88ee053af0 heating up santity, formarly knows as "watchdog", but renamed due to the existance of the real watchdog, works now.
Bernhard b1d84d879b st_synchronize back to normal..
Bernhard Kubicek f6fe7143e4 Merge pull request from k-eex/Marlin_v1
Fix M201 not saving settings in all places, so the changes did not get written into EEPROM
Bernhard dde4b40fa9 disable steppers in runout prevention
Bernhard 2bc5e7ec9e prevent too long extrudes, or too cold extrudes
Bernhard aa4f9a6474 better values.
Bernhard 87fd249c43 made runout prevention independent of tempeorarily set esteps
Bernhard 1ec0c3b68a extruder runout prevention.
Bernhard 5b4625f79c added a partial release option to "m84" aka "stepper release". If you do tiny layers, you might want to keep the z-axis powered to not loose height positioning after homeing.
Bernhard cc4a9cdb69 added autostart procedure trigger to the ultralcd menu
Bernhard 61c943b4bf fixed the st_synchronize. it would have continued if there is only the last move of the buffer being stepped.
Keegi bae1e422f6 Fix M201 not saving settings in all places, so the changes did not get written into EEPROM
Bernhard 754d2d69b2 z homing sound fix, for now until the actual cause is found..
Bernhard 986f0ba76c moved <stdio.h> to more dominant location.
Bernhard 460b788d78 repaired homing position setting.
Denis B 4fd75dc813 Working version of multiple extruders (up to 3)
- The temperature control is pretty much complete
  (not sure what to do w/ autotemp though)
  Changed the pins assignment to clearly separate bed and extruder heaters
  and temp sensors, changed a bit how termistor tables are handled.
- The steppers control is rudimentary
  (only chanages what pins it uses depending on the active_extruder var,
   but that's enough for switching extruder in the start.gcode in the
   the profiles)
- Tested only w/ RAMPS 1.4
Bernhard 12e8edcac3 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard cf50ba140f added M503 to display eeprom storage, and renamed eeprom routings. This version is compatible with the qtmarlin eeprom-tab.
Erik van der Zalm 89e832c295 Update endstops only for homing. (use less resources when not used)
Erik van der Zalm b99c49ec3b Add option to only check endstop when homing
Erik van der Zalm 95a0b28acb Merge branch 'Marlin_v1', remote-tracking branch 'origin/Marlin_v1' into Marlin_v1
Erik van der Zalm af22e9cd38 Some advance modifications
Bernhard 7714b98da7 solved some compiler warnings that are now visible in arduino 1.0.
Found a couple of unused variables, that I commented.
Tried to solve the program memory warning message, and failed.
Bernhard dfd240b260 overworked autotemp, removed one layer of nesting from the ultralcd.
Bernhard 4f909963e4 make QUICKHOME configureable
Erik van der Zalm 6b86f15686 More 2nd extruder implementation. (Not usable)
Advance (not tested)
Bernhard 0bc9daa4f7 make it compile with arduino 1.0 ; function is still untested.
Bernhard b0c3871750 more fixing of the sanguino math round problem
Bernhard 9c57453168 removed stream.h referenece from marlinserial.
Bernhard 59205ac5fc preliminiary implementation for the early heating finish.
Might be replaced by something more clever, e.g. by erik, and does not yet support the second extruder or the bed.
its kind of not so cool, because you need 6 more ints.
Maybe isheating() should use the degrees directly, as it is not used in time-critical anyways.
Then it would be much easier. to have the offsets without additional variables.
Bernhard 7a4be21b4f made it compile if arduino decides to include files in a differnt order. DEC HEX and stuff now defined in MarlinSerial.h
Bernhard 716e89b87c first homing move diagonal towards home switches.
Bernhard d00b7e5587 repaired compiliation in windows
Bernhard e4ab0e5982 more inlines
Bernhard 8cb29921a0 possible stepper release after sd printing
Bernhard 044886b4a0 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard b19c8b74b9 force inline
Erik van der Zalm 6d95644c0d Moved M88 into M84. (M84 E)
Bernhard 311627141b Merge branch 'smallopt' into Marlin_v1
Conflicts:
	Marlin/temperature.h
Erik van der Zalm 7216a12856 Disabled M88 for boards that don't have seperate enable pins.
Erik van der Zalm 98805c9228 Added M88 command. (Request from Action68)
Bernhard 85da81e673 inlineing of small functions in serial
Bernhard b9ad0bb2ce removed unecessary indirect register adressing in serial.
Bernhard dd5ca68c87 get rid of indirect ringbuffer calls, made some inlines, removed virtual and streaming class requirements.
Erik van der Zalm dd5296ad4d Fixed temperature reading bug.
(When using the lower and upper adc input bank)
Erik van der Zalm f75f426dfa Removed interrupt nesting in the stepper ISR.
Add serial checkRx in stepper ISR.
Copied HardwareSerial to MarlinSerial (Needed for checkRx).
Bernhard 2d9a715655 first naive attempt to have a offset in the homeing procedure. Does not enable to move into regions not allowed by endstops.
Bernhard d2f034ba84 lcd message from gcode, m117
Bernhard 6aecf80278 add autotemp support to the lcd
Bernhard b128d25f27 overlooked some inlines..
Bernhard 26a1de1e44 force inline
Bernhard f8e170a44b planner optimization by inline functions
Erik van der Zalm aad4b75b94 First parts 2nd extruder
Bernhard a0dc66f7bf Home retract distance configureable per axis.
Bernhard 6d6f323535 make an option if sd-card stop should release the steppers.
Bernhard 4d6a5c29df disable steppers as routine in stepper.cpp
Bernhard 74d0032e25 cooldown blocking selectable by #define.
Bernhard 191f36b493 slowdown
Bernhard c54a807824 overworked ultralcd a bit
Bernhard a6823a84e1 another typo
Bernhard 57e163e989 typo
Bernhard b58787a367 now velocities are also set in mm/sec in gcode.
Bernhard 71ca78982b Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard 235051253a overworked lcd+eeprom to have only mm/sec and PID including pid_dt
Erik van der Zalm 27654bfe69 Fixed variable (removed 0x)
Erik van der Zalm cdf0bd4e63 Fixed config bug when EEPROM was disabled
Erik van der Zalm 6ac9b2e761 Fixed residency time bug. (Thanks to Sound :-) )
Erik van der Zalm ac8adabb2b Small nominal speed improvement.
Erik van der Zalm 0e0e4945d8 Removed ISR overtaken message from ISR routine
Erik van der Zalm c0f8c9fd72 Seperate ENDSTOP_INVERTING for X Y and Z
Added simple endstop filter.
Corrected M114 count display.
Bernhard Kubicek 5535e51bf6 Yes, thats the beta.
Bernhard Kubicek 8b14a8ad34 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard Kubicek 924bab1a03 less lcd flickering
Bernhard Kubicek 379ea642e1 make tuneing sub-menu.
Erik van der Zalm 959d82e81e Small temperature disable bug.
Erik van der Zalm 15bb3f284e Merge branch 'Marlin_v1', remote-tracking branch 'origin/Marlin_v1' into Marlin_v1
Erik van der Zalm 4e5becfc51 Added endstop reporting
Bernhard Kubicek eeb4f029db Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard Kubicek b21d5193f2 made ultralcd compatible with folders.
Erik van der Zalm 2e43f9c809 Changed min max temperature code.
Bernhard Kubicek cd2268f10a code cleanup in ultralcd.
Erik van der Zalm 0e7fee9a9b Merge branch 'Marlin_v1', remote-tracking branch 'origin/Marlin_v1' into Marlin_v1
Erik van der Zalm 915ef2d4a1 Added software endstops
Bernhard Kubicek e87df99e22 update mcode documentation
Bernhard Kubicek 8a1e719a3f overworked config file
Bernhard Kubicek 5ad1d19384 make it compile without sd_support
Bernhard Kubicek 7a2d1f5aeb add M17, so the enable stepper button works in repg.
Erik van der Zalm e02af3e66a Merge remote-tracking branch 'origin/Marlin_v1' into Marlin_v1
Erik van der Zalm 537b5c155d Fixed arc flowrate.
Bernhard Kubicek 953d830bba Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard Kubicek 2a6afee832 make it compile without autotemp
Bernhard Kubicek f52e1a9571 autotemp working, default=disabled.
Erik van der Zalm 6e6fdb9a4e Merge remote-tracking branch 'origin/Marlin_v1' into Marlin_v1
Erik van der Zalm 6841a10446 Fixed max/min temperature bug
Bernhard Kubicek 8a08b8e07e trying to get autotemp to work.
Bernhard Kubicek f0154de5b3 found bug that disabled printing from root.
Bernhard Kubicek 70650c331d corrected the ultimaker default values, the previous had a calculation error: see: http://groups.google.com/group/ultimaker/browse_thread/thread/91906788639703cf
Bernhard Kubicek 9d90220537 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard Kubicek 869cee74e6 host-based sd card printing seems now to work with folders
Bernhard Kubicek 70abca195a overworked cardreader for folder support; not finished yet.
Erik van der Zalm ff69e0a772 Changed max/min temp init. Removed second uart from sabguino core
Bernhard Kubicek 1e5e141ac9 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard Kubicek edb5ea7efa the normal config again..
Bernhard Kubicek 5df5727e93 removed some debugging comments
Bernhard Kubicek 64f2121ab1 updated to sdfatlib2010902
Erik van der Zalm b15902d3b5 Fixed bug in configuration.h
Erik van der Zalm e63e224a33 Merge remote-tracking branch 'origin/Marlin_v1' into Marlin_v1
Conflicts:
	Marlin/Configuration.h
	Marlin/Marlin.pde
Erik van der Zalm e7dca8614b Advance experiments. Not working yet.
Bernhard Kubicek 46f80e82d9 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Conflicts:
	Marlin/ultralcd.h
Bernhard Kubicek a9c7da06e3 and changed ultipanel to have the mm/sec and not mm/min
Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1

Conflicts:
	Marlin/Marlin.pde
	Marlin/ultralcd.h
Bernhard Kubicek 02b9eceead show sd%
Bernhard Kubicek 7919a40d06 watchdog,percent done,
Erik van der Zalm 805d37f77b Fixed some small planner bugs
Erik van der Zalm 5fd41ae872 Some fixes in planner
Erik van der Zalm 95126c09c0 Added slowdown
Erik van der Zalm 331e82dcd3 Buffer size > 16
Erik van der Zalm 2643ae93d6 Added modified Sanguino files
Erik van der Zalm c00eefb824 Merge remote-tracking branch 'origin/Marlin_v1' into Marlin_v1
Erik van der Zalm 1d0452f10c 250000 baud
Bernhard Kubicek c57906b627 fixed bug with adjusting ki in realtime.
Erik van der Zalm ac82411c73 Merge remote-tracking branch 'origin/Marlin_v1' into Marlin_v1
Erik van der Zalm 65934eee9c A lot of changes in the planner code
Bernhard Kubicek 9980ceb4a3 added a m400, that finished all moves,
and the mechanism so that if an endstop is hit it the ISR, the steps_to_be_taken are stored, and some current_block data that will be deleted in the next move
If the normal loop() then finds such an event, the position is calculated (floats would have taken too long in the ISR) A serial message is generated.
Bernhard Kubicek ff592b056a heater power repair.
Bernhard Kubicek e9adfa27b5 re-enabled heaterpower as storage for the current storage of the heater PWM duty cycle.
the M301 now returns the current PID settings of the machine.
M105 returns heating pwm duty cylce as "@:"
Bernhard Kubicek 36958ee305 minor changes and first not-well working version of autotemp
Bernhard Kubicek ba8a53a40f Streaming.h is gone. It conflicted with PROGMEM. And saving memory is more important than nicer code, imho
Bernhard Kubicek 27361e7cd0 beautified the config. ordered it into thematic sections.
Bernhard Kubicek ab154d5592 project progmem finished: total change with ultipanel: 2456 byte free ram initial. now: 4374 ram.
Bernhard Kubicek 7b70caab7c made progmem mainly, found one bug in cardreader, added a empty class for cardreader in case no sd support.
Bernhard Kubicek 72ace55e6a better visibility of public/private/imported variables
Bernhard Kubicek 977fd2b2c7 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard Kubicek 907daa49af made loop counters uint8_t most were int(16_t) before
Erik van der Zalm e3af73ee0c Thermistor name problem
Bernhard Kubicek 0b43761c3a preprocessor magic to have a single source principle
Bernhard Kubicek 156763d027 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard Kubicek fc0064e525 made cardreader more selfsustained
Erik van der Zalm d3bfffcb6e Corrected thermistor naming
Bernhard Kubicek 01df04e02c first compile with the cardreader class
Bernhard Kubicek 163efdf1c7 Merge branch 'Marlin_v1' of https://github.com/ErikZalm/Marlin into Marlin_v1
Bernhard Kubicek 87aaf0f70a static'ified Marlin.pde.
Erik van der Zalm 5cf349a24a Fixed some arc bugs
Bernhard Kubicek 79d1bfb5c0 made many possible variables static, so they cannot be used extern.
Erik van der Zalm 76b3f805c0 Added teensylu pins
Bernhard Kubicek 1d171e9e52 reformating and some minor bugs/things found on the way.
Bernhard Kubicek 900e0c9bf2 overworked the serial responses. Quite difficult, since many texts are Pronterface protocol.
Bernhard Kubicek 1740a83e11 correcting commit errors.
Bernhard Kubicek 7cc358b56b wrong file location
Bernhard Kubicek e8092898b1 watchdog into dedicated file
Bernhard Kubicek 2afb7bd4cf refactured temperature.cpp so that there are now abstract functions to access temperatures.
Erik van der Zalm 0b82465168 First arcs version. (Arcs not working ok)
Erik van der Zalm 2e8e8878e5 Corrected temp variables.
Erik van der Zalm 04d3b5537f Merge remote-tracking branch 'origin/Marlin_v1' into Marlin_v1
Conflicts:
	Marlin/Configuration.h
	Marlin/EEPROMwrite.h
	Marlin/Marlin.h
	Marlin/Marlin.pde
	Marlin/temperature.cpp
	Marlin/temperature.h
	Marlin/thermistortables.h
Erik van der Zalm d15f01e1b4 Temperature changes
Bernhard Kubicek ea86a5e10f moved the variables in the ISR, thats the most normal use case of static.
Bernhard Kubicek b9ea0651ec Revert "this is not working. Do you maybe know why?"
This reverts commit 8bcdb9f5f0.
Bernhard Kubicek 8bcdb9f5f0 this is not working. Do you maybe know why?
Bernhard Kubicek 40e8081623 changed end of line to windows, which seems to be the majority of developers main platform.
Bernhard Kubicek 00674af3a8 merge from the branch bkubicek/Marlin/zalmmerge
Erik van der Zalm d7c4f0780b Added M42, M80 and M81
Erik van der Zalm 95d3d9847c M109 now equal to sprinter
Erik van der Zalm bf879ceaa9 Added thermistor tables
Erik van der Zalm 094afe7c10 Merged Marlin, Marlin non gen6 and Ultimaker changes
Erik van der Zalm 0b1423c303 Fixed crashes.
Erik van der Zalm 27664c6da6 Software endstps added
Erik van der Zalm 8e017b81ab Sync with non-gen6 version
Erik van der Zalm b5f6482dce Fixed small feedrate bug.
Copied Camiels comments in the Configuration.h file
Erik van der Zalm 0024a26ccf Fixed lookup table bug.
Erik van der Zalm 5a1787b2f4 Fix M109
Erik van der Zalm 26bf57e22c first-commit
Erik van der Zalm f850af5c1c Signed-off-by: Erik van der Zalm <erik@vdzalm.eu>
Erik van der Zalm 750f6c33e3 first commit