Prusa MINI Firmware overview
Main Page
Modules
Classes
Files
File List
File Members
pins_SAV_MKI.h
Go to the documentation of this file.
1
/**
2
* Marlin 3D Printer Firmware
3
* Copyright (c) 2019 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
4
*
5
* Based on Sprinter and grbl.
6
* Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
7
*
8
* This program is free software: you can redistribute it and/or modify
9
* it under the terms of the GNU General Public License as published by
10
* the Free Software Foundation, either version 3 of the License, or
11
* (at your option) any later version.
12
*
13
* This program is distributed in the hope that it will be useful,
14
* but WITHOUT ANY WARRANTY; without even the implied warranty of
15
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
* GNU General Public License for more details.
17
*
18
* You should have received a copy of the GNU General Public License
19
* along with this program. If not, see <http://www.gnu.org/licenses/>.
20
*
21
*/
22
#pragma once
23
24
/**
25
* Rev B 2 JUN 2017
26
*
27
* Converted to Arduino pin numbering
28
*/
29
30
/**
31
* There are two Arduino IDE extensions that are compatible with this board
32
* and with the mainstream Marlin software.
33
*
34
* Teensyduino - http://www.pjrc.com/teensy/teensyduino.html
35
* Select Teensy++ 2.0 in Arduino IDE from the 'Tools > Board' menu
36
*
37
* Installation instructions are at the above URL. Don't bother loading the
38
* libraries - they are not used with the Marlin software.
39
*
40
* Printrboard - https://github.com/scwimbush/Printrboard-HID-Arduino-IDE-Support
41
*
42
* Installation:
43
*
44
* 1. Go to the above URL, click on the "Clone or Download" button and then
45
* click on "Download ZIP" button.
46
* 2. Unzip the file, find the "printrboard" directory and then copy it to the
47
* hardware directory in Arduino. The Arduino hardware directory will probably
48
* be located in a path similar to this: C:\Program Files (x86)\Arduino\hardware.
49
* 3. Restart Arduino.
50
* 4. Select "Printrboard" from the 'Tools > Board' menu.
51
*
52
* Teensyduino is the most popular option. Printrboard is used if your board doesn't have
53
* the Teensyduino bootloader on it.
54
*/
55
56
/**
57
* To burn the bootloader that comes with Printrboard:
58
*
59
* 1. Connect your programmer to the board.
60
* 2. In the Arduino IDE select "Printrboard" and then select the programmer.
61
* 3. In the Arduino IDE click on "burn bootloader". Don't worry about the "verify failed at 1F000" error message.
62
* 4. The programmer is no longer needed. Remove it.
63
*/
64
65
#ifndef __AVR_AT90USB1286__
66
#error "Oops! Select 'Teensy++ 2.0' or 'Printrboard' in 'Tools > Board.'"
67
#endif
68
69
#define BOARD_INFO_NAME "SAV MkI"
70
#define DEFAULT_MACHINE_NAME BOARD_INFO_NAME
71
#define DEFAULT_SOURCE_CODE_URL "https://tinyurl.com/onru38b"
72
73
//
74
// Servos
75
//
76
#define SERVO0_PIN 39 // F1 In teensy's pin definition for pinMode (in servo.cpp)
77
78
//
79
// Limit Switches
80
//
81
#define X_STOP_PIN 25 // B5
82
#define Y_STOP_PIN 26 // B6
83
//#define Z_STOP_PIN 27 // B7
84
#define Z_STOP_PIN 36 // E4 For inductive sensor.
85
//#define E_STOP_PIN 36 // E4
86
87
//
88
// Steppers
89
//
90
#define X_STEP_PIN 28 // A0
91
#define X_DIR_PIN 29 // A1
92
#define X_ENABLE_PIN 19 // E7
93
94
#define Y_STEP_PIN 30 // A2
95
#define Y_DIR_PIN 31 // A3
96
#define Y_ENABLE_PIN 18 // E6
97
98
#define Z_STEP_PIN 32 // A4
99
#define Z_DIR_PIN 33 // A5
100
#define Z_ENABLE_PIN 17 // C7
101
102
#define E0_STEP_PIN 34 // A6
103
#define E0_DIR_PIN 35 // A7
104
#define E0_ENABLE_PIN 13 // C3
105
106
//
107
// Temperature Sensors
108
//
109
#define TEMP_0_PIN 7 // F7 Analog Input (Extruder)
110
#define TEMP_BED_PIN 6 // F6 Analog Input (Bed)
111
112
//
113
// Heaters / Fans
114
//
115
#define HEATER_0_PIN 15 // C5 PWM3B - Extruder
116
#define HEATER_BED_PIN 14 // C4 PWM3C - Bed
117
118
#ifndef FAN_PIN
119
#define FAN_PIN 16 // C6 PWM3A
120
#endif
121
122
//
123
// Misc. Functions
124
//
125
#define SDSS 20 // B0
126
127
// Extension header pin mapping
128
// ----------------------------
129
// SCL (I2C)-D0 A0 (An), IO
130
// SDA (I2C)-D1 A1 (An), IO
131
// RX1-D2 A2 (An), IO
132
// TX1-D3 A3 (An), IO
133
// PWM-D24 A4 (An), IO
134
// 5V GND
135
// 12V GND
136
#define EXT_AUX_SCL_D0 0 // D0 PWM0B
137
#define EXT_AUX_SDA_D1 1 // D1
138
#define EXT_AUX_RX1_D2 2 // D2
139
#define EXT_AUX_TX1_D3 3 // D3
140
#define EXT_AUX_PWM_D24 24 // B4 PWM2A
141
#define EXT_AUX_A0 0 // F0 Analog Input
142
#define EXT_AUX_A0_IO 38 // F0 Digital IO
143
#define EXT_AUX_A1 1 // F1 Analog Input
144
#define EXT_AUX_A1_IO 39 // F1 Digital IO
145
#define EXT_AUX_A2 2 // F2 Analog Input
146
#define EXT_AUX_A2_IO 40 // F2 Digital IO
147
#define EXT_AUX_A3 3 // F3 Analog Input
148
#define EXT_AUX_A3_IO 41 // F3 Digital IO
149
#define EXT_AUX_A4 4 // F4 Analog Input
150
#define EXT_AUX_A4_IO 42 // F4 Digital IO
151
152
//
153
// LCD / Controller
154
//
155
#define BEEPER_PIN -1
156
#define LCD_PINS_RS -1
157
#define LCD_PINS_ENABLE -1
158
159
#if ENABLED(SAV_3DLCD)
160
// For LCD SHIFT register LCD
161
#define SR_DATA_PIN EXT_AUX_SDA_D1
162
#define SR_CLK_PIN EXT_AUX_SCL_D0
163
#endif
164
165
#if EITHER(SAV_3DLCD, SAV_3DGLCD)
166
167
#define BTN_EN1 EXT_AUX_A1_IO
168
#define BTN_EN2 EXT_AUX_A0_IO
169
#define BTN_ENC EXT_AUX_PWM_D24
170
171
#define KILL_PIN EXT_AUX_A2_IO
172
#define HOME_PIN EXT_AUX_A4_IO
173
174
#else // Use the expansion header for spindle control
175
176
//
177
// M3/M4/M5 - Spindle/Laser Control
178
//
179
#define SPINDLE_LASER_PWM_PIN 24 // B4 PWM2A
180
#define SPINDLE_LASER_ENA_PIN 39 // F1 Pin should have a pullup!
181
#define SPINDLE_DIR_PIN 40 // F2
182
183
#define CASE_LIGHT_PIN 0 // D0 PWM0B
184
185
#endif
Prusa-Firmware-Buddy-Private1
lib
Marlin
Marlin
src
pins
teensy2
pins_SAV_MKI.h
Generated by
1.8.16