Duet3 config with limit on 7 temp inputs
-
M308 S7 P"3.temp1" Y"thermistor" T100000 A"Test"
Error: Pin 3.temp1 is not free Using the S308 after defining says that it does not exist.Hmm, I still get the error after I get past board 2 sensor 0. Also, sensor 0 on board 2 reports 2000C. I just wired it, but I tried swapping thermistors and that did not affect the output.
good idea for troubleshooting though, thanks!
Ok, so I did a little more
playing arounderm, testing. I found that the 7th sensor always reports 2000C. If I change the IDs of the expansion boards, the problem follows the board with id of 2, so this is not a hardware problem. -
Sounds like a bug, indeed. @dc42 what do you think?
-
My memory is a bit hazy on this but I seem to remember a post from months ago where it was mentioned that there is a limit on the number of temperature channels which can be defined and David increased it. Unfortunately I can't remember what the limit was nor what David increased it to.
-
I am no programmer, but I took a look at the firmware. (I know, famous last words!)
this is in RepRapFirmware.h#if SUPPORT_CAN_EXPANSION typedef uint64_t SensorsBitmap; #else typedef uint32_t SensorsBitmap; #endif static_assert(MaxAxes <= sizeof(AxesBitmap) * CHAR_BIT); static_assert(MaxExtruders <= sizeof(ExtrudersBitmap) * CHAR_BIT); static_assert(MaxFans <= sizeof(FansBitmap) * CHAR_BIT); static_assert(MaxHeaters <= sizeof(HeatersBitmap) * CHAR_BIT); static_assert(NumDirectDrivers <= sizeof(DriversBitmap) * CHAR_BIT); static_assert(MaxSensors <= sizeof(SensorsBitmap) * CHAR_BIT);
it seems that using can expansion only doubles the list from the base amount of sensors.
typedef uint64_t SensorsBitmap; #else typedef uint32_t SensorsBitmap; #endif
also, if I am not mistaken,
static_assert(MaxSensors <= sizeof(SensorsBitmap) * CHAR_BIT);
would be 8*CHAR_BIT
I have not looked into the code enough to verify that my hunch is right, I could be totally off base, again, I am no professional programmer!
EDIT: Nope, I think I am off base, never mind!
-
I suspect that problem is that you have previously configured sensors on the expansion boards, then rebooted just the main board. Currently, restarting the main board does not restart the expansion boards (this will be fixed in a subsequent 3.x firmware release). So when you change the pin usage in config.g, you may need to press the reset buttons on the expansion boards, or alternatively power the system down, wait until the blue LEDs have gone out, and then power it up again.
-
@dc42 I wish it was the case. I have tried that, and just tried it again, and alas, when I run M308 SN where N is 4-7 I get errors, also, now I am getting two sensors on the 2nd expansion board to read 2000C
-
@RobMink said in Duet3 config with limit on 7 temp inputs:
M308 S0 P"0.temp0" Y"thermistor" T100000 A"Bed"
M308 S1 P"1.temp0" Y"thermistor" T100000 A"Head0"
M308 S2 P"1.temp1" Y"thermistor" T100000 A"Head1"
M308 S3 P"1.temp2" Y"thermistor" T100000 A"Head2"
M308 S4 P"2.temp0" Y"thermistor" T100000 A"Head3"
M308 S5 P"0.temp1" Y"thermistor" T100000 A"Head4"
M308 S6 P"0.temp2" Y"thermistor" T100000 A"Head5"
M308 S7 P"3.temp1" Y"thermistor" T100000 A"Test"I don't get any errors when I run that sequence, but there is something not quite right:
26/12/2019, 14:37:52 M308 S8 Error: Sensor 8 does not exist 26/12/2019, 14:37:48 M308 S7 Sensor 7 type Thermistor using pin 3.temp1, last error: sensor open circuit, T:100000.0 B:4388.0 C:0.00e+0 R:2200.0 26/12/2019, 14:37:45 M308 S6 Sensor 6 (Head5) type Thermistor using pin temp2, reading -273.1, last error: sensor open circuit, T:100000.0 B:4388.0 C:0.00e+0 R:2200.0 L:0 H:0 26/12/2019, 14:37:43 M308 S5 Sensor 5 (Head4) type Thermistor using pin temp1, reading -273.1, last error: sensor open circuit, T:100000.0 B:4388.0 C:0.00e+0 R:2200.0 L:0 H:0 26/12/2019, 14:37:41 M308 S4 Sensor 4 type Thermistor using pin 2.temp0, last error: sensor open circuit, T:100000.0 B:4388.0 C:0.00e+0 R:2200.0 26/12/2019, 14:37:40 M308 S3 Sensor 3 type Thermistor using pin 1.temp2, last error: sensor open circuit, T:100000.0 B:4388.0 C:0.00e+0 R:2200.0 26/12/2019, 14:37:38 M308 S2 Sensor 2 type Thermistor using pin 1.temp1, last error: sensor open circuit, T:100000.0 B:4388.0 C:0.00e+0 R:2200.0 26/12/2019, 14:37:36 M308 S1 Sensor 1 type Thermistor using pin 1.temp0, last error: success, T:100000.0 B:4388.0 C:0.00e+0 R:2200.0 26/12/2019, 14:37:32 M308 S0 Sensor 0 (Bed) type Thermistor using pin temp0, reading -273.1, last error: sensor open circuit, T:100000.0 B:4388.0 C:0.00e+0 R:2200.0 L:0 H:0
When i query the sensors individually, it only prints the sensor name and current reading for sensors connected to the main board. I will look into it.
-
I also tried running the second sequence:
M308 S0 P"0.temp0" Y"thermistor" T100000 A"Bed" M308 S1 P"1.temp0" Y"thermistor" T100000 A"Head0" M308 S2 P"1.temp1" Y"thermistor" T100000 A"Head1" M308 S3 P"1.temp2" Y"thermistor" T100000 A"Head2" M308 S4 P"2.temp0" Y"thermistor" T100000 A"Head3" M308 S5 P"2.temp1" Y"thermistor" T100000 A"Head4" M308 S6 P"2.temp2" Y"thermistor" T100000 A"Head5" M308 S7 P"3.temp1" Y"thermistor" T100000 A"Test"
That works for me too.
Are you sure that you don't have any other M308 commands earlier in config.g?
-
Here is my entire config.g
; Config for piper2v2 with tool changing - RAM - 13 heads ; General preferences G90 ; Send absolute coordinates... M83 ; ...but relative extruder moves ; Network M550 P"Duet3" ; Set machine name M552 S1 ; Enable network M586 P0 S1 ; Enable HTTP M586 P1 S0 ; Disable FTP M586 P2 S0 ; Disable Telnet ; Drives M584 X0.0 Y0.1 Z0.2:0.3:0.4:0.5 E1.0:1.1:1.2:2.0:2.1:2.2 ; Map Drives to Axis M669 K1 ; Select CoreXY mode M564 H0 ; Allow axis movement prior to homing M569 P0 S0 V118 ; Drive 0 goes backwards, Stealthchop2 till about 78 mm/sec M569 P1 S1 V118 ; Drive 1 goes forwards, Stealthchop2 till about 78 mm/sec M569 P2 S1 V118 ; Drive 2 goes forwards, Stealthchop2 till about 78 mm/sec ;xmax ymin Z M569 P3 S0 V118 ; Drive 3 goes backwards, Stealthchop2 till about 78 mm/sec ;XMIN YMIN Z M569 P4 S0 V118 ;XMAX, YMAX Z M569 P5 S0 V118 ;X0,YMAX Z M350 X16 Y16 Z16 E16 I1 ; Configure microstepping with interpolation M92 X80 Y80 Z400 E784 ; Set steps per mm M566 X60 Y60 Z24 E1200 ; Set maximum jerk (mm/min) M203 X30000 Y30000 Z1500 E800 ; Set maximum speeds (mm/min) M201 X900 Y900 Z300 E1000 I1 ; Set accelerations (mm/s^2) M906 X1000 Y1000 Z1800 E1500 I30 ; Set motor currents (mA) and motor idle factor in per cent M84 S30 ; Set idle timeout ; Tool M563 P0 D0 H1 F0 S"Extruder0" ; Define tool 0 G10 P0 X0 Y0 Z0 ; Set tool 0 axis offsets G10 P0 R0 S0 ; Set initial tool 0 active and standby temperatures to 0C M563 P1 D1 H2 F1 S"Extruder1" ; Define tool 1 G10 P1 X0 Y0 Z0 ; Set tool 1 axis offsets G10 P1 R0 S0 ; Set initial tool 1 active and standby temperatures to 0C M563 P2 D2 H3 F2 S"Extruder2" ; Define tool 2 G10 P2 X0 Y0 Z0 ; Set tool 2 axis offsets G10 P2 R0 S0 ; Set initial tool 2 active and standby temperatures to 0C M563 P3 D3 H4 F3 S"Extruder3" ; Define tool 3 G10 P3 X0 Y0 Z0 ; Set tool 2 axis offsets G10 P3 R0 S0 ; Set initial tool 2 active and standby temperatures to 0C M563 P4 D4 H5 F4 S"Extruder4" ; Define tool 4 G10 P4 X0 Y0 Z0 ; Set tool 2 axis offsets G10 P4 R0 S0 ; Set initial tool 2 active and standby temperatures to 0C M563 P5 D5 H6 F5 S"Extruder5" ; Define tool 5 G10 P5 X0 Y0 Z0 ; Set tool 2 axis offsets G10 P5 R0 S0 ; Set initial tool 2 active and standby temperatures to 0C ; Fans M950 F0 C"1.out6" M106 P0 S1 H1 T45 C"Extruder0" ; Set fan 1 value, PWM signal inversion and frequency. Thermostatic control is turned on M950 F1 C"1.out7" M106 P1 S1 H2 T45 C"Extruder1" ; Set fan 2 value, PWM signal inversion and frequency. Thermostatic control is turned on M950 F2 C"1.out8" M106 P2 S1 H3 T45 C"Extruder2" ; Set fan 3 value, PWM signal inversion and frequency. Thermostatic control is turned on M950 F3 C"2.out6" M106 P3 S1 H4 T45 C"Extruder3" ; Set fan 4 value, PWM signal inversion and frequency. Thermostatic control is turned on M950 F4 C"2.out7" M106 P4 S1 H5 T45 C"Extruder4" ; Set fan 5 value, PWM signal inversion and frequency. Thermostatic control is turned on M950 F5 C"2.out8" M106 P5 S1 H6 T45 C"Extruder5" ; Set fan 6 value, PWM signal inversion and frequency. Thermostatic control is turned on ; Heaters M308 S0 P"temp0" Y"thermistor" T100000 A"Bed" M308 S1 P"1.temp0" Y"thermistor" T100000 A"Head0" M308 S2 P"1.temp1" Y"thermistor" T100000 A"Head1" M308 S3 P"1.temp2" Y"thermistor" T100000 A"Head2" M308 S4 P"2.temp0" Y"thermistor" T100000 A"Head3" M308 S5 P"2.temp1" Y"thermistor" T100000 A"Head4" M308 S6 P"2.temp2" Y"thermistor" T100000 A"Head5" M308 S7 P"3.temp1" Y"thermistor" T100000 A"Test" M950 H0 C"out0" T0 ; heater 0 M950 H1 C"1.out0" T1 ; heater 1 M950 H2 C"1.out1" T2 ; heater 2 M950 H3 C"1.out2" T3 ; heater 3 M950 H4 C"2.out0" T4 ; heater 4 M950 H5 C"2.out1" T5 ; heater 5 M950 H6 C"2.out2" T6 ; heater 6 ; Pressure Advance M572 D0 S0.074 ; Axis Limits M208 X0 Y0 Z0 S1 ; Set axis minima M208 X950 Y950 Z600 S0 ; Set axis maxima ; Endstops M574 X1 P"!io1.in" S1 M574 Y1 P"!io2.in" S1
as you can see it is a work in progress.
Thanks again for looking at this!
-
Ok, so I did a little more troubleshooting. Bear with me here...
I cut the config to just the following.
;Heaters M308 S0 P"temp0" Y"thermistor" T100000 A"Bed" M308 S1 P"1.temp0" Y"thermistor" T100000 A"Head0" M308 S2 P"1.temp1" Y"thermistor" T100000 A"Head1" M308 S3 P"1.temp2" Y"thermistor" T100000 A"Head2" M308 S4 P"2.temp0" Y"thermistor" T100000 A"Head3" M308 S5 P"2.temp1" Y"thermistor" T100000 A"Head4" M308 S6 P"2.temp2" Y"thermistor" T100000 A"Head5" M308 S7 P"3.temp0" Y"thermistor" T100000 A"Test" M950 H0 C"0.out1" T0 ;Bed heater M950 H1 C"1.out0" T1 ;Extruder0 M950 H2 C"1.out1" T2 ;Extruder1 M950 H3 C"1.out2" T3 ;Extruder2 ;M950 H4 C"2.out0" T4 ;Extruder3 ;M950 H5 C"2.out1" T5 ;Extruder4 ;M950 H6 C"2.out2" T6 :Extruder5
creates no error, but when I un-comment out the last few lines....
;Heaters M308 S0 P"temp0" Y"thermistor" T100000 A"Bed" M308 S1 P"1.temp0" Y"thermistor" T100000 A"Head0" M308 S2 P"1.temp1" Y"thermistor" T100000 A"Head1" M308 S3 P"1.temp2" Y"thermistor" T100000 A"Head2" M308 S4 P"2.temp0" Y"thermistor" T100000 A"Head3" M308 S5 P"2.temp1" Y"thermistor" T100000 A"Head4" M308 S6 P"2.temp2" Y"thermistor" T100000 A"Head5" M308 S7 P"3.temp0" Y"thermistor" T100000 A"Test" M950 H0 C"0.out1" T0 ;Bed heater M950 H1 C"1.out0" T1 ;Extruder0 M950 H2 C"1.out1" T2 ;Extruder1 M950 H3 C"1.out2" T3 ;Extruder2 M950 H4 C"2.out0" T4 ;Extruder3 M950 H5 C"2.out1" T5 ;Extruder4 M950 H6 C"2.out2" T6 ;Extruder5
creates an error.
12/26/2019, 2:14:33 PM Warning: Sensor number 5 has not been defined
12/26/2019, 2:14:33 PM Error: M308: Pin 2.temp1 is not free
12/26/2019, 2:14:33 PM Error: M308: Pin 2.temp2 is not free
12/26/2019, 2:14:33 PM Warning: Sensor number 6 has not been definedAnd every time I update the config I shut down the pi and cut all power for 20 seconds right now, just for grins.
-
Thanks, I have reproduced that.
-
I found the problem. For now, don't assign heater numbers greater than 5 to ports on expansion boards. Will be fixed in RC2.
-
Nice work, thank you!
-
There are new builds of Duet 3 main and expansion board firmware at https://www.dropbox.com/sh/3azy1njy3ayjsbp/AACquxr2m00eV568RZg5QG5wa?dl=0 with this fixed.
-
Confirmed Fixed.