Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/Duet3D/RepRapFirmware.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordc42 <dcrocker@eschertech.com>2017-03-25 13:28:19 +0300
committerGitHub <noreply@github.com>2017-03-25 13:28:19 +0300
commitdde45bd81a8665f3bd0aac289603412c6dcf326b (patch)
tree8082a1248752c43b719025ca66d743ed97cc6f41 /README.md
parente3b8adbe4340f19b3e4916280fbabcdd20281249 (diff)
Update and rename README to README.md
Diffstat (limited to 'README.md')
-rw-r--r--README.md24
1 files changed, 24 insertions, 0 deletions
diff --git a/README.md b/README.md
new file mode 100644
index 00000000..2bdfe5f1
--- /dev/null
+++ b/README.md
@@ -0,0 +1,24 @@
+This is firmware for controlling 3D printers and related devices using electronics with Atmel ARM main processors. The minimum specification processor it is intended for is ARM Cortex M3 with 96Kb RAM such as the SAM3X8E.
+
+General design principles:
+
+* Unlike most other 3D printer firmwares, this is not intended to be portable to outdated processors with limited CPU power. So make good use of the power of modern inexpensive ARM processors to implement advanced features.
+* "One binary to rule them all". For a given electronics board, all features if interest to many 3D printer owners are supported by a single binary. Users do not need to recompile the firmware unless they have unusual requirements.
+* "G-code everywhere". All firmware configuration is done using gcodes in the config.g file. Most type of change can be done on the fly so that you can experiment with different configurations without even having to restart the printer.
+* Use high-integrity coding standards to help ensure that the firmware is reliable. In particular, don't use dynamic memory allocation after the initialisation phase. The MISRA-C++ 2008 coding standard serves as a guide as to what is acceptable practice, but compliance to it is not rigidlty enforced in order to allow features from later versions of the C++ language to be used.
+* Use an appoprriate degree of modularity. Too little modularity makes the code hard to understand and maintain. Too much makes it hard to intruduce new features when the exising module boundaries turn out to be inappropriate.
+* Use object-based and object-oriented design principles where it is appropriate. In particular, class data should normally be private. Use 'friend'# sparingly or not at all.
+
+RepRapFirmware has pioneered a number of advances in 3D printing including:
+
+* Support for mixing extruders (July 2014)
+* Precise timing of step pulses, even during acceleration (Janury 2015)
+* Segmentation-free delta motion (January 2015)
+* Least-squares auto calibratoin of delta printers (April 2015)
+* Accurate extruder pressure advance, including retraction before the end of a move when needed (January 2015)
+
+For documentation on supported gcodes and configuration, see https://duet3d.com/wiki. There is a tool for generating the config'g file and homing files at https://configurator.reprapfirmware.org/.
+
+Compiling from source: see separate file BuildInstructions.txt.
+
+Licence: GPLv3, see http://www.gnu.org/licenses/gpl-3.0.en.html