Skip to content

Commit 5859ff0

Browse files
✨ NUM_REDUNDANT_FANS (#25808)
Co-authored-by: Scott Lahteine <[email protected]>
1 parent 40aa398 commit 5859ff0

File tree

9 files changed

+53
-32
lines changed

9 files changed

+53
-32
lines changed

Marlin/Configuration_adv.h

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -660,9 +660,12 @@
660660
#endif
661661

662662
/**
663-
* Use one of the PWM fans as a redundant part-cooling fan
663+
* Assign more PWM fans for part cooling, synchronized with Fan 0
664664
*/
665-
//#define REDUNDANT_PART_COOLING_FAN 2 // Index of the fan to sync with FAN 0.
665+
//#define REDUNDANT_PART_COOLING_FAN 1 // Index of the first fan to synchronize with Fan 0
666+
#ifdef REDUNDANT_PART_COOLING_FAN
667+
//#define NUM_REDUNDANT_FANS 1 // Number of sequential fans to synchronize with Fan 0
668+
#endif
666669

667670
// @section extruder
668671

Marlin/src/gcode/temp/M106_M107.cpp

Lines changed: 2 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -61,9 +61,7 @@
6161
void GcodeSuite::M106() {
6262
const uint8_t pfan = parser.byteval('P', _ALT_P);
6363
if (pfan >= _CNT_P) return;
64-
#if REDUNDANT_PART_COOLING_FAN
65-
if (pfan == REDUNDANT_PART_COOLING_FAN) return;
66-
#endif
64+
if (FAN_IS_REDUNDANT(pfan)) return;
6765

6866
#if ENABLED(EXTRA_FAN_SPEED)
6967
const uint16_t t = parser.intval('T');
@@ -102,9 +100,7 @@ void GcodeSuite::M106() {
102100
void GcodeSuite::M107() {
103101
const uint8_t pfan = parser.byteval('P', _ALT_P);
104102
if (pfan >= _CNT_P) return;
105-
#if REDUNDANT_PART_COOLING_FAN
106-
if (pfan == REDUNDANT_PART_COOLING_FAN) return;
107-
#endif
103+
if (FAN_IS_REDUNDANT(pfan)) return;
108104

109105
thermalManager.set_fan_speed(pfan, 0);
110106

Marlin/src/inc/Conditionals_adv.h

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1280,3 +1280,8 @@
12801280
#define MULTISTEPPING_LIMIT 128
12811281
#define MULTISTEPPING_LIMIT_WARNING 1
12821282
#endif
1283+
1284+
// One redundant cooling fan by default
1285+
#if defined(REDUNDANT_PART_COOLING_FAN) && !defined(NUM_REDUNDANT_FANS)
1286+
#define NUM_REDUNDANT_FANS 1
1287+
#endif

Marlin/src/inc/SanityCheck.h

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1843,8 +1843,10 @@ static_assert(COUNT(arm) == LOGICAL_AXES, "AXIS_RELATIVE_MODES must contain " _L
18431843
#ifdef REDUNDANT_PART_COOLING_FAN
18441844
#if FAN_COUNT < 2
18451845
#error "REDUNDANT_PART_COOLING_FAN requires a board with at least two PWM fans."
1846-
#else
1847-
static_assert(WITHIN(REDUNDANT_PART_COOLING_FAN, 1, FAN_COUNT - 1), "REDUNDANT_PART_COOLING_FAN must be between 1 and " STRINGIFY(DECREMENT(FAN_COUNT)) ".");
1846+
#elif !WITHIN(REDUNDANT_PART_COOLING_FAN, 1, FAN_COUNT - 1)
1847+
static_assert(false, "REDUNDANT_PART_COOLING_FAN must be between 1 and " STRINGIFY(DECREMENT(FAN_COUNT)) ".");
1848+
#elif !WITHIN(REDUNDANT_PART_COOLING_FAN + NUM_REDUNDANT_FANS - 1, 1, FAN_COUNT - 1)
1849+
#error "Not enough fans available for NUM_REDUNDANT_FANS."
18481850
#endif
18491851
#endif
18501852

Marlin/src/lcd/menu/menu_item.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -580,10 +580,10 @@ class MenuItem_bool : public MenuEditItemBase {
580580
}while(0)
581581

582582
#if FAN_COUNT > 1
583-
#define FAN_EDIT_ITEMS(F) _FAN_EDIT_ITEMS(F,FAN_SPEED_N)
583+
#define FAN_EDIT_ITEMS(F) _FAN_EDIT_ITEMS(F, FAN_SPEED_N)
584584
#endif
585585

586-
#define SNFAN(N) (ENABLED(SINGLENOZZLE_STANDBY_FAN) && !HAS_FAN##N && EXTRUDERS > N)
586+
#define SNFAN(N) (ENABLED(SINGLENOZZLE_STANDBY_FAN) && !HAS_FAN##N && (N) < EXTRUDERS)
587587

588588
#if SNFAN(1) || SNFAN(2) || SNFAN(3) || SNFAN(4) || SNFAN(5) || SNFAN(6) || SNFAN(7)
589589
#define DEFINE_SINGLENOZZLE_ITEM() \

Marlin/src/lcd/menu/menu_temperature.cpp

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -221,40 +221,40 @@ void menu_temperature() {
221221

222222
DEFINE_SINGLENOZZLE_ITEM();
223223

224-
#if HAS_FAN0
225-
_FAN_EDIT_ITEMS(0,FIRST_FAN_SPEED);
224+
#if FAN_IS_M106ABLE(0)
225+
_FAN_EDIT_ITEMS(0, FIRST_FAN_SPEED);
226226
#endif
227-
#if HAS_FAN1 && REDUNDANT_PART_COOLING_FAN != 1
227+
#if FAN_IS_M106ABLE(1)
228228
FAN_EDIT_ITEMS(1);
229229
#elif SNFAN(1)
230230
singlenozzle_item(1);
231231
#endif
232-
#if HAS_FAN2 && REDUNDANT_PART_COOLING_FAN != 2
232+
#if FAN_IS_M106ABLE(2)
233233
FAN_EDIT_ITEMS(2);
234234
#elif SNFAN(2)
235235
singlenozzle_item(2);
236236
#endif
237-
#if HAS_FAN3 && REDUNDANT_PART_COOLING_FAN != 3
237+
#if FAN_IS_M106ABLE(3)
238238
FAN_EDIT_ITEMS(3);
239239
#elif SNFAN(3)
240240
singlenozzle_item(3);
241241
#endif
242-
#if HAS_FAN4 && REDUNDANT_PART_COOLING_FAN != 4
242+
#if FAN_IS_M106ABLE(4)
243243
FAN_EDIT_ITEMS(4);
244244
#elif SNFAN(4)
245245
singlenozzle_item(4);
246246
#endif
247-
#if HAS_FAN5 && REDUNDANT_PART_COOLING_FAN != 5
247+
#if FAN_IS_M106ABLE(5)
248248
FAN_EDIT_ITEMS(5);
249249
#elif SNFAN(5)
250250
singlenozzle_item(5);
251251
#endif
252-
#if HAS_FAN6 && REDUNDANT_PART_COOLING_FAN != 6
252+
#if FAN_IS_M106ABLE(6)
253253
FAN_EDIT_ITEMS(6);
254254
#elif SNFAN(6)
255255
singlenozzle_item(6);
256256
#endif
257-
#if HAS_FAN7 && REDUNDANT_PART_COOLING_FAN != 7
257+
#if FAN_IS_M106ABLE(7)
258258
FAN_EDIT_ITEMS(7);
259259
#elif SNFAN(7)
260260
singlenozzle_item(7);

Marlin/src/lcd/menu/menu_tune.cpp

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -153,40 +153,40 @@ void menu_tune() {
153153

154154
DEFINE_SINGLENOZZLE_ITEM();
155155

156-
#if HAS_FAN0
157-
_FAN_EDIT_ITEMS(0,FIRST_FAN_SPEED);
156+
#if FAN_IS_M106ABLE(0)
157+
_FAN_EDIT_ITEMS(0, FIRST_FAN_SPEED);
158158
#endif
159-
#if HAS_FAN1 && REDUNDANT_PART_COOLING_FAN != 1
159+
#if FAN_IS_M106ABLE(1)
160160
FAN_EDIT_ITEMS(1);
161161
#elif SNFAN(1)
162162
singlenozzle_item(1);
163163
#endif
164-
#if HAS_FAN2 && REDUNDANT_PART_COOLING_FAN != 2
164+
#if FAN_IS_M106ABLE(2)
165165
FAN_EDIT_ITEMS(2);
166166
#elif SNFAN(2)
167167
singlenozzle_item(2);
168168
#endif
169-
#if HAS_FAN3 && REDUNDANT_PART_COOLING_FAN != 3
169+
#if FAN_IS_M106ABLE(3)
170170
FAN_EDIT_ITEMS(3);
171171
#elif SNFAN(3)
172172
singlenozzle_item(3);
173173
#endif
174-
#if HAS_FAN4 && REDUNDANT_PART_COOLING_FAN != 4
174+
#if FAN_IS_M106ABLE(4)
175175
FAN_EDIT_ITEMS(4);
176176
#elif SNFAN(4)
177177
singlenozzle_item(4);
178178
#endif
179-
#if HAS_FAN5 && REDUNDANT_PART_COOLING_FAN != 5
179+
#if FAN_IS_M106ABLE(5)
180180
FAN_EDIT_ITEMS(5);
181181
#elif SNFAN(5)
182182
singlenozzle_item(5);
183183
#endif
184-
#if HAS_FAN6 && REDUNDANT_PART_COOLING_FAN != 6
184+
#if FAN_IS_M106ABLE(6)
185185
FAN_EDIT_ITEMS(6);
186186
#elif SNFAN(6)
187187
singlenozzle_item(6);
188188
#endif
189-
#if HAS_FAN7 && REDUNDANT_PART_COOLING_FAN != 7
189+
#if FAN_IS_M106ABLE(7)
190190
FAN_EDIT_ITEMS(7);
191191
#elif SNFAN(7)
192192
singlenozzle_item(7);

Marlin/src/module/temperature.cpp

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -467,8 +467,12 @@ PGMSTR(str_t_heating_failed, STR_T_HEATING_FAILED);
467467
if (fan >= FAN_COUNT) return;
468468

469469
fan_speed[fan] = speed;
470-
#if REDUNDANT_PART_COOLING_FAN
471-
if (fan == 0) fan_speed[REDUNDANT_PART_COOLING_FAN] = speed;
470+
471+
#if NUM_REDUNDANT_FANS
472+
if (fan == 0) {
473+
for (uint8_t f = REDUNDANT_PART_COOLING_FAN; f < REDUNDANT_PART_COOLING_FAN + NUM_REDUNDANT_FANS; ++f)
474+
thermalManager.set_fan_speed(f, 0);
475+
}
472476
#endif
473477

474478
TERN_(REPORT_FAN_CHANGE, report_fan_speed(fan));

Marlin/src/module/temperature.h

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -44,6 +44,17 @@
4444
#define HOTEND_INDEX TERN(HAS_MULTI_HOTEND, e, 0)
4545
#define E_NAME TERN_(HAS_MULTI_HOTEND, e)
4646

47+
#if HAS_FAN
48+
#if NUM_REDUNDANT_FANS
49+
#define FAN_IS_REDUNDANT(Q) WITHIN(Q, REDUNDANT_PART_COOLING_FAN, REDUNDANT_PART_COOLING_FAN + NUM_REDUNDANT_FANS - 1)
50+
#else
51+
#define FAN_IS_REDUNDANT(Q) false
52+
#endif
53+
#define FAN_IS_M106ABLE(Q) (HAS_FAN##Q && !FAN_IS_REDUNDANT(Q))
54+
#else
55+
#define FAN_IS_M106ABLE(Q) false
56+
#endif
57+
4758
// Element identifiers. Positive values are hotends. Negative values are other heaters or coolers.
4859
typedef enum : int_fast8_t {
4960
H_REDUNDANT = HID_REDUNDANT,

0 commit comments

Comments
 (0)