65 Commits

Author SHA1 Message Date
Håkan Båstedt
a99d0f0eda Update README.md 2024-02-19 22:16:27 +01:00
Hakan Bastedt
c21d42cf0b Updated readme pending video release. 2024-02-19 21:51:31 +01:00
Hakan Bastedt
7ffd757fb5 After building the first board. 2024-02-19 18:02:48 +01:00
Hakan Bastedt
934f3cb028 Octave files not commited 2024-01-29 12:08:01 +01:00
Hakan Bastedt
d60822388e ordered 2024-01-26 22:02:32 +01:00
Hakan Bastedt
31d24e2676 Fab from this version 2024-01-26 16:38:10 +01:00
Hakan Bastedt
c444f9a496 Getting ready for fab 2024-01-26 16:27:17 +01:00
Hakan Bastedt
e234ea7a97 morfe copper in +5V leads 2024-01-26 13:44:45 +01:00
Hakan Bastedt
eb63adbdc2 all leds are now 0603 2024-01-26 13:21:14 +01:00
Hakan Bastedt
70014d3b1d Added 4k7 pullup onm scs_func. Think not needed since it is to a pin on stm32, but in case 2024-01-26 12:38:11 +01:00
Hakan Bastedt
990801f2d0 4.7k to 4k7 2024-01-26 01:10:08 +01:00
Hakan Bastedt
329474309d Might be in final shape. 2024-01-25 22:35:25 +01:00
Hakan Bastedt
da2b1f6376 resistor overhaul 2024-01-25 13:08:04 +01:00
Hakan Bastedt
a88090a853 wip 2024-01-25 11:31:48 +01:00
Hakan Bastedt
aa955aec67 Two-layer now 2024-01-25 00:30:19 +01:00
Hakan Bastedt
e641fd04b7 First component placement 2024-01-25 00:27:56 +01:00
Hakan Bastedt
ac711cd168 Assigned footprints 2024-01-24 20:10:20 +01:00
Hakan Bastedt
ee56f85c53 Steppers, encoders, IO, etc remapped 2024-01-24 19:44:33 +01:00
Hakan Bastedt
69357d35a4 Wip optocoupler input and outputs 2024-01-23 23:42:32 +01:00
Hakan Bastedt
84d790c687 Cleaning old gerber files. 2024-01-23 23:00:09 +01:00
Hakan Bastedt
e7fc20fec5 micros() in irq is suspicous. Some optomization of stepper parameters. Comments. 2024-01-23 22:40:15 +01:00
Hakan Bastedt
f8cec1ac69 How many times to fix it? 2024-01-23 17:51:44 +01:00
Hakan Bastedt
ddffbe5f8b Actually don't run ecat-slv_poll() 2024-01-23 15:48:59 +01:00
Håkan Båstedt
e95a098367 Update README.md 2024-01-23 13:27:26 +01:00
Hakan Bastedt
1d36ffbf69 Pending video7 release 2024-01-23 13:16:31 +01:00
Hakan Bastedt
c97e1fa96a Moved ESCvar.PrevTime. It's not used though 2024-01-23 11:22:09 +01:00
Hakan Bastedt
ef84d552e4 Debug comments 2024-01-23 11:17:00 +01:00
Hakan Bastedt
d93adac4a2 Don't run ecat_slv_poll() when expecting to serve interrupt 2024-01-23 11:00:47 +01:00
Hakan Bastedt
ca3ceac5c6 wip inputs with photodiodes etc 2024-01-21 23:31:45 +01:00
Hakan Bastedt
b534e3d4da Kludge with 'tone' of steppers. Gives ferror, but nice tone 2024-01-21 23:29:59 +01:00
Hakan Bastedt
6ac0949f26 Added optional pull-down to step generators 2024-01-21 00:24:36 +01:00
Hakan Bastedt
1f97534133 New pwmCycleTime different from sync0CycleTime 2024-01-20 12:37:42 +01:00
Hakan Bastedt
e6bfe4f880 Tests for growling. That 10xcycle time seems to do it, but it's not right. 2024-01-19 21:31:15 +01:00
Hakan Bastedt
8f05f33e58 Both steppers work in simulated environment 2024-01-18 18:21:21 +01:00
Hakan Bastedt
9e311038c1 TIM8 replaced with TIM3. TIM3,chan4 works on PC9. TIM8,chan4 should work but doesn't. How should one know? 2024-01-18 17:21:12 +01:00
Hakan Bastedt
9ab4afabe4 New enable input. Add dc ability. Set only SM2 synchronization. Various to make lathe work 2024-01-18 14:26:51 +01:00
Hakan Bastedt
38825bbaf3 Trying to make stepper suing tim8 work 2024-01-18 14:25:19 +01:00
Hakan Bastedt
0a04124b35 Remove TIM8, TIM8 is stepper generator timer. 2024-01-17 00:29:06 +01:00
Hakan Bastedt
760944afe5 Various improvements. New pdo variable stepsPerMM. 2024-01-17 00:24:17 +01:00
Hakan Bastedt
044e8fd2c5 Removed unnecessary condition in timerCB, was aleady test on ´steps´ 2024-01-15 23:10:25 +01:00
Hakan Bastedt
697ea19dae Bug, digitalWrite of stepPin should be dirPin in timerCB. Reshuffling 2024-01-15 23:07:46 +01:00
Hakan Bastedt
20ca9d4974 Maybe works better now. Using G0 can not provoke the scrape sound. Jogging for a long while can provoke still. 2024-01-15 21:12:23 +01:00
Hakan Bastedt
c6857d0be2 Still problem with overlapping cycles in stepgen. TIM8 works for stepgen now. 2024-01-15 20:21:14 +01:00
Hakan Bastedt
f14b0160f6 Spelling 2024-01-15 15:54:11 +01:00
Hakan Bastedt
deadd488dd Two stepgens active pending lathe test 2024-01-13 22:44:08 +01:00
Hakan Bastedt
25c2aa7b3c Some cleanup. 2024-01-12 14:37:25 +01:00
Hakan Bastedt
7a63d27303 Two encoders and two steppers declared. Encoder is 64-bit again 2024-01-11 21:10:27 +01:00
Hakan Bastedt
6176166b3a More encapsulation of timer info. 2024-01-11 16:44:28 +01:00
Hakan Bastedt
5df911296c sync0CycleTime static member of StepGen 2024-01-11 10:54:13 +01:00
Hakan Bastedt
a4488da9fa Cleanup encoder code 2024-01-11 10:42:29 +01:00
Hakan Bastedt
cd8388ea58 Reshuffle in main.cpp 2024-01-10 23:42:05 +01:00
Hakan Bastedt
6f29a0d492 Further cleanup and modularization 2024-01-10 22:27:04 +01:00
Hakan Bastedt
3bbf089d01 MyEncoder split into cpp and h file 2024-01-10 22:05:38 +01:00
Hakan Bastedt
2e4e768d5e Raw classified encoder. Compiles, untested 2024-01-10 21:58:11 +01:00
Hakan Bastedt
6c168d96d9 Test with different stepscale. ok 2024-01-10 20:25:26 +01:00
Hakan Bastedt
f8fc5fccd6 Max step-rate introduced - solves initial step storm 2024-01-10 20:08:30 +01:00
Hakan Bastedt
f6abd73c58 Split class into cpp and h file. Works at commands, but initial isn't ok 2024-01-10 18:59:16 +01:00
Hakan Bastedt
c5a95074dc Moved stepper into C++ class. Seems to work. Basic 2024-01-10 18:44:58 +01:00
Hakan Bastedt
8614d1dfd3 Moved stepper into C++ class. Seems to work. Basic 2024-01-10 18:44:40 +01:00
Hakan Bastedt
251fd29d23 wip 2024-01-10 15:32:45 +01:00
Hakan Bastedt
5ad02fae03 New gerber files for ax58100 for pcb quotations 2024-01-10 15:30:41 +01:00
Hakan Bastedt
9adae08b98 It seems to work now, with reload in the timer_CB. Avoid micros() 2024-01-09 22:20:20 +01:00
Hakan Bastedt
0b9ce37200 Reloading in irq might possibly work 2024-01-09 10:39:56 +01:00
Hakan Bastedt
120b423f59 Restructure, makes pulses again 2024-01-08 21:13:34 +01:00
Hakan Bastedt
222e5857dc Reorganize 2024-01-07 19:38:22 +01:00
230 changed files with 63014 additions and 60250 deletions

1
.gitignore vendored
View File

@@ -3,3 +3,4 @@
.vscode/c_cpp_properties.json .vscode/c_cpp_properties.json
.vscode/launch.json .vscode/launch.json
.vscode/ipch .vscode/ipch
Octave

View File

@@ -9,8 +9,9 @@ Mcu.CPN=STM32F407VGT6
Mcu.Family=STM32F4 Mcu.Family=STM32F4
Mcu.IP0=DAC Mcu.IP0=DAC
Mcu.IP1=I2C2 Mcu.IP1=I2C2
Mcu.IP10=TIM8 Mcu.IP10=TIM5
Mcu.IP11=USART1 Mcu.IP11=TIM9
Mcu.IP12=USART1
Mcu.IP2=NVIC Mcu.IP2=NVIC
Mcu.IP3=RCC Mcu.IP3=RCC
Mcu.IP4=SPI1 Mcu.IP4=SPI1
@@ -19,48 +20,44 @@ Mcu.IP6=TIM1
Mcu.IP7=TIM2 Mcu.IP7=TIM2
Mcu.IP8=TIM3 Mcu.IP8=TIM3
Mcu.IP9=TIM4 Mcu.IP9=TIM4
Mcu.IPNb=12 Mcu.IPNb=13
Mcu.Name=STM32F407V(E-G)Tx Mcu.Name=STM32F407V(E-G)Tx
Mcu.Package=LQFP100 Mcu.Package=LQFP100
Mcu.Pin0=PA0-WKUP Mcu.Pin0=PE5
Mcu.Pin1=PA1 Mcu.Pin1=PA0-WKUP
Mcu.Pin10=PB1 Mcu.Pin10=PB0
Mcu.Pin11=PE7 Mcu.Pin11=PB1
Mcu.Pin12=PE8 Mcu.Pin12=PE7
Mcu.Pin13=PE9 Mcu.Pin13=PE8
Mcu.Pin14=PE10 Mcu.Pin14=PE9
Mcu.Pin15=PE11 Mcu.Pin15=PE10
Mcu.Pin16=PE12 Mcu.Pin16=PE11
Mcu.Pin17=PE13 Mcu.Pin17=PE12
Mcu.Pin18=PE14 Mcu.Pin18=PE13
Mcu.Pin19=PE15 Mcu.Pin19=PE14
Mcu.Pin2=PA2 Mcu.Pin2=PA1
Mcu.Pin20=PB10 Mcu.Pin20=PE15
Mcu.Pin21=PB11 Mcu.Pin21=PB10
Mcu.Pin22=PD11 Mcu.Pin22=PB11
Mcu.Pin23=PD12 Mcu.Pin23=PD11
Mcu.Pin24=PD13 Mcu.Pin24=PD12
Mcu.Pin25=PC6 Mcu.Pin25=PC9
Mcu.Pin26=PC7 Mcu.Pin26=PA8
Mcu.Pin27=PC9 Mcu.Pin27=PA9
Mcu.Pin28=PA8 Mcu.Pin28=PA10
Mcu.Pin29=PA9 Mcu.Pin29=PA11
Mcu.Pin3=PA4 Mcu.Pin3=PA2
Mcu.Pin30=PA10 Mcu.Pin30=PA12
Mcu.Pin31=PA11 Mcu.Pin31=PC10
Mcu.Pin32=PA12 Mcu.Pin32=PB6
Mcu.Pin33=PC10 Mcu.Pin33=VP_SYS_VS_Systick
Mcu.Pin34=PB4 Mcu.Pin4=PA4
Mcu.Pin35=PB5 Mcu.Pin5=PA5
Mcu.Pin36=PB6 Mcu.Pin6=PA6
Mcu.Pin37=VP_SYS_VS_Systick Mcu.Pin7=PA7
Mcu.Pin4=PA5 Mcu.Pin8=PC4
Mcu.Pin5=PA6 Mcu.Pin9=PC5
Mcu.Pin6=PA7 Mcu.PinsNb=34
Mcu.Pin7=PC4
Mcu.Pin8=PC5
Mcu.Pin9=PB0
Mcu.PinsNb=38
Mcu.ThirdPartyNb=0 Mcu.ThirdPartyNb=0
Mcu.UserConstants= Mcu.UserConstants=
Mcu.UserName=STM32F407VGTx Mcu.UserName=STM32F407VGTx
@@ -84,8 +81,7 @@ PA10.Signal=USART1_RX
PA11.Signal=S_TIM1_CH4 PA11.Signal=S_TIM1_CH4
PA12.Locked=true PA12.Locked=true
PA12.Signal=GPIO_Output PA12.Signal=GPIO_Output
PA2.Locked=true PA2.Signal=S_TIM5_CH3
PA2.Signal=GPIO_Input
PA4.Signal=COMP_DAC1_group PA4.Signal=COMP_DAC1_group
PA5.Mode=Full_Duplex_Master PA5.Mode=Full_Duplex_Master
PA5.Signal=SPI1_SCK PA5.Signal=SPI1_SCK
@@ -105,8 +101,6 @@ PB10.Mode=I2C
PB10.Signal=I2C2_SCL PB10.Signal=I2C2_SCL
PB11.Mode=I2C PB11.Mode=I2C
PB11.Signal=I2C2_SDA PB11.Signal=I2C2_SDA
PB4.Signal=S_TIM3_CH1
PB5.Signal=S_TIM3_CH2
PB6.Locked=true PB6.Locked=true
PB6.Signal=GPIO_Input PB6.Signal=GPIO_Input
PC10.Locked=true PC10.Locked=true
@@ -115,13 +109,10 @@ PC4.Locked=true
PC4.Signal=GPIO_Output PC4.Signal=GPIO_Output
PC5.Locked=true PC5.Locked=true
PC5.Signal=GPIO_Input PC5.Signal=GPIO_Input
PC6.Signal=S_TIM8_CH1 PC9.Signal=S_TIM3_CH4
PC7.Signal=S_TIM8_CH2
PC9.Signal=S_TIM8_CH4
PD11.Locked=true PD11.Locked=true
PD11.Signal=GPIO_Input PD11.Signal=GPIO_Input
PD12.Signal=S_TIM4_CH1 PD12.Signal=S_TIM4_CH1
PD13.Signal=S_TIM4_CH2
PE10.Locked=true PE10.Locked=true
PE10.Signal=GPIO_Output PE10.Signal=GPIO_Output
PE11.Locked=true PE11.Locked=true
@@ -134,6 +125,7 @@ PE14.Locked=true
PE14.Signal=GPIO_Input PE14.Signal=GPIO_Input
PE15.Locked=true PE15.Locked=true
PE15.Signal=GPIO_Input PE15.Signal=GPIO_Input
PE5.Signal=S_TIM9_CH1
PE7.Locked=true PE7.Locked=true
PE7.Signal=GPIO_Output PE7.Signal=GPIO_Output
PE8.Locked=true PE8.Locked=true
@@ -200,20 +192,14 @@ SH.S_TIM2_CH1_ETR.0=TIM2_CH1,Encoder_Interface
SH.S_TIM2_CH1_ETR.ConfNb=1 SH.S_TIM2_CH1_ETR.ConfNb=1
SH.S_TIM2_CH2.0=TIM2_CH2,Encoder_Interface SH.S_TIM2_CH2.0=TIM2_CH2,Encoder_Interface
SH.S_TIM2_CH2.ConfNb=1 SH.S_TIM2_CH2.ConfNb=1
SH.S_TIM3_CH1.0=TIM3_CH1,Encoder_Interface SH.S_TIM3_CH4.0=TIM3_CH4,PWM Generation4 CH4
SH.S_TIM3_CH1.ConfNb=1 SH.S_TIM3_CH4.ConfNb=1
SH.S_TIM3_CH2.0=TIM3_CH2,Encoder_Interface SH.S_TIM4_CH1.0=TIM4_CH1,PWM Generation1 CH1
SH.S_TIM3_CH2.ConfNb=1
SH.S_TIM4_CH1.0=TIM4_CH1,Encoder_Interface
SH.S_TIM4_CH1.ConfNb=1 SH.S_TIM4_CH1.ConfNb=1
SH.S_TIM4_CH2.0=TIM4_CH2,Encoder_Interface SH.S_TIM5_CH3.0=TIM5_CH3,Input_Capture3_from_TI3
SH.S_TIM4_CH2.ConfNb=1 SH.S_TIM5_CH3.ConfNb=1
SH.S_TIM8_CH1.0=TIM8_CH1,Encoder_Interface SH.S_TIM9_CH1.0=TIM9_CH1,PWM Generation1 CH1
SH.S_TIM8_CH1.ConfNb=1 SH.S_TIM9_CH1.ConfNb=1
SH.S_TIM8_CH2.0=TIM8_CH2,Encoder_Interface
SH.S_TIM8_CH2.ConfNb=1
SH.S_TIM8_CH4.0=TIM8_CH4,PWM Generation4 CH4
SH.S_TIM8_CH4.ConfNb=1
SPI1.CalculateBaudRate=8.0 MBits/s SPI1.CalculateBaudRate=8.0 MBits/s
SPI1.Direction=SPI_DIRECTION_2LINES SPI1.Direction=SPI_DIRECTION_2LINES
SPI1.IPParameters=VirtualType,Mode,Direction,CalculateBaudRate SPI1.IPParameters=VirtualType,Mode,Direction,CalculateBaudRate
@@ -221,8 +207,14 @@ SPI1.Mode=SPI_MODE_MASTER
SPI1.VirtualType=VM_MASTER SPI1.VirtualType=VM_MASTER
TIM1.Channel-PWM\ Generation4\ CH4=TIM_CHANNEL_4 TIM1.Channel-PWM\ Generation4\ CH4=TIM_CHANNEL_4
TIM1.IPParameters=Channel-PWM Generation4 CH4 TIM1.IPParameters=Channel-PWM Generation4 CH4
TIM8.Channel-PWM\ Generation4\ CH4=TIM_CHANNEL_4 TIM3.Channel-PWM\ Generation4\ CH4=TIM_CHANNEL_4
TIM8.IPParameters=Channel-PWM Generation4 CH4 TIM3.IPParameters=Channel-PWM Generation4 CH4
TIM4.Channel-PWM\ Generation1\ CH1=TIM_CHANNEL_1
TIM4.IPParameters=Channel-PWM Generation1 CH1
TIM5.Channel-Input_Capture3_from_TI3=TIM_CHANNEL_3
TIM5.IPParameters=Channel-Input_Capture3_from_TI3
TIM9.Channel-PWM\ Generation1\ CH1=TIM_CHANNEL_1
TIM9.IPParameters=Channel-PWM Generation1 CH1
USART1.IPParameters=VirtualMode USART1.IPParameters=VirtualMode
USART1.VirtualMode=VM_ASYNC USART1.VirtualMode=VM_ASYNC
VP_SYS_VS_Systick.Mode=SysTick VP_SYS_VS_Systick.Mode=SysTick

View File

Before

Width:  |  Height:  |  Size: 46 KiB

After

Width:  |  Height:  |  Size: 46 KiB

View File

Before

Width:  |  Height:  |  Size: 17 KiB

After

Width:  |  Height:  |  Size: 17 KiB

View File

@@ -1,6 +1,6 @@
<head> <head>
<meta charset="UTF-8"> <meta charset="UTF-8">
<title>🔁 EEPROM Generator | ESI, EEPORM, SOES C code configuration tool</title> <title>🔁 EEPROM Generator | ESI, EEPROM, SOES C code configuration tool</title>
<!-- <!--
* SOES EEPROM generator * SOES EEPROM generator
* This tool serves as: * This tool serves as:
@@ -52,10 +52,12 @@
<option value="INTEGER8">INTEGER8</option> <option value="INTEGER8">INTEGER8</option>
<option value="INTEGER16">INTEGER16</option> <option value="INTEGER16">INTEGER16</option>
<option value="INTEGER32">INTEGER32</option> <option value="INTEGER32">INTEGER32</option>
<option value="INTEGER64">INTEGER64</option>
<option value="UNSIGNED8">UNSIGNED8</option> <option value="UNSIGNED8">UNSIGNED8</option>
<option value="UNSIGNED16">UNSIGNED16</option> <option value="UNSIGNED16">UNSIGNED16</option>
<option value="UNSIGNED32">UNSIGNED32</option> <option value="UNSIGNED32">UNSIGNED64</option>
<option value="REAL32">REAL32</option> <option value="REAL32">REAL32</option>
<option value="REAL64">REAL64</option>
<option value="VISIBLE_STRING">VISIBLE STRING</option> <option value="VISIBLE_STRING">VISIBLE STRING</option>
</select></td> </select></td>
</tr> </tr>
@@ -412,4 +414,4 @@
<input id="restoreFileInput" type='file' accept=".json" style="visibility:hidden;" onchange="readFile(event)" /> <input id="restoreFileInput" type='file' accept=".json" style="visibility:hidden;" onchange="readFile(event)" />
</form> </form>
</div> </div>
</body> </body>

View File

Before

Width:  |  Height:  |  Size: 1.5 KiB

After

Width:  |  Height:  |  Size: 1.5 KiB

View File

@@ -28,10 +28,13 @@ const DTYPE = {
INTEGER8 : 'INTEGER8', INTEGER8 : 'INTEGER8',
INTEGER16 : 'INTEGER16', INTEGER16 : 'INTEGER16',
INTEGER32 : 'INTEGER32', INTEGER32 : 'INTEGER32',
INTEGER32 : 'INTEGER64',
UNSIGNED8 : 'UNSIGNED8', UNSIGNED8 : 'UNSIGNED8',
UNSIGNED16 : 'UNSIGNED16', UNSIGNED16 : 'UNSIGNED16',
UNSIGNED32 : 'UNSIGNED32', UNSIGNED32 : 'UNSIGNED32',
UNSIGNED32 : 'UNSIGNED64',
REAL32 : 'REAL32', REAL32 : 'REAL32',
REAL64 : 'REAL64',
VISIBLE_STRING : 'VISIBLE_STRING', VISIBLE_STRING : 'VISIBLE_STRING',
/* TODO implement missing less common types */ /* TODO implement missing less common types */
// OCTET_STRING : 'OCTET_STRING', // OCTET_STRING : 'OCTET_STRING',
@@ -49,10 +52,13 @@ const dtype_bitsize = {
'INTEGER8' : 8, 'INTEGER8' : 8,
'INTEGER16' : 16, 'INTEGER16' : 16,
'INTEGER32' : 32, 'INTEGER32' : 32,
'INTEGER64' : 64,
'UNSIGNED8' : 8, 'UNSIGNED8' : 8,
'UNSIGNED16' : 16, 'UNSIGNED16' : 16,
'UNSIGNED32' : 32, 'UNSIGNED32' : 32,
'UNSIGNED64' : 64,
'REAL32' : 32, 'REAL32' : 32,
'REAL64' : 64,
'VISIBLE_STRING' : 8, 'VISIBLE_STRING' : 8,
}; };
const booleanPaddingBitsize = 7; const booleanPaddingBitsize = 7;
@@ -62,10 +68,13 @@ const ESI_DT = {
'INTEGER8': { name: 'SINT', bitsize: 8, ctype: 'int8_t' }, 'INTEGER8': { name: 'SINT', bitsize: 8, ctype: 'int8_t' },
'INTEGER16': { name: 'INT', bitsize: 16, ctype: 'int16_t' }, 'INTEGER16': { name: 'INT', bitsize: 16, ctype: 'int16_t' },
'INTEGER32': { name: 'DINT', bitsize: 32, ctype: 'int32_t' }, 'INTEGER32': { name: 'DINT', bitsize: 32, ctype: 'int32_t' },
'INTEGER64': { name: 'LINT', bitsize: 64, ctype: 'int64_t' },
'UNSIGNED8': { name: 'USINT', bitsize: 8, ctype: 'uint8_t' }, 'UNSIGNED8': { name: 'USINT', bitsize: 8, ctype: 'uint8_t' },
'UNSIGNED16': { name: 'UINT', bitsize: 16, ctype: 'uint16_t' }, 'UNSIGNED16': { name: 'UINT', bitsize: 16, ctype: 'uint16_t' },
'UNSIGNED32': { name: 'UDINT', bitsize: 32, ctype: 'uint32_t' }, 'UNSIGNED32': { name: 'UDINT', bitsize: 32, ctype: 'uint32_t' },
'REAL32': { name: 'REAL', bitsize: 32, ctype: 'float' }, // TODO check C type name 'UNSIGNED64': { name: 'ULINT', bitsize: 64, ctype: 'uint64_t' },
'REAL32': { name: 'REAL', bitsize: 32, ctype: 'float' },
'REAL64': { name: 'LREAL', bitsize: 64, ctype: 'double' },
'VISIBLE_STRING': { name: 'STRING', bitsize: 8, ctype: 'char *' }, // TODO check C type name 'VISIBLE_STRING': { name: 'STRING', bitsize: 8, ctype: 'char *' }, // TODO check C type name
}; };

View File

@@ -8,6 +8,10 @@
"string": "cpp", "string": "cpp",
"unordered_map": "cpp", "unordered_map": "cpp",
"vector": "cpp", "vector": "cpp",
"system_error": "cpp" "system_error": "cpp",
} "numeric": "cpp",
"ostream": "cpp"
},
"C_Cpp.errorSquiggles": "disabled",
"cmake.configureOnOpen": false
} }

37
Firmware/include/MyEncoder.h Executable file
View File

@@ -0,0 +1,37 @@
#ifndef MYENCODER
#define MYENCODER
#include "Stm32F4_Encoder.h"
#include <CircularBuffer.h>
#define RINGBUFFERLEN 101
class MyEncoder
{
public:
MyEncoder(TIM_TypeDef *_tim_base, uint8_t _indexPin, void irq(void));
int64_t unwrapEncoder(uint16_t in);
void indexPulse(void);
uint8_t indexHappened();
double currentPos();
double frequency(uint64_t time);
uint8_t getIndexState();
void setScale(double scale);
void setLatch(uint8_t latchEnable);
private:
int64_t previousEncoderCounterValue = 0;
double PosScaleRes = 1.0;
uint32_t CurPosScale = 1;
uint8_t oldLatchCEnable = 0;
volatile uint8_t indexPulseFired = 0;
volatile uint8_t pleaseZeroTheCounter = 0;
Encoder EncoderInit;
uint8_t indexPin;
CircularBuffer<double_t, RINGBUFFERLEN> Pos;
CircularBuffer<uint32_t, RINGBUFFERLEN> TDelta;
double curPos;
TIM_TypeDef *tim_base;
};
#endif

42
Firmware/include/StepGen.h Executable file
View File

@@ -0,0 +1,42 @@
#ifndef STEPGEN
#define STEPGEN
#include <HardwareTimer.h>
class StepGen
{
private:
volatile uint8_t timerIsRunning;
volatile int32_t timerStepPosition;
volatile int32_t timerStepDirection;
volatile int32_t timerStepPositionAtEnd;
volatile int32_t timerNewEndStepPosition;
volatile uint32_t timerNewCycleTime;
volatile double_t actualPosition;
volatile double_t requestedPosition;
volatile uint8_t enabled;
HardwareTimer *MyTim;
uint16_t stepsPerMM;
uint8_t dirPin;
PinName stepPin;
uint32_t timerChan;
const uint32_t maxFreq = 100000;
volatile uint32_t prevFreq1 = 0;
volatile uint32_t prevFreq2 = 0;
public:
static uint32_t sync0CycleTime;
volatile uint32_t pwmCycleTime;
StepGen(TIM_TypeDef *Timer, uint32_t timerChannel, PinName stepPin, uint8_t dirPin, void irq(void));
void reqPos(double_t pos);
double reqPos();
void actPos(double_t pos);
double actPos();
void handleStepper(void);
void timerCB();
void setScale(int16_t spm);
void enable(uint8_t yes);
};
#endif

View File

@@ -0,0 +1,651 @@
#ifndef __Stm32F4_Encoder_H__
#define __Stm32F4_Encoder_H__
#include <Arduino.h>
#define GPIO_Speed_50MHz 0x02 /*!< Fast speed */
// #define GPIO_MODER_MODER0 ((uint32_t)0x00000003)
#define GPIO_Mode_OUT 0x01
// #define GPIO_OSPEEDER_OSPEEDR0 ((uint32_t)0x00000003)
// #define GPIO_OTYPER_OT_0 ((uint32_t)0x00000001)
// #define GPIO_PUPDR_PUPDR0 ((uint32_t)0x00000003)
#define GPIO_PuPd_NOPULL 0x00
#define GPIO_Mode_AF 0x02
#define GPIO_OType_PP 0x00
#define GPIO_PuPd_NOPULL 0x00
#define GPIO_Pin_0 ((uint16_t)0x0001) /* Pin 0 selected */
#define GPIO_Pin_1 ((uint16_t)0x0002) /* Pin 1 selected */
#define GPIO_Pin_2 ((uint16_t)0x0004) /* Pin 2 selected */
#define GPIO_Pin_3 ((uint16_t)0x0008) /* Pin 3 selected */
#define GPIO_Pin_4 ((uint16_t)0x0010) /* Pin 4 selected */
#define GPIO_Pin_5 ((uint16_t)0x0020) /* Pin 5 selected */
#define GPIO_Pin_6 ((uint16_t)0x0040) /* Pin 6 selected */
#define GPIO_Pin_7 ((uint16_t)0x0080) /* Pin 7 selected */
#define GPIO_Pin_8 ((uint16_t)0x0100) /* Pin 8 selected */
#define GPIO_Pin_9 ((uint16_t)0x0200) /* Pin 9 selected */
#define GPIO_Pin_10 ((uint16_t)0x0400) /* Pin 10 selected */
#define GPIO_Pin_11 ((uint16_t)0x0800) /* Pin 11 selected */
#define GPIO_Pin_12 ((uint16_t)0x1000) /* Pin 12 selected */
#define GPIO_Pin_13 ((uint16_t)0x2000) /* Pin 13 selected */
#define GPIO_Pin_14 ((uint16_t)0x4000) /* Pin 14 selected */
#define GPIO_Pin_15 ((uint16_t)0x8000) /* Pin 15 selected */
#define GPIO_Pin_All ((uint16_t)0xFFFF) /* All pins selected */
typedef struct TIM_TimeBaseInitTypeDef
{
uint16_t TIM_Prescaler; /*!< Specifies the prescaler value used to divide the TIM clock.
This parameter can be a number between 0x0000 and 0xFFFF */
uint16_t TIM_CounterMode; /*!< Specifies the counter mode.
This parameter can be a value of @ref TIM_Counter_Mode */
uint32_t TIM_Period; /*!< Specifies the period value to be loaded into the active
Auto-Reload Register at the next update event.
This parameter must be a number between 0x0000 and 0xFFFF. */
uint16_t TIM_ClockDivision; /*!< Specifies the clock division.
This parameter can be a value of @ref TIM_Clock_Division_CKD */
uint8_t TIM_RepetitionCounter; /*!< Specifies the repetition counter value. Each time the RCR downcounter
reaches zero, an update event is generated and counting restarts
from the RCR value (N).
This means in PWM mode that (N+1) corresponds to:
- the number of PWM periods in edge-aligned mode
- the number of half PWM period in center-aligned mode
This parameter must be a number between 0x00 and 0xFF.
@note This parameter is valid only for TIM1 and TIM8. */
} TIM_TimeBaseInitTypeDef;
typedef struct
{
uint16_t setcount;
} encoder;
typedef struct
{
uint16_t TIM_OCMode; /*!< Specifies the TIM mode.
This parameter can be a value of @ref TIM_Output_Compare_and_PWM_modes */
uint16_t TIM_OutputState; /*!< Specifies the TIM Output Compare state.
This parameter can be a value of @ref TIM_Output_Compare_State */
uint16_t TIM_OutputNState; /*!< Specifies the TIM complementary Output Compare state.
This parameter can be a value of @ref TIM_Output_Compare_N_State
@note This parameter is valid only for TIM1 and TIM8. */
uint32_t TIM_Pulse; /*!< Specifies the pulse value to be loaded into the Capture Compare Register.
This parameter can be a number between 0x0000 and 0xFFFF */
uint16_t TIM_OCPolarity; /*!< Specifies the output polarity.
This parameter can be a value of @ref TIM_Output_Compare_Polarity */
uint16_t TIM_OCNPolarity; /*!< Specifies the complementary output polarity.
This parameter can be a value of @ref TIM_Output_Compare_N_Polarity
@note This parameter is valid only for TIM1 and TIM8. */
uint16_t TIM_OCIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state.
This parameter can be a value of @ref TIM_Output_Compare_Idle_State
@note This parameter is valid only for TIM1 and TIM8. */
uint16_t TIM_OCNIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state.
This parameter can be a value of @ref TIM_Output_Compare_N_Idle_State
@note This parameter is valid only for TIM1 and TIM8. */
} TIM_OCInitTypeDef;
typedef struct
{
uint16_t TIM_Channel; /*!< Specifies the TIM channel.
This parameter can be a value of @ref TIM_Channel */
uint16_t TIM_ICPolarity; /*!< Specifies the active edge of the input signal.
This parameter can be a value of @ref TIM_Input_Capture_Polarity */
uint16_t TIM_ICSelection; /*!< Specifies the input.
This parameter can be a value of @ref TIM_Input_Capture_Selection */
uint16_t TIM_ICPrescaler; /*!< Specifies the Input Capture Prescaler.
This parameter can be a value of @ref TIM_Input_Capture_Prescaler */
uint16_t TIM_ICFilter; /*!< Specifies the input capture filter.
This parameter can be a number between 0x0 and 0xF */
} TIM_ICInitTypeDef;
typedef struct
{
uint16_t TIM_OSSRState; /*!< Specifies the Off-State selection used in Run mode.
This parameter can be a value of @ref TIM_OSSR_Off_State_Selection_for_Run_mode_state */
uint16_t TIM_OSSIState; /*!< Specifies the Off-State used in Idle state.
This parameter can be a value of @ref TIM_OSSI_Off_State_Selection_for_Idle_mode_state */
uint16_t TIM_LOCKLevel; /*!< Specifies the LOCK level parameters.
This parameter can be a value of @ref TIM_Lock_level */
uint16_t TIM_DeadTime; /*!< Specifies the delay time between the switching-off and the
switching-on of the outputs.
This parameter can be a number between 0x00 and 0xFF */
uint16_t TIM_Break; /*!< Specifies whether the TIM Break input is enabled or not.
This parameter can be a value of @ref TIM_Break_Input_enable_disable */
uint16_t TIM_BreakPolarity; /*!< Specifies the TIM Break Input pin polarity.
This parameter can be a value of @ref TIM_Break_Polarity */
uint16_t TIM_AutomaticOutput; /*!< Specifies whether the TIM Automatic Output feature is enabled or not.
This parameter can be a value of @ref TIM_AOE_Bit_Set_Reset */
} TIM_BDTRInitTypeDef;
#define GPIO_PinSource0 ((uint8_t)0x00)
#define GPIO_PinSource1 ((uint8_t)0x01)
#define GPIO_PinSource2 ((uint8_t)0x02)
#define GPIO_PinSource3 ((uint8_t)0x03)
#define GPIO_PinSource4 ((uint8_t)0x04)
#define GPIO_PinSource5 ((uint8_t)0x05)
#define GPIO_PinSource6 ((uint8_t)0x06)
#define GPIO_PinSource7 ((uint8_t)0x07)
#define GPIO_PinSource8 ((uint8_t)0x08)
#define GPIO_PinSource9 ((uint8_t)0x09)
#define GPIO_PinSource10 ((uint8_t)0x0A)
#define GPIO_PinSource11 ((uint8_t)0x0B)
#define GPIO_PinSource12 ((uint8_t)0x0C)
#define GPIO_PinSource13 ((uint8_t)0x0D)
#define GPIO_PinSource14 ((uint8_t)0x0E)
#define GPIO_PinSource15 ((uint8_t)0x0F)
#define GPIO_AF_TIM8 ((uint8_t)0x03) /* TIM8 Alternate Function mapping */
#define GPIO_AF_TIM3 ((uint8_t)0x02) /* TIM3 Alternate Function mapping */
#define GPIO_AF_TIM4 ((uint8_t)0x02) /* TIM4 Alternate Function mapping */
#define GPIO_AF_TIM5 ((uint8_t)0x02) /* TIM5 Alternate Function mapping */
#define GPIO_AF_TIM1 ((uint8_t)0x01) /* TIM1 Alternate Function mapping */
#define GPIO_AF_TIM2 ((uint8_t)0x01) /* TIM2 Alternate Function mapping */
// #define TIM4 ((TIM_TypeDef *)TIM4_BASE)
// #define TIM8 ((TIM_TypeDef *)TIM8_BASE)
#define TIM_EncoderMode_TI12 ((uint16_t)0x0003)
#define TIM_ICPolarity_Rising ((uint16_t)0x0000)
#define TIM_ICPolarity_Falling ((uint16_t)0x0002)
// #define TIM_CR1_CEN ((uint16_t)0x0001) /*!<Counter enable */
// #define TIM_CR1_CEN ((uint16_t)0x0001) /*!<Counter enable */
#define IS_TIM_ALL_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
((PERIPH) == TIM2) || \
((PERIPH) == TIM3) || \
((PERIPH) == TIM4) || \
((PERIPH) == TIM5) || \
((PERIPH) == TIM6) || \
((PERIPH) == TIM7) || \
((PERIPH) == TIM8) || \
((PERIPH) == TIM9) || \
((PERIPH) == TIM10) || \
((PERIPH) == TIM11) || \
((PERIPH) == TIM12) || \
(((PERIPH) == TIM13) || \
((PERIPH) == TIM14)))
#define IS_TIM_LIST1_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
((PERIPH) == TIM2) || \
((PERIPH) == TIM3) || \
((PERIPH) == TIM4) || \
((PERIPH) == TIM5) || \
((PERIPH) == TIM8) || \
((PERIPH) == TIM9) || \
((PERIPH) == TIM10) || \
((PERIPH) == TIM11) || \
((PERIPH) == TIM12) || \
((PERIPH) == TIM13) || \
((PERIPH) == TIM14))
#define IS_TIM_LIST2_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
((PERIPH) == TIM2) || \
((PERIPH) == TIM3) || \
((PERIPH) == TIM4) || \
((PERIPH) == TIM5) || \
((PERIPH) == TIM8) || \
((PERIPH) == TIM9) || \
((PERIPH) == TIM12))
#define IS_TIM_LIST3_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
((PERIPH) == TIM2) || \
((PERIPH) == TIM3) || \
((PERIPH) == TIM4) || \
((PERIPH) == TIM5) || \
((PERIPH) == TIM8))
#define IS_TIM_LIST4_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
((PERIPH) == TIM8))
#define IS_TIM_LIST5_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
((PERIPH) == TIM2) || \
((PERIPH) == TIM3) || \
((PERIPH) == TIM4) || \
((PERIPH) == TIM5) || \
((PERIPH) == TIM6) || \
((PERIPH) == TIM7) || \
((PERIPH) == TIM8))
#define IS_TIM_LIST6_PERIPH(TIMx) (((TIMx) == TIM2) || \
((TIMx) == TIM5) || \
((TIMx) == TIM11))
#define TIM_OCMode_Timing ((uint16_t)0x0000)
#define TIM_OCMode_Active ((uint16_t)0x0010)
#define TIM_OCMode_Inactive ((uint16_t)0x0020)
#define TIM_OCMode_Toggle ((uint16_t)0x0030)
#define TIM_OCMode_PWM1 ((uint16_t)0x0060)
#define TIM_OCMode_PWM2 ((uint16_t)0x0070)
//#define IS_TIM_OC_MODE(MODE) (((MODE) == TIM_OCMode_Timing) || \
// ((MODE) == TIM_OCMode_Active) || \
// ((MODE) == TIM_OCMode_Inactive) || \
// ((MODE) == TIM_OCMode_Toggle)|| \
// ((MODE) == TIM_OCMode_PWM1) || \
// ((MODE) == TIM_OCMode_PWM2))
#define IS_TIM_OCM(MODE) (((MODE) == TIM_OCMode_Timing) || \
((MODE) == TIM_OCMode_Active) || \
((MODE) == TIM_OCMode_Inactive) || \
((MODE) == TIM_OCMode_Toggle) || \
((MODE) == TIM_OCMode_PWM1) || \
((MODE) == TIM_OCMode_PWM2) || \
((MODE) == TIM_ForcedAction_Active) || \
((MODE) == TIM_ForcedAction_InActive))
#define TIM_OPMode_Single ((uint16_t)0x0008)
#define TIM_OPMode_Repetitive ((uint16_t)0x0000)
//#define IS_TIM_OPM_MODE(MODE) (((MODE) == TIM_OPMode_Single) || \
// ((MODE) == TIM_OPMode_Repetitive))
#define TIM_Channel_1 ((uint16_t)0x0000)
#define TIM_Channel_2 ((uint16_t)0x0004)
#define TIM_Channel_3 ((uint16_t)0x0008)
#define TIM_Channel_4 ((uint16_t)0x000C)
#define IS_TIM_CHANNEL(CHANNEL) (((CHANNEL) == TIM_Channel_1) || \
((CHANNEL) == TIM_Channel_2) || \
((CHANNEL) == TIM_Channel_3) || \
((CHANNEL) == TIM_Channel_4))
#define IS_TIM_PWMI_CHANNEL(CHANNEL) (((CHANNEL) == TIM_Channel_1) || \
((CHANNEL) == TIM_Channel_2))
#define IS_TIM_COMPLEMENTARY_CHANNEL(CHANNEL) (((CHANNEL) == TIM_Channel_1) || \
((CHANNEL) == TIM_Channel_2) || \
((CHANNEL) == TIM_Channel_3))
#define TIM_CKD_DIV1 ((uint16_t)0x0000)
#define TIM_CKD_DIV2 ((uint16_t)0x0100)
#define TIM_CKD_DIV4 ((uint16_t)0x0200)
#define IS_TIM_CKD_DIV(DIV) (((DIV) == TIM_CKD_DIV1) || \
((DIV) == TIM_CKD_DIV2) || \
((DIV) == TIM_CKD_DIV4))
#define TIM_CounterMode_Up ((uint16_t)0x0000)
#define TIM_CounterMode_Down ((uint16_t)0x0010)
#define TIM_CounterMode_CenterAligned1 ((uint16_t)0x0020)
#define TIM_CounterMode_CenterAligned2 ((uint16_t)0x0040)
#define TIM_CounterMode_CenterAligned3 ((uint16_t)0x0060)
//#define IS_TIM_COUNTER_MODE(MODE) (((MODE) == TIM_CounterMode_Up) || \
// ((MODE) == TIM_CounterMode_Down) || \
// ((MODE) == TIM_CounterMode_CenterAligned1) || \
// ((MODE) == TIM_CounterMode_CenterAligned2) || \
// ((MODE) == TIM_CounterMode_CenterAligned3))
#define TIM_OCPolarity_High ((uint16_t)0x0000)
#define TIM_OCPolarity_Low ((uint16_t)0x0002)
//#define IS_TIM_OC_POLARITY(POLARITY) (((POLARITY) == TIM_OCPolarity_High) || \
// ((POLARITY) == TIM_OCPolarity_Low))
#define TIM_OCNPolarity_High ((uint16_t)0x0000)
#define TIM_OCNPolarity_Low ((uint16_t)0x0008)
//#define IS_TIM_OCN_POLARITY(POLARITY) (((POLARITY) == TIM_OCNPolarity_High) || \
// ((POLARITY) == TIM_OCNPolarity_Low))
#define TIM_OutputState_Disable ((uint16_t)0x0000)
#define TIM_OutputState_Enable ((uint16_t)0x0001)
#define IS_TIM_OUTPUT_STATE(STATE) (((STATE) == TIM_OutputState_Disable) || \
((STATE) == TIM_OutputState_Enable))
#define TIM_OutputNState_Disable ((uint16_t)0x0000)
#define TIM_OutputNState_Enable ((uint16_t)0x0004)
#define IS_TIM_OUTPUTN_STATE(STATE) (((STATE) == TIM_OutputNState_Disable) || \
((STATE) == TIM_OutputNState_Enable))
#define TIM_CCx_Enable ((uint16_t)0x0001)
#define TIM_CCx_Disable ((uint16_t)0x0000)
#define IS_TIM_CCX(CCX) (((CCX) == TIM_CCx_Enable) || \
((CCX) == TIM_CCx_Disable))
#define TIM_CCxN_Enable ((uint16_t)0x0004)
#define TIM_CCxN_Disable ((uint16_t)0x0000)
#define IS_TIM_CCXN(CCXN) (((CCXN) == TIM_CCxN_Enable) || \
((CCXN) == TIM_CCxN_Disable))
#define TIM_Break_Enable ((uint16_t)0x1000)
#define TIM_Break_Disable ((uint16_t)0x0000)
//#define IS_TIM_BREAK_STATE(STATE) (((STATE) == TIM_Break_Enable) || \
// ((STATE) == TIM_Break_Disable))
#define TIM_BreakPolarity_Low ((uint16_t)0x0000)
#define TIM_BreakPolarity_High ((uint16_t)0x2000)
//#define IS_TIM_BREAK_POLARITY(POLARITY) (((POLARITY) == TIM_BreakPolarity_Low) || \
// ((POLARITY) == TIM_BreakPolarity_High))
#define TIM_AutomaticOutput_Enable ((uint16_t)0x4000)
#define TIM_AutomaticOutput_Disable ((uint16_t)0x0000)
//#define IS_TIM_AUTOMATIC_OUTPUT_STATE(STATE) (((STATE) == TIM_AutomaticOutput_Enable) || \
// ((STATE) == TIM_AutomaticOutput_Disable))
#define TIM_LOCKLevel_OFF ((uint16_t)0x0000)
#define TIM_LOCKLevel_1 ((uint16_t)0x0100)
#define TIM_LOCKLevel_2 ((uint16_t)0x0200)
#define TIM_LOCKLevel_3 ((uint16_t)0x0300)
//#define IS_TIM_LOCK_LEVEL(LEVEL) (((LEVEL) == TIM_LOCKLevel_OFF) || \
// ((LEVEL) == TIM_LOCKLevel_1) || \
// ((LEVEL) == TIM_LOCKLevel_2) || \
// ((LEVEL) == TIM_LOCKLevel_3))
#define TIM_OSSIState_Enable ((uint16_t)0x0400)
#define TIM_OSSIState_Disable ((uint16_t)0x0000)
//#define IS_TIM_OSSI_STATE(STATE) (((STATE) == TIM_OSSIState_Enable) || \
// ((STATE) == TIM_OSSIState_Disable))
#define TIM_OSSRState_Enable ((uint16_t)0x0800)
#define TIM_OSSRState_Disable ((uint16_t)0x0000)
//#define IS_TIM_OSSR_STATE(STATE) (((STATE) == TIM_OSSRState_Enable) || \
// ((STATE) == TIM_OSSRState_Disable))
#define TIM_OCIdleState_Set ((uint16_t)0x0100)
#define TIM_OCIdleState_Reset ((uint16_t)0x0000)
//#define IS_TIM_OCIDLE_STATE(STATE) (((STATE) == TIM_OCIdleState_Set) || \
// ((STATE) == TIM_OCIdleState_Reset))
//
#define TIM_OCNIdleState_Set ((uint16_t)0x0200)
#define TIM_OCNIdleState_Reset ((uint16_t)0x0000)
//#define IS_TIM_OCNIDLE_STATE(STATE) (((STATE) == TIM_OCNIdleState_Set) || \
// ((STATE) == TIM_OCNIdleState_Reset))
#define TIM_ICPolarity_Rising ((uint16_t)0x0000)
#define TIM_ICPolarity_Falling ((uint16_t)0x0002)
#define TIM_ICPolarity_BothEdge ((uint16_t)0x000A)
//#define IS_TIM_IC_POLARITY(POLARITY) (((POLARITY) == TIM_ICPolarity_Rising) || \
// ((POLARITY) == TIM_ICPolarity_Falling)|| \
// ((POLARITY) == TIM_ICPolarity_BothEdge))
#define TIM_ICSelection_DirectTI ((uint16_t)0x0001) /*!< TIM Input 1, 2, 3 or 4 is selected to be \
connected to IC1, IC2, IC3 or IC4, respectively */
#define TIM_ICSelection_IndirectTI ((uint16_t)0x0002) /*!< TIM Input 1, 2, 3 or 4 is selected to be \
connected to IC2, IC1, IC4 or IC3, respectively. */
#define TIM_ICSelection_TRC ((uint16_t)0x0003) /*!< TIM Input 1, 2, 3 or 4 is selected to be connected to TRC. */
//#define IS_TIM_IC_SELECTION(SELECTION) (((SELECTION) == TIM_ICSelection_DirectTI) || \
// ((SELECTION) == TIM_ICSelection_IndirectTI) || \
// ((SELECTION) == TIM_ICSelection_TRC))
// #define TIM_ICPSC_DIV1 ((uint16_t)0x0000) /*!< Capture performed each time an edge is detected on the capture input. */
// #define TIM_ICPSC_DIV2 ((uint16_t)0x0004) /*!< Capture performed once every 2 events. */
// #define TIM_ICPSC_DIV4 ((uint16_t)0x0008) /*!< Capture performed once every 4 events. */
// #define TIM_ICPSC_DIV8 ((uint16_t)0x000C) /*!< Capture performed once every 8 events. */
// #define IS_TIM_IC_PRESCALER(PRESCALER) ( ((PRESCALER) == TIM_ICPSC_DIV1) || \
// ((PRESCALER) == TIM_ICPSC_DIV2) || \
// ((PRESCALER) == TIM_ICPSC_DIV4) || \
// ((PRESCALER) == TIM_ICPSC_DIV8))
#define TIM_IT_Update ((uint16_t)0x0001)
// #define TIM_IT_CC1 ((uint16_t)0x0002)
// #define TIM_IT_CC2 ((uint16_t)0x0004)
// #define TIM_IT_CC3 ((uint16_t)0x0008)
// #define TIM_IT_CC4 ((uint16_t)0x0010)
// #define TIM_IT_COM ((uint16_t)0x0020)
#define TIM_IT_Trigger ((uint16_t)0x0040)
#define TIM_IT_Break ((uint16_t)0x0080)
#define IS_TIM_IT(IT) ((((IT) & (uint16_t)0xFF00) == 0x0000) && ((IT) != 0x0000))
#define IS_TIM_GET_IT(IT) (((IT) == TIM_IT_Update) || \
((IT) == TIM_IT_CC1) || \
((IT) == TIM_IT_CC2) || \
((IT) == TIM_IT_CC3) || \
((IT) == TIM_IT_CC4) || \
((IT) == TIM_IT_COM) || \
((IT) == TIM_IT_Trigger) || \
((IT) == TIM_IT_Break))
// #define TIM_DMABase_CR1 ((uint16_t)0x0000)
// #define TIM_DMABase_CR2 ((uint16_t)0x0001)
// #define TIM_DMABase_SMCR ((uint16_t)0x0002)
// #define TIM_DMABase_DIER ((uint16_t)0x0003)
// #define TIM_DMABase_SR ((uint16_t)0x0004)
// #define TIM_DMABase_EGR ((uint16_t)0x0005)
// #define TIM_DMABase_CCMR1 ((uint16_t)0x0006)
// #define TIM_DMABase_CCMR2 ((uint16_t)0x0007)
// #define TIM_DMABase_CCER ((uint16_t)0x0008)
// #define TIM_DMABase_CNT ((uint16_t)0x0009)
// #define TIM_DMABase_PSC ((uint16_t)0x000A)
// #define TIM_DMABase_ARR ((uint16_t)0x000B)
// #define TIM_DMABase_RCR ((uint16_t)0x000C)
// #define TIM_DMABase_CCR1 ((uint16_t)0x000D)
// #define TIM_DMABase_CCR2 ((uint16_t)0x000E)
// #define TIM_DMABase_CCR3 ((uint16_t)0x000F)
// #define TIM_DMABase_CCR4 ((uint16_t)0x0010)
// #define TIM_DMABase_BDTR ((uint16_t)0x0011)
// #define TIM_DMABase_DCR ((uint16_t)0x0012)
// #define TIM_DMABase_OR ((uint16_t)0x0013)
// #define IS_TIM_DMA_BASE(BASE) ( ((BASE) == TIM_DMABase_CR1) || \
// ((BASE) == TIM_DMABase_CR2) || \
// ((BASE) == TIM_DMABase_SMCR) || \
// ((BASE) == TIM_DMABase_DIER) || \
// ((BASE) == TIM_DMABase_SR) || \
// ((BASE) == TIM_DMABase_EGR) || \
// ((BASE) == TIM_DMABase_CCMR1) || \
// ((BASE) == TIM_DMABase_CCMR2) || \
// ((BASE) == TIM_DMABase_CCER) || \
// ((BASE) == TIM_DMABase_CNT) || \
// ((BASE) == TIM_DMABase_PSC) || \
// ((BASE) == TIM_DMABase_ARR) || \
// ((BASE) == TIM_DMABase_RCR) || \
// ((BASE) == TIM_DMABase_CCR1) || \
// ((BASE) == TIM_DMABase_CCR2) || \
// ((BASE) == TIM_DMABase_CCR3) || \
// ((BASE) == TIM_DMABase_CCR4) || \
// ((BASE) == TIM_DMABase_BDTR) || \
// ((BASE) == TIM_DMABase_DCR) || \
// ((BASE) == TIM_DMABase_OR))
// #define TIM_DMABurstLength_1Transfer ((uint16_t)0x0000)
// #define TIM_DMABurstLength_2Transfers ((uint16_t)0x0100)
// #define TIM_DMABurstLength_3Transfers ((uint16_t)0x0200)
// #define TIM_DMABurstLength_4Transfers ((uint16_t)0x0300)
// #define TIM_DMABurstLength_5Transfers ((uint16_t)0x0400)
// #define TIM_DMABurstLength_6Transfers ((uint16_t)0x0500)
// #define TIM_DMABurstLength_7Transfers ((uint16_t)0x0600)
// #define TIM_DMABurstLength_8Transfers ((uint16_t)0x0700)
// #define TIM_DMABurstLength_9Transfers ((uint16_t)0x0800)
// #define TIM_DMABurstLength_10Transfers ((uint16_t)0x0900)
// #define TIM_DMABurstLength_11Transfers ((uint16_t)0x0A00)
// #define TIM_DMABurstLength_12Transfers ((uint16_t)0x0B00)
// #define TIM_DMABurstLength_13Transfers ((uint16_t)0x0C00)
// #define TIM_DMABurstLength_14Transfers ((uint16_t)0x0D00)
// #define TIM_DMABurstLength_15Transfers ((uint16_t)0x0E00)
// #define TIM_DMABurstLength_16Transfers ((uint16_t)0x0F00)
// #define TIM_DMABurstLength_17Transfers ((uint16_t)0x1000)
// #define TIM_DMABurstLength_18Transfers ((uint16_t)0x1100)
// #define IS_TIM_DMA_LENGTH(LENGTH) ( ((LENGTH) == TIM_DMABurstLength_1Transfer) || \
// ((LENGTH) == TIM_DMABurstLength_2Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_3Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_4Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_5Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_6Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_7Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_8Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_9Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_10Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_11Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_12Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_13Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_14Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_15Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_16Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_17Transfers) || \
// ((LENGTH) == TIM_DMABurstLength_18Transfers))
// #define TIM_DMA_Update ((uint16_t)0x0100)
// #define TIM_DMA_CC1 ((uint16_t)0x0200)
// #define TIM_DMA_CC2 ((uint16_t)0x0400)
// #define TIM_DMA_CC3 ((uint16_t)0x0800)
// #define TIM_DMA_CC4 ((uint16_t)0x1000)
// #define TIM_DMA_COM ((uint16_t)0x2000)
// #define TIM_DMA_Trigger ((uint16_t)0x4000)
// #define IS_TIM_DMA_SOURCE(SOURCE) ((((SOURCE) & (uint16_t)0x80FF) == 0x0000) && ((SOURCE) != 0x0000))
#define TIM_ExtTRGPSC_OFF ((uint16_t)0x0000)
#define TIM_ExtTRGPSC_DIV2 ((uint16_t)0x1000)
#define TIM_ExtTRGPSC_DIV4 ((uint16_t)0x2000)
#define TIM_ExtTRGPSC_DIV8 ((uint16_t)0x3000)
#define IS_TIM_EXT_PRESCALER(PRESCALER) (((PRESCALER) == TIM_ExtTRGPSC_OFF) || \
((PRESCALER) == TIM_ExtTRGPSC_DIV2) || \
((PRESCALER) == TIM_ExtTRGPSC_DIV4) || \
((PRESCALER) == TIM_ExtTRGPSC_DIV8))
// #define TIM_TS_ITR0 ((uint16_t)0x0000)
// #define TIM_TS_ITR1 ((uint16_t)0x0010)
// #define TIM_TS_ITR2 ((uint16_t)0x0020)
// #define TIM_TS_ITR3 ((uint16_t)0x0030)
// #define TIM_TS_TI1F_ED ((uint16_t)0x0040)
// #define TIM_TS_TI1FP1 ((uint16_t)0x0050)
// #define TIM_TS_TI2FP2 ((uint16_t)0x0060)
// #define TIM_TS_ETRF ((uint16_t)0x0070)
// #def ine IS_TIM_TRIGGER_SELECTION(SELECTION) (((SELECTION) == TIM_TS_ITR0) || \
// ((SELECTION) == TIM_TS_ITR1) || \
// ((SELECTION) == TIM_TS_ITR2) || \
// ((SELECTION) == TIM_TS_ITR3) || \
// ((SELECTION) == TIM_TS_TI1F_ED) || \
// ((SELECTION) == TIM_TS_TI1FP1) || \
// ((SELECTION) == TIM_TS_TI2FP2) || \
// ((SELECTION) == TIM_TS_ETRF))
#define IS_TIM_INTERNAL_TRIGGER_SELECTION(SELECTION) (((SELECTION) == TIM_TS_ITR0) || \
((SELECTION) == TIM_TS_ITR1) || \
((SELECTION) == TIM_TS_ITR2) || \
((SELECTION) == TIM_TS_ITR3))
#define TIM_TIxExternalCLK1Source_TI1 ((uint16_t)0x0050)
#define TIM_TIxExternalCLK1Source_TI2 ((uint16_t)0x0060)
#define TIM_TIxExternalCLK1Source_TI1ED ((uint16_t)0x0040)
#define TIM_ExtTRGPolarity_Inverted ((uint16_t)0x8000)
#define TIM_ExtTRGPolarity_NonInverted ((uint16_t)0x0000)
#define IS_TIM_EXT_POLARITY(POLARITY) (((POLARITY) == TIM_ExtTRGPolarity_Inverted) || \
((POLARITY) == TIM_ExtTRGPolarity_NonInverted))
#define TIM_PSCReloadMode_Update ((uint16_t)0x0000)
#define TIM_PSCReloadMode_Immediate ((uint16_t)0x0001)
#define IS_TIM_PRESCALER_RELOAD(RELOAD) (((RELOAD) == TIM_PSCReloadMode_Update) || \
((RELOAD) == TIM_PSCReloadMode_Immediate))
#define TIM_ForcedAction_Active ((uint16_t)0x0050)
#define TIM_ForcedAction_InActive ((uint16_t)0x0040)
#define IS_TIM_FORCED_ACTION(ACTION) (((ACTION) == TIM_ForcedAction_Active) || \
((ACTION) == TIM_ForcedAction_InActive))
#define TIM_EncoderMode_TI1 ((uint16_t)0x0001)
#define TIM_EncoderMode_TI2 ((uint16_t)0x0002)
#define TIM_EncoderMode_TI12 ((uint16_t)0x0003)
//#define IS_TIM_ENCODER_MODE(MODE) (((MODE) == TIM_EncoderMode_TI1) || \
// ((MODE) == TIM_EncoderMode_TI2) || \
// ((MODE) == TIM_EncoderMode_TI12))
// #define TIM_EventSource_Update ((uint16_t)0x0001)
// #define TIM_EventSource_CC1 ((uint16_t)0x0002)
// #define TIM_EventSource_CC2 ((uint16_t)0x0004)
// #define TIM_EventSource_CC3 ((uint16_t)0x0008)
// #define TIM_EventSource_CC4 ((uint16_t)0x0010)
// #define TIM_EventSource_COM ((uint16_t)0x0020)
// #define TIM_EventSource_Trigger ((uint16_t)0x0040)
// #define TIM_EventSource_Break ((uint16_t)0x0080)
// #define IS_TIM_EVENT_SOURCE(SOURCE) ((((SOURCE) & (uint16_t)0xFF00) == 0x0000) && ((SOURCE) != 0x0000))
#define TIM_UpdateSource_Global ((uint16_t)0x0000) /*!< Source of update is the counter overflow/underflow \
or the setting of UG bit, or an update generation \
through the slave mode controller. */
#define TIM_UpdateSource_Regular ((uint16_t)0x0001) /*!< Source of update is counter overflow/underflow. */
#define IS_TIM_UPDATE_SOURCE(SOURCE) (((SOURCE) == TIM_UpdateSource_Global) || \
((SOURCE) == TIM_UpdateSource_Regular))
#define TIM_OCPreload_Enable ((uint16_t)0x0008)
#define TIM_OCPreload_Disable ((uint16_t)0x0000)
#define IS_TIM_OCPRELOAD_STATE(STATE) (((STATE) == TIM_OCPreload_Enable) || \
((STATE) == TIM_OCPreload_Disable))
#define TIM_OCFast_Enable ((uint16_t)0x0004)
#define TIM_OCFast_Disable ((uint16_t)0x0000)
#define IS_TIM_OCFAST_STATE(STATE) (((STATE) == TIM_OCFast_Enable) || \
((STATE) == TIM_OCFast_Disable))
#define TIM_OCClear_Enable ((uint16_t)0x0080)
#define TIM_OCClear_Disable ((uint16_t)0x0000)
#define IS_TIM_OCCLEAR_STATE(STATE) (((STATE) == TIM_OCClear_Enable) || \
((STATE) == TIM_OCClear_Disable))
#define TIM_TRGOSource_Reset ((uint16_t)0x0000)
#define TIM_TRGOSource_Enable ((uint16_t)0x0010)
#define TIM_TRGOSource_Update ((uint16_t)0x0020)
#define TIM_TRGOSource_OC1 ((uint16_t)0x0030)
#define TIM_TRGOSource_OC1Ref ((uint16_t)0x0040)
#define TIM_TRGOSource_OC2Ref ((uint16_t)0x0050)
#define TIM_TRGOSource_OC3Ref ((uint16_t)0x0060)
#define TIM_TRGOSource_OC4Ref ((uint16_t)0x0070)
//#define IS_TIM_TRGO_SOURCE(SOURCE) (((SOURCE) == TIM_TRGOSource_Reset) || \
// ((SOURCE) == TIM_TRGOSource_Enable) || \
// ((SOURCE) == TIM_TRGOSource_Update) || \
// ((SOURCE) == TIM_TRGOSource_OC1) || \
// ((SOURCE) == TIM_TRGOSource_OC1Ref) || \
// ((SOURCE) == TIM_TRGOSource_OC2Ref) || \
// ((SOURCE) == TIM_TRGOSource_OC3Ref) || \
// ((SOURCE) == TIM_TRGOSource_OC4Ref))
#define TIM_SlaveMode_Reset ((uint16_t)0x0004)
#define TIM_SlaveMode_Gated ((uint16_t)0x0005)
#define TIM_SlaveMode_Trigger ((uint16_t)0x0006)
#define TIM_SlaveMode_External1 ((uint16_t)0x0007)
//#define IS_TIM_SLAVE_MODE(MODE) (((MODE) == TIM_SlaveMode_Reset) || \
// ((MODE) == TIM_SlaveMode_Gated) || \
// ((MODE) == TIM_SlaveMode_Trigger) || \
// ((MODE) == TIM_SlaveMode_External1))
#define TIM_MasterSlaveMode_Enable ((uint16_t)0x0080)
#define TIM_MasterSlaveMode_Disable ((uint16_t)0x0000)
//#define IS_TIM_MSM_STATE(STATE) (((STATE) == TIM_MasterSlaveMode_Enable) || \
// ((STATE) == TIM_MasterSlaveMode_Disable))
#define TIM2_TIM8_TRGO ((uint16_t)0x0000)
#define TIM2_ETH_PTP ((uint16_t)0x0400)
#define TIM2_USBFS_SOF ((uint16_t)0x0800)
#define TIM2_USBHS_SOF ((uint16_t)0x0C00)
#define TIM5_GPIO ((uint16_t)0x0000)
#define TIM5_LSI ((uint16_t)0x0040)
#define TIM5_LSE ((uint16_t)0x0080)
#define TIM5_RTC ((uint16_t)0x00C0)
#define TIM11_GPIO ((uint16_t)0x0000)
#define TIM11_HSE ((uint16_t)0x0002)
class Encoder
{
private:
int _pin;
public:
TIM_TypeDef *tim_base;
Encoder();
void SetCount(int64_t Counter);
uint16_t GetCount();
};
void rcc_config();
void GpioConfigPortA(GPIO_TypeDef *GPIOx);
void GpioConfigPortC(GPIO_TypeDef *GPIOx);
void GpioConfigPortD(GPIO_TypeDef *GPIOx);
void TIM_EncoderInterConfig(TIM_TypeDef *TIMx, uint16_t TIM_EncoderMode, uint16_t TIM_IC1Polarity, uint16_t TIM_IC2Polarity);
void TIM_TimeBaseStructInit(TIM_TimeBaseInitTypeDef *TIM_TimeBaseInitStruct);
void TIM_TimeBaseInit(TIM_TypeDef *TIMx, TIM_TimeBaseInitTypeDef *TIM_TimeBaseInitStruct);
#endif

View File

Before

Width:  |  Height:  |  Size: 48 KiB

After

Width:  |  Height:  |  Size: 48 KiB

View File

Before

Width:  |  Height:  |  Size: 58 KiB

After

Width:  |  Height:  |  Size: 58 KiB

View File

@@ -33,8 +33,8 @@
#define SM3_smc 0x20 #define SM3_smc 0x20
#define SM3_act 1 #define SM3_act 1
#define MAX_MAPPINGS_SM2 2 #define MAX_MAPPINGS_SM2 8
#define MAX_MAPPINGS_SM3 5 #define MAX_MAPPINGS_SM3 7
#define MAX_RXPDO_SIZE 512 #define MAX_RXPDO_SIZE 512
#define MAX_TXPDO_SIZE 512 #define MAX_TXPDO_SIZE 512

View File

@@ -57,7 +57,7 @@
"pdo_mappings": [ "pdo_mappings": [
"txpdo" "txpdo"
], ],
"dtype": "REAL32", "dtype": "REAL64",
"value": "0", "value": "0",
"data": "&Obj.EncPos" "data": "&Obj.EncPos"
}, },
@@ -68,7 +68,7 @@
"pdo_mappings": [ "pdo_mappings": [
"txpdo" "txpdo"
], ],
"dtype": "REAL32", "dtype": "REAL64",
"value": "0", "value": "0",
"data": "&Obj.EncFrequency" "data": "&Obj.EncFrequency"
}, },
@@ -104,6 +104,46 @@
"dtype": "UNSIGNED32", "dtype": "UNSIGNED32",
"value": "0", "value": "0",
"data": "&Obj.IndexStatus" "data": "&Obj.IndexStatus"
},
"6005": {
"otype": "RECORD",
"name": "StepGenOut1",
"access": "RO",
"items": [
{
"name": "Max SubIndex"
},
{
"name": "ActualPosition",
"dtype": "REAL64",
"data": "&Obj.StepGenOut1.ActualPosition",
"value": "0",
"access": "RO"
}
],
"pdo_mappings": [
"txpdo"
]
},
"6006": {
"otype": "RECORD",
"name": "StepGenOut2",
"access": "RO",
"items": [
{
"name": "Max SubIndex"
},
{
"name": "ActualPosition",
"dtype": "REAL64",
"data": "&Obj.StepGenOut2.ActualPosition",
"value": "0",
"access": "RO"
}
],
"pdo_mappings": [
"txpdo"
]
} }
}, },
"rxpdo": { "rxpdo": {
@@ -129,6 +169,71 @@
"value": "0", "value": "0",
"data": "&Obj.IndexLatchEnable" "data": "&Obj.IndexLatchEnable"
}, },
"7002": {
"otype": "RECORD",
"name": "StepGenIn1",
"access": "RO",
"items": [
{
"name": "Max SubIndex"
},
{
"name": "CommandedPosition",
"dtype": "REAL64",
"data": "&Obj.StepGenIn1.CommandedPosition",
"value": "0",
"access": "RO"
},
{
"name": "StepsPerMM",
"dtype": "INTEGER16",
"value": "0",
"access": "RO",
"data": "&Obj.StepGenIn1.StepsPerMM"
}
],
"pdo_mappings": [
"rxpdo"
]
},
"7003": {
"otype": "RECORD",
"name": "StepGenIn2",
"access": "RO",
"items": [
{
"name": "Max SubIndex"
},
{
"name": "CommandedPosition",
"dtype": "REAL64",
"data": "&Obj.StepGenIn2.CommandedPosition",
"value": "0",
"access": "RO"
},
{
"name": "StepsPerMM",
"dtype": "INTEGER16",
"value": "0",
"access": "RO",
"data": "&Obj.StepGenIn2.StepsPerMM"
}
],
"pdo_mappings": [
"rxpdo"
]
},
"7004": {
"otype": "VAR",
"name": "Enable1",
"access": "RO",
"pdo_mappings": [
"rxpdo"
],
"dtype": "BOOLEAN",
"value": "0",
"data": "&Obj.Enable1"
},
"60664": { "60664": {
"otype": "VAR", "otype": "VAR",
"name": "ActualPosition", "name": "ActualPosition",

View File

@@ -19,6 +19,18 @@ static const char acName1600_01[] = "EncPosScale";
static const char acName1601[] = "IndexLatchEnable"; static const char acName1601[] = "IndexLatchEnable";
static const char acName1601_00[] = "Max SubIndex"; static const char acName1601_00[] = "Max SubIndex";
static const char acName1601_01[] = "IndexLatchEnable"; static const char acName1601_01[] = "IndexLatchEnable";
static const char acName1602[] = "StepGenIn1";
static const char acName1602_00[] = "Max SubIndex";
static const char acName1602_01[] = "CommandedPosition";
static const char acName1602_02[] = "StepsPerMM";
static const char acName1603[] = "StepGenIn2";
static const char acName1603_00[] = "Max SubIndex";
static const char acName1603_01[] = "CommandedPosition";
static const char acName1603_02[] = "StepsPerMM";
static const char acName1604[] = "Enable1";
static const char acName1604_00[] = "Max SubIndex";
static const char acName1604_01[] = "Enable1";
static const char acName1604_02[] = "Padding 1";
static const char acName1A00[] = "EncPos"; static const char acName1A00[] = "EncPos";
static const char acName1A00_00[] = "Max SubIndex"; static const char acName1A00_00[] = "Max SubIndex";
static const char acName1A00_01[] = "EncPos"; static const char acName1A00_01[] = "EncPos";
@@ -34,6 +46,12 @@ static const char acName1A03_01[] = "IndexByte";
static const char acName1A04[] = "IndexStatus"; static const char acName1A04[] = "IndexStatus";
static const char acName1A04_00[] = "Max SubIndex"; static const char acName1A04_00[] = "Max SubIndex";
static const char acName1A04_01[] = "IndexStatus"; static const char acName1A04_01[] = "IndexStatus";
static const char acName1A05[] = "StepGenOut1";
static const char acName1A05_00[] = "Max SubIndex";
static const char acName1A05_01[] = "ActualPosition";
static const char acName1A06[] = "StepGenOut2";
static const char acName1A06_00[] = "Max SubIndex";
static const char acName1A06_01[] = "ActualPosition";
static const char acName1C00[] = "Sync Manager Communication Type"; static const char acName1C00[] = "Sync Manager Communication Type";
static const char acName1C00_00[] = "Max SubIndex"; static const char acName1C00_00[] = "Max SubIndex";
static const char acName1C00_01[] = "Communications Type SM0"; static const char acName1C00_01[] = "Communications Type SM0";
@@ -44,6 +62,9 @@ static const char acName1C12[] = "Sync Manager 2 PDO Assignment";
static const char acName1C12_00[] = "Max SubIndex"; static const char acName1C12_00[] = "Max SubIndex";
static const char acName1C12_01[] = "PDO Mapping"; static const char acName1C12_01[] = "PDO Mapping";
static const char acName1C12_02[] = "PDO Mapping"; static const char acName1C12_02[] = "PDO Mapping";
static const char acName1C12_03[] = "PDO Mapping";
static const char acName1C12_04[] = "PDO Mapping";
static const char acName1C12_05[] = "PDO Mapping";
static const char acName1C13[] = "Sync Manager 3 PDO Assignment"; static const char acName1C13[] = "Sync Manager 3 PDO Assignment";
static const char acName1C13_00[] = "Max SubIndex"; static const char acName1C13_00[] = "Max SubIndex";
static const char acName1C13_01[] = "PDO Mapping"; static const char acName1C13_01[] = "PDO Mapping";
@@ -51,17 +72,34 @@ static const char acName1C13_02[] = "PDO Mapping";
static const char acName1C13_03[] = "PDO Mapping"; static const char acName1C13_03[] = "PDO Mapping";
static const char acName1C13_04[] = "PDO Mapping"; static const char acName1C13_04[] = "PDO Mapping";
static const char acName1C13_05[] = "PDO Mapping"; static const char acName1C13_05[] = "PDO Mapping";
static const char acName1C13_06[] = "PDO Mapping";
static const char acName1C13_07[] = "PDO Mapping";
static const char acName6000[] = "EncPos"; static const char acName6000[] = "EncPos";
static const char acName6001[] = "EncFrequency"; static const char acName6001[] = "EncFrequency";
static const char acName6002[] = "DiffT"; static const char acName6002[] = "DiffT";
static const char acName6003[] = "IndexByte"; static const char acName6003[] = "IndexByte";
static const char acName6004[] = "IndexStatus"; static const char acName6004[] = "IndexStatus";
static const char acName6005[] = "StepGenOut1";
static const char acName6005_00[] = "Max SubIndex";
static const char acName6005_01[] = "ActualPosition";
static const char acName6006[] = "StepGenOut2";
static const char acName6006_00[] = "Max SubIndex";
static const char acName6006_01[] = "ActualPosition";
static const char acName7000[] = "EncPosScale"; static const char acName7000[] = "EncPosScale";
static const char acName7001[] = "IndexLatchEnable"; static const char acName7001[] = "IndexLatchEnable";
static const char acName7002[] = "StepGenIn1";
static const char acName7002_00[] = "Max SubIndex";
static const char acName7002_01[] = "CommandedPosition";
static const char acName7002_02[] = "StepsPerMM";
static const char acName7003[] = "StepGenIn2";
static const char acName7003_00[] = "Max SubIndex";
static const char acName7003_01[] = "CommandedPosition";
static const char acName7003_02[] = "StepsPerMM";
static const char acName7004[] = "Enable1";
const _objd SDO1000[] = const _objd SDO1000[] =
{ {
{0x0, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1000, 5001, NULL}, {0x0, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1000, 5001, NULL},
}; };
const _objd SDO1008[] = const _objd SDO1008[] =
{ {
@@ -78,45 +116,73 @@ const _objd SDO100A[] =
const _objd SDO1018[] = const _objd SDO1018[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1018_00, 4, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1018_00, 4, NULL},
{0x01, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1018_01, 2730, NULL}, {0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1018_01, 2730, NULL},
{0x02, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1018_02, 12303564, NULL}, {0x02, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1018_02, 12303564, NULL},
{0x03, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1018_03, 2, NULL}, {0x03, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1018_03, 2, NULL},
{0x04, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1018_04, 1, &Obj.serial}, {0x04, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1018_04, 1, &Obj.serial},
}; };
const _objd SDO1600[] = const _objd SDO1600[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1600_00, 1, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1600_00, 1, NULL},
{0x01, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1600_01, 0x70000020, NULL}, {0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1600_01, 0x70000020, NULL},
}; };
const _objd SDO1601[] = const _objd SDO1601[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1601_00, 1, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1601_00, 1, NULL},
{0x01, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1601_01, 0x70010020, NULL}, {0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1601_01, 0x70010020, NULL},
};
const _objd SDO1602[] =
{
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1602_00, 2, NULL},
{0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1602_01, 0x70020140, NULL},
{0x02, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1602_02, 0x70020210, NULL},
};
const _objd SDO1603[] =
{
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1603_00, 2, NULL},
{0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1603_01, 0x70030140, NULL},
{0x02, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1603_02, 0x70030210, NULL},
};
const _objd SDO1604[] =
{
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1604_00, 2, NULL},
{0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1604_01, 0x70040001, NULL},
{0x02, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1604_02, 0x00000007, NULL},
}; };
const _objd SDO1A00[] = const _objd SDO1A00[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A00_00, 1, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A00_00, 1, NULL},
{0x01, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1A00_01, 0x60000020, NULL}, {0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1A00_01, 0x60000040, NULL},
}; };
const _objd SDO1A01[] = const _objd SDO1A01[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A01_00, 1, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A01_00, 1, NULL},
{0x01, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1A01_01, 0x60010020, NULL}, {0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1A01_01, 0x60010040, NULL},
}; };
const _objd SDO1A02[] = const _objd SDO1A02[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A02_00, 1, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A02_00, 1, NULL},
{0x01, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1A02_01, 0x60020020, NULL}, {0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1A02_01, 0x60020020, NULL},
}; };
const _objd SDO1A03[] = const _objd SDO1A03[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A03_00, 1, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A03_00, 1, NULL},
{0x01, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1A03_01, 0x60030020, NULL}, {0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1A03_01, 0x60030020, NULL},
}; };
const _objd SDO1A04[] = const _objd SDO1A04[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A04_00, 1, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A04_00, 1, NULL},
{0x01, DTYPE_UNSIGNED32, 32, ATYPE_RO, acName1A04_01, 0x60040020, NULL}, {0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1A04_01, 0x60040020, NULL},
};
const _objd SDO1A05[] =
{
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A05_00, 1, NULL},
{0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1A05_01, 0x60050140, NULL},
};
const _objd SDO1A06[] =
{
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1A06_00, 1, NULL},
{0x01, DTYPE_UNSIGNED64, 64, ATYPE_RO, acName1A06_01, 0x60060140, NULL},
}; };
const _objd SDO1C00[] = const _objd SDO1C00[] =
{ {
@@ -128,26 +194,31 @@ const _objd SDO1C00[] =
}; };
const _objd SDO1C12[] = const _objd SDO1C12[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1C12_00, 2, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1C12_00, 5, NULL},
{0x01, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C12_01, 0x1600, NULL}, {0x01, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C12_01, 0x1600, NULL},
{0x02, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C12_02, 0x1601, NULL}, {0x02, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C12_02, 0x1601, NULL},
{0x03, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C12_03, 0x1602, NULL},
{0x04, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C12_04, 0x1603, NULL},
{0x05, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C12_05, 0x1604, NULL},
}; };
const _objd SDO1C13[] = const _objd SDO1C13[] =
{ {
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1C13_00, 5, NULL}, {0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName1C13_00, 7, NULL},
{0x01, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_01, 0x1A00, NULL}, {0x01, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_01, 0x1A00, NULL},
{0x02, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_02, 0x1A01, NULL}, {0x02, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_02, 0x1A01, NULL},
{0x03, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_03, 0x1A02, NULL}, {0x03, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_03, 0x1A02, NULL},
{0x04, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_04, 0x1A03, NULL}, {0x04, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_04, 0x1A03, NULL},
{0x05, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_05, 0x1A04, NULL}, {0x05, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_05, 0x1A04, NULL},
{0x06, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_06, 0x1A05, NULL},
{0x07, DTYPE_UNSIGNED16, 16, ATYPE_RO, acName1C13_07, 0x1A06, NULL},
}; };
const _objd SDO6000[] = const _objd SDO6000[] =
{ {
{0x0, DTYPE_REAL32, 32, ATYPE_RO | ATYPE_TXPDO, acName6000, 0x00000000, &Obj.EncPos}, {0x0, DTYPE_REAL64, 64, ATYPE_RO | ATYPE_TXPDO, acName6000, 0, &Obj.EncPos},
}; };
const _objd SDO6001[] = const _objd SDO6001[] =
{ {
{0x0, DTYPE_REAL32, 32, ATYPE_RO | ATYPE_TXPDO, acName6001, 0x00000000, &Obj.EncFrequency}, {0x0, DTYPE_REAL64, 64, ATYPE_RO | ATYPE_TXPDO, acName6001, 0, &Obj.EncFrequency},
}; };
const _objd SDO6002[] = const _objd SDO6002[] =
{ {
@@ -161,6 +232,16 @@ const _objd SDO6004[] =
{ {
{0x0, DTYPE_UNSIGNED32, 32, ATYPE_RO | ATYPE_TXPDO, acName6004, 0, &Obj.IndexStatus}, {0x0, DTYPE_UNSIGNED32, 32, ATYPE_RO | ATYPE_TXPDO, acName6004, 0, &Obj.IndexStatus},
}; };
const _objd SDO6005[] =
{
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName6005_00, 1, NULL},
{0x01, DTYPE_REAL64, 64, ATYPE_RO, acName6005_01, 0, &Obj.StepGenOut1.ActualPosition},
};
const _objd SDO6006[] =
{
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName6006_00, 1, NULL},
{0x01, DTYPE_REAL64, 64, ATYPE_RO, acName6006_01, 0, &Obj.StepGenOut2.ActualPosition},
};
const _objd SDO7000[] = const _objd SDO7000[] =
{ {
{0x0, DTYPE_INTEGER32, 32, ATYPE_RO | ATYPE_RXPDO, acName7000, 0, &Obj.EncPosScale}, {0x0, DTYPE_INTEGER32, 32, ATYPE_RO | ATYPE_RXPDO, acName7000, 0, &Obj.EncPosScale},
@@ -169,6 +250,22 @@ const _objd SDO7001[] =
{ {
{0x0, DTYPE_UNSIGNED32, 32, ATYPE_RO | ATYPE_RXPDO, acName7001, 0, &Obj.IndexLatchEnable}, {0x0, DTYPE_UNSIGNED32, 32, ATYPE_RO | ATYPE_RXPDO, acName7001, 0, &Obj.IndexLatchEnable},
}; };
const _objd SDO7002[] =
{
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName7002_00, 2, NULL},
{0x01, DTYPE_REAL64, 64, ATYPE_RO, acName7002_01, 0, &Obj.StepGenIn1.CommandedPosition},
{0x02, DTYPE_INTEGER16, 16, ATYPE_RO, acName7002_02, 0, &Obj.StepGenIn1.StepsPerMM},
};
const _objd SDO7003[] =
{
{0x00, DTYPE_UNSIGNED8, 8, ATYPE_RO, acName7003_00, 2, NULL},
{0x01, DTYPE_REAL64, 64, ATYPE_RO, acName7003_01, 0, &Obj.StepGenIn2.CommandedPosition},
{0x02, DTYPE_INTEGER16, 16, ATYPE_RO, acName7003_02, 0, &Obj.StepGenIn2.StepsPerMM},
};
const _objd SDO7004[] =
{
{0x0, DTYPE_BOOLEAN, 1, ATYPE_RO | ATYPE_RXPDO, acName7004, 0, &Obj.Enable1},
};
const _objectlist SDOobjects[] = const _objectlist SDOobjects[] =
{ {
@@ -179,20 +276,30 @@ const _objectlist SDOobjects[] =
{0x1018, OTYPE_RECORD, 4, 0, acName1018, SDO1018}, {0x1018, OTYPE_RECORD, 4, 0, acName1018, SDO1018},
{0x1600, OTYPE_RECORD, 1, 0, acName1600, SDO1600}, {0x1600, OTYPE_RECORD, 1, 0, acName1600, SDO1600},
{0x1601, OTYPE_RECORD, 1, 0, acName1601, SDO1601}, {0x1601, OTYPE_RECORD, 1, 0, acName1601, SDO1601},
{0x1602, OTYPE_RECORD, 2, 0, acName1602, SDO1602},
{0x1603, OTYPE_RECORD, 2, 0, acName1603, SDO1603},
{0x1604, OTYPE_RECORD, 2, 0, acName1604, SDO1604},
{0x1A00, OTYPE_RECORD, 1, 0, acName1A00, SDO1A00}, {0x1A00, OTYPE_RECORD, 1, 0, acName1A00, SDO1A00},
{0x1A01, OTYPE_RECORD, 1, 0, acName1A01, SDO1A01}, {0x1A01, OTYPE_RECORD, 1, 0, acName1A01, SDO1A01},
{0x1A02, OTYPE_RECORD, 1, 0, acName1A02, SDO1A02}, {0x1A02, OTYPE_RECORD, 1, 0, acName1A02, SDO1A02},
{0x1A03, OTYPE_RECORD, 1, 0, acName1A03, SDO1A03}, {0x1A03, OTYPE_RECORD, 1, 0, acName1A03, SDO1A03},
{0x1A04, OTYPE_RECORD, 1, 0, acName1A04, SDO1A04}, {0x1A04, OTYPE_RECORD, 1, 0, acName1A04, SDO1A04},
{0x1A05, OTYPE_RECORD, 1, 0, acName1A05, SDO1A05},
{0x1A06, OTYPE_RECORD, 1, 0, acName1A06, SDO1A06},
{0x1C00, OTYPE_ARRAY, 4, 0, acName1C00, SDO1C00}, {0x1C00, OTYPE_ARRAY, 4, 0, acName1C00, SDO1C00},
{0x1C12, OTYPE_ARRAY, 2, 0, acName1C12, SDO1C12}, {0x1C12, OTYPE_ARRAY, 5, 0, acName1C12, SDO1C12},
{0x1C13, OTYPE_ARRAY, 5, 0, acName1C13, SDO1C13}, {0x1C13, OTYPE_ARRAY, 7, 0, acName1C13, SDO1C13},
{0x6000, OTYPE_VAR, 0, 0, acName6000, SDO6000}, {0x6000, OTYPE_VAR, 0, 0, acName6000, SDO6000},
{0x6001, OTYPE_VAR, 0, 0, acName6001, SDO6001}, {0x6001, OTYPE_VAR, 0, 0, acName6001, SDO6001},
{0x6002, OTYPE_VAR, 0, 0, acName6002, SDO6002}, {0x6002, OTYPE_VAR, 0, 0, acName6002, SDO6002},
{0x6003, OTYPE_VAR, 0, 0, acName6003, SDO6003}, {0x6003, OTYPE_VAR, 0, 0, acName6003, SDO6003},
{0x6004, OTYPE_VAR, 0, 0, acName6004, SDO6004}, {0x6004, OTYPE_VAR, 0, 0, acName6004, SDO6004},
{0x6005, OTYPE_RECORD, 1, 0, acName6005, SDO6005},
{0x6006, OTYPE_RECORD, 1, 0, acName6006, SDO6006},
{0x7000, OTYPE_VAR, 0, 0, acName7000, SDO7000}, {0x7000, OTYPE_VAR, 0, 0, acName7000, SDO7000},
{0x7001, OTYPE_VAR, 0, 0, acName7001, SDO7001}, {0x7001, OTYPE_VAR, 0, 0, acName7001, SDO7001},
{0x7002, OTYPE_RECORD, 2, 0, acName7002, SDO7002},
{0x7003, OTYPE_RECORD, 2, 0, acName7003, SDO7003},
{0x7004, OTYPE_VAR, 0, 0, acName7004, SDO7004},
{0xffff, 0xff, 0xff, 0xff, NULL, NULL} {0xffff, 0xff, 0xff, 0xff, NULL, NULL}
}; };

View File

@@ -13,16 +13,35 @@ typedef struct
/* Inputs */ /* Inputs */
float EncPos; double EncPos;
float EncFrequency; double EncFrequency;
uint32_t DiffT; uint32_t DiffT;
uint32_t IndexByte; uint32_t IndexByte;
uint32_t IndexStatus; uint32_t IndexStatus;
struct
{
double ActualPosition;
} StepGenOut1;
struct
{
double ActualPosition;
} StepGenOut2;
/* Outputs */ /* Outputs */
int32_t EncPosScale; int32_t EncPosScale;
uint32_t IndexLatchEnable; uint32_t IndexLatchEnable;
struct
{
double CommandedPosition;
int16_t StepsPerMM;
} StepGenIn1;
struct
{
double CommandedPosition;
int16_t StepsPerMM;
} StepGenIn2;
uint8_t Enable1;
} _Objects; } _Objects;

94
Firmware/src/MyEncoder.cpp Executable file
View File

@@ -0,0 +1,94 @@
#include "MyENcoder.h"
MyEncoder::MyEncoder(TIM_TypeDef *_tim_base, uint8_t _indexPin, void irq(void))
{
tim_base = _tim_base;
indexPin = _indexPin;
attachInterrupt(digitalPinToInterrupt(indexPin), irq, RISING); // When Index triggered
EncoderInit.SetCount(0);
}
#define ONE_PERIOD 65536
#define HALF_PERIOD 32768
int64_t MyEncoder::unwrapEncoder(uint16_t in)
{
int32_t c32 = (int32_t)in - HALF_PERIOD; // remove half period to determine (+/-) sign of the wrap
int32_t dif = (c32 - previousEncoderCounterValue); // core concept: prev + (current - prev) = current
// wrap difference from -HALF_PERIOD to HALF_PERIOD. modulo prevents differences after the wrap from having an incorrect result
int32_t mod_dif = ((dif + HALF_PERIOD) % ONE_PERIOD) - HALF_PERIOD;
if (dif < -HALF_PERIOD)
mod_dif += ONE_PERIOD; // account for mod of negative number behavior in C
int64_t unwrapped = previousEncoderCounterValue + mod_dif;
previousEncoderCounterValue = unwrapped; // load previous value
return unwrapped + HALF_PERIOD; // remove the shift we applied at the beginning, and return
}
void MyEncoder::indexPulse(void)
{
if (pleaseZeroTheCounter)
{
tim_base->CNT = 0;
indexPulseFired = 1;
Pos.clear();
TDelta.clear();
pleaseZeroTheCounter = 0;
}
}
uint8_t MyEncoder::indexHappened()
{
if (indexPulseFired)
{
indexPulseFired = 0;
previousEncoderCounterValue = 0;
return 1;
}
return 0;
}
double MyEncoder::currentPos()
{
curPos = unwrapEncoder(tim_base->CNT) * PosScaleRes;
return curPos;
}
double MyEncoder::frequency(uint64_t time)
{
double diffT = 0;
double diffPos = 0;
TDelta.push(time); // Running average over the length of the circular buffer
Pos.push(curPos);
if (Pos.size() >= 2)
{
diffT = 1.0e-9 * (TDelta.last() - TDelta.first()); // Time is in nanoseconds
diffPos = fabs(Pos.last() - Pos.first());
}
return diffT != 0 ? diffPos / diffT : 0.0; // Revolutions per second
}
uint8_t MyEncoder::getIndexState()
{
return digitalRead(indexPin);
}
void MyEncoder::setScale(double scale)
{
if (CurPosScale != scale && scale != 0)
{
CurPosScale = scale;
PosScaleRes = 1.0 / double(scale);
}
}
void MyEncoder::setLatch(uint8_t latchEnable)
{
if (latchEnable && !oldLatchCEnable) // Should only happen first time IndexCEnable is set
{
pleaseZeroTheCounter = 1;
}
oldLatchCEnable = latchEnable;
}

148
Firmware/src/StepGen.cpp Executable file
View File

@@ -0,0 +1,148 @@
#include <Arduino.h>
#include <stdio.h>
#include "StepGen.h"
StepGen::StepGen(TIM_TypeDef *Timer, uint32_t _timerChannel, PinName _stepPin, uint8_t _dirPin, void irq(void))
{
timerIsRunning = 0;
timerStepPosition = 0;
timerStepDirection = 0;
timerStepPositionAtEnd = 0;
timerNewEndStepPosition = 0;
actualPosition = 0;
requestedPosition = 0;
stepsPerMM = 0;
enabled = 0;
dirPin = _dirPin;
stepPin = _stepPin;
timerChan = _timerChannel;
MyTim = new HardwareTimer(Timer);
MyTim->attachInterrupt(irq);
pinMode(dirPin, OUTPUT);
}
void StepGen::reqPos(double_t pos)
{
requestedPosition = pos;
}
double StepGen::reqPos()
{
return requestedPosition;
}
void StepGen::actPos(double pos)
{
actualPosition = pos;
}
double StepGen::actPos()
{
return actualPosition;
}
void StepGen::enable(uint8_t yes)
{
enabled = yes;
}
void StepGen::handleStepper(void)
{
if (!enabled)
return;
pwmCycleTime = StepGen::sync0CycleTime;
actPos(timerStepPosition / double(stepsPerMM));
double diffPosition = reqPos() - actPos();
#if 1
// Wild "tone" kludge. map() function
#define SPEED_MIN 0.00005
#define SPEED_MAX 0.0005
#define FACT_LOW 1.0
#define FACT_HIGH 20.0
if (abs(diffPosition) < SPEED_MIN) // 60 mm/min = 0.001 mm/ms
{
pwmCycleTime = FACT_LOW * StepGen::sync0CycleTime;
}
else if (abs(diffPosition) > SPEED_MAX) // 60 mm/min = 0.001 mm/ms
{
pwmCycleTime = FACT_HIGH * StepGen::sync0CycleTime;
}
else
{
pwmCycleTime = (FACT_LOW + (FACT_HIGH - FACT_LOW) * (abs(diffPosition) - SPEED_MIN) / (SPEED_MAX - SPEED_MIN)) * StepGen::sync0CycleTime;
}
#endif
uint64_t fre = (abs(diffPosition) * stepsPerMM * 1000000) / pwmCycleTime; // Frequency needed
if (fre > maxFreq) // Only do maxFre
{
double maxDist = (maxFreq * pwmCycleTime) / (stepsPerMM * 1000000.0) * (diffPosition > 0 ? 1 : -1);
reqPos(actPos() + maxDist);
}
int32_t pulsesAtEndOfCycle = stepsPerMM * reqPos();
// Will be picked up by the timer_CB and the timer is reloaded, if it runs.
timerNewEndStepPosition = pulsesAtEndOfCycle;
if (!timerIsRunning) // Timer isn't running. Start it here
{
int32_t steps = pulsesAtEndOfCycle - timerStepPosition; // Pulses to go + or -
if (steps != 0)
{
if (steps > 0)
{
digitalWrite(dirPin, HIGH);
timerStepDirection = 1;
}
else
{
digitalWrite(dirPin, LOW);
timerStepDirection = -1;
}
timerStepPositionAtEnd = pulsesAtEndOfCycle; // Current Position
float_t freqf = abs(steps) / (pwmCycleTime*1.0e-6);
uint32_t freq = uint32_t(freqf);
MyTim->setMode(timerChan, TIMER_OUTPUT_COMPARE_PWM2, stepPin);
MyTim->setOverflow(freq, HERTZ_FORMAT);
MyTim->setCaptureCompare(timerChan, 50, PERCENT_COMPARE_FORMAT); // 50 %
timerIsRunning = 1;
MyTim->resume();
}
}
}
void StepGen::timerCB()
{
timerStepPosition += timerStepDirection; // The step that was just completed
if (timerNewEndStepPosition != 0) // Are we going to reload?
{
// Input for reload is timerNewEndStepPosition
// The timer has current position and from this
// can set new frequency and new endtarget for steps
MyTim->pause(); // We are not at stop, let's stop it. Note stepPin is floating
int32_t steps = timerNewEndStepPosition - timerStepPosition;
if (steps != 0)
{
uint8_t sgn = steps > 0 ? HIGH : LOW;
digitalWrite(dirPin, sgn);
float_t freqf = abs(steps) / float(pwmCycleTime*1.0e-6);
uint32_t freq = uint32_t(freqf);
timerStepDirection = steps > 0 ? 1 : -1;
timerStepPositionAtEnd = timerNewEndStepPosition;
timerNewEndStepPosition = 0; // Set to zero to not reload next time
MyTim->setMode(timerChan, TIMER_OUTPUT_COMPARE_PWM2, stepPin);
MyTim->setOverflow(freq, HERTZ_FORMAT);
MyTim->setCaptureCompare(timerChan, 50, PERCENT_COMPARE_FORMAT); // 50 %
MyTim->resume();
timerIsRunning = 1;
}
}
if (timerStepPosition == timerStepPositionAtEnd) // Are we finished?
{
timerIsRunning = 0;
MyTim->pause();
}
}
void StepGen::setScale(int16_t spm)
{
stepsPerMM = spm;
}
uint32_t StepGen::sync0CycleTime = 0;

View File

@@ -5,45 +5,21 @@
Created on: Nov 20, 2020 Created on: Nov 20, 2020
Author: GoktugH. Author: GoktugH.
*/ */
// TIM2, TIM3, TIM4, TIM8
Encoder::Encoder() Encoder::Encoder()
{ {
int unit; int unit;
} }
void Encoder::eattach(int enco) // void Encoder::SetCount(enum EncTimer enc, int64_t Counter)
void Encoder::SetCount(int64_t Counter)
{ {
tim_base->CNT = Counter;
} }
// uint16_t Encoder::GetCount(enum EncTimer enc)
void Encoder::attachh(int encoNumber) uint16_t Encoder::GetCount()
{ {
eattach(encoNumber); return tim_base->CNT;
}
void Encoder::SetCount(enum EncTimer enc, int64_t Counter)
{
if (enc == Tim2)
TIM2->CNT = Counter;
else if (enc == Tim3)
TIM3->CNT = Counter;
else if (enc == Tim4)
TIM4->CNT = Counter;
else if (enc == Tim8)
TIM8->CNT = Counter;
}
uint16_t Encoder::GetCount(enum EncTimer enc)
{
if (enc == Tim2)
c = (TIM2->CNT);
else if (enc == Tim3)
c = (TIM3->CNT);
else if (enc == Tim4)
c = (TIM4->CNT);
else if (enc == Tim8)
c = (TIM8->CNT);
return c;
} }
void GpioConfigPortA(GPIO_TypeDef *GPIOx) void GpioConfigPortA(GPIO_TypeDef *GPIOx)
@@ -295,27 +271,27 @@ void rcc_config()
RCC->AHB1ENR |= 0x10; // GPIOE RCC->AHB1ENR |= 0x10; // GPIOE
RCC->APB1ENR |= 0x20000000; // ENABLE DAC RCC->APB1ENR |= 0x20000000; // ENABLE DAC
RCC->APB2ENR |= 0x00000002; // APB2 TIM8 // RCC->APB2ENR |= 0x00000002; // APB2 TIM8
RCC->APB1ENR |= 0x00000004; // APB1 TIM4 RCC->APB1ENR |= 0x00000004; // APB1 TIM4
RCC->APB1ENR |= 0x00000001; // APB1 TIM2 RCC->APB1ENR |= 0x00000001; // APB1 TIM2
RCC->APB1ENR |= 0x00000002; // APB1 TIM3 // RCC->APB1ENR |= 0x00000002; // APB1 TIM3
GpioConfigPortA(GPIOA); GpioConfigPortA(GPIOA);
GpioConfigPortC(GPIOC); // GpioConfigPortC(GPIOC);
GpioConfigPortD(GPIOD); GpioConfigPortD(GPIOD);
#if 0 // Skipping since TIM8 is step generator and TIM3, chan4 is smae as TIM8, chan4
GPIO_PinAF(GPIOA, GPIO_PinSource6, GPIO_AF_TIM3); GPIO_PinAF(GPIOA, GPIO_PinSource6, GPIO_AF_TIM3);
GPIO_PinAF(GPIOA, GPIO_PinSource7, GPIO_AF_TIM3); GPIO_PinAF(GPIOA, GPIO_PinSource7, GPIO_AF_TIM3);
GPIO_PinAF(GPIOC, GPIO_PinSource6, GPIO_AF_TIM8); GPIO_PinAF(GPIOC, GPIO_PinSource6, GPIO_AF_TIM8);
GPIO_PinAF(GPIOC, GPIO_PinSource7, GPIO_AF_TIM8); GPIO_PinAF(GPIOC, GPIO_PinSource7, GPIO_AF_TIM8);
#endif
GPIO_PinAF(GPIOD, GPIO_PinSource12, GPIO_AF_TIM4); GPIO_PinAF(GPIOD, GPIO_PinSource12, GPIO_AF_TIM4);
GPIO_PinAF(GPIOD, GPIO_PinSource13, GPIO_AF_TIM4); GPIO_PinAF(GPIOD, GPIO_PinSource13, GPIO_AF_TIM4);
GPIO_PinAF(GPIOA, GPIO_PinSource0, GPIO_AF_TIM2); GPIO_PinAF(GPIOA, GPIO_PinSource0, GPIO_AF_TIM2);
GPIO_PinAF(GPIOA, GPIO_PinSource1, GPIO_AF_TIM2); GPIO_PinAF(GPIOA, GPIO_PinSource1, GPIO_AF_TIM2);
#if 0 // Skipping since I use TIM8 as stepper generator
TIM_EncoderInterConfig(TIM8, TIM_EncoderMode_TI12, TIM_ICPolarity_Rising, TIM_ICPolarity_Falling); TIM_EncoderInterConfig(TIM8, TIM_EncoderMode_TI12, TIM_ICPolarity_Rising, TIM_ICPolarity_Falling);
TIMER_InitStructure.TIM_Period = 65535; TIMER_InitStructure.TIM_Period = 65535;
TIMER_InitStructure.TIM_CounterMode = TIM_CounterMode_Up | TIM_CounterMode_Down; TIMER_InitStructure.TIM_CounterMode = TIM_CounterMode_Up | TIM_CounterMode_Down;
@@ -323,7 +299,7 @@ void rcc_config()
TIM_TimeBaseStructInit(&TIMER_InitStructure); TIM_TimeBaseStructInit(&TIMER_InitStructure);
TIM_Cmd(TIM8, ENABLE); TIM_Cmd(TIM8, ENABLE);
TIM8->CNT = 0; TIM8->CNT = 0;
#endif
TIM_EncoderInterConfig(TIM4, TIM_EncoderMode_TI12, TIM_ICPolarity_Rising, TIM_ICPolarity_Falling); TIM_EncoderInterConfig(TIM4, TIM_EncoderMode_TI12, TIM_ICPolarity_Rising, TIM_ICPolarity_Falling);
TIMER_InitStructureE.TIM_Period = 65535; TIMER_InitStructureE.TIM_Period = 65535;
TIMER_InitStructureE.TIM_CounterMode = TIM_CounterMode_Up | TIM_CounterMode_Down; TIMER_InitStructureE.TIM_CounterMode = TIM_CounterMode_Up | TIM_CounterMode_Down;
@@ -340,7 +316,7 @@ void rcc_config()
TIM_Cmd(TIM2, ENABLE); TIM_Cmd(TIM2, ENABLE);
TIM2->CNT = 0; TIM2->CNT = 0;
#if 0
TIM_EncoderInterConfig(TIM3, TIM_EncoderMode_TI12, TIM_ICPolarity_Rising, TIM_ICPolarity_Falling); TIM_EncoderInterConfig(TIM3, TIM_EncoderMode_TI12, TIM_ICPolarity_Rising, TIM_ICPolarity_Falling);
TIMER_InitStructureEEG.TIM_Period = 65535; TIMER_InitStructureEEG.TIM_Period = 65535;
TIMER_InitStructureEEG.TIM_CounterMode = TIM_CounterMode_Up | TIM_CounterMode_Down; TIMER_InitStructureEEG.TIM_CounterMode = TIM_CounterMode_Up | TIM_CounterMode_Down;
@@ -349,4 +325,5 @@ void rcc_config()
TIM_Cmd(TIM3, ENABLE); TIM_Cmd(TIM3, ENABLE);
TIM3->CNT = 0; TIM3->CNT = 0;
#endif
} }

184
Firmware/src/main.cpp Executable file
View File

@@ -0,0 +1,184 @@
#include <Arduino.h>
#include <stdio.h>
extern "C"
{
#include "ecat_slv.h"
#include "utypes.h"
};
_Objects Obj;
HardwareSerial Serial1(PA10, PA9);
#define DEBUG_TIM8 1
#include "MyEncoder.h"
void indexPulseEncoderCB1(void);
MyEncoder Encoder1(TIM2, PA2, indexPulseEncoderCB1);
void indexPulseEncoderCB1(void)
{
Encoder1.indexPulse();
}
#include "StepGen.h"
void timerCallbackStep1(void);
StepGen Step1(TIM1, 4, PA_11, PA12, timerCallbackStep1);
void timerCallbackStep1(void)
{
Step1.timerCB();
}
void timerCallbackStep2(void);
StepGen Step2(TIM3, 4, PC_9, PC10, timerCallbackStep2);
void timerCallbackStep2(void)
{
Step2.timerCB();
}
CircularBuffer<uint32_t, 200> Tim;
volatile uint64_t nowTime = 0, thenTime = 0;
void cb_set_outputs(void) // Master outputs gets here, slave inputs, first operation
{
Encoder1.setLatch(Obj.IndexLatchEnable);
Encoder1.setScale(Obj.EncPosScale);
Step1.reqPos(Obj.StepGenIn1.CommandedPosition);
Step1.setScale(Obj.StepGenIn1.StepsPerMM);
Step1.enable(Obj.Enable1);
Step2.reqPos(Obj.StepGenIn2.CommandedPosition);
Step2.setScale(Obj.StepGenIn2.StepsPerMM);
Step2.enable(Obj.Enable1);
}
void handleStepper(void)
{
Step1.handleStepper();
Step2.handleStepper();
}
void cb_get_inputs(void) // Set Master inputs, slave outputs, last operation
{
Obj.IndexStatus = Encoder1.indexHappened();
Obj.EncPos = Encoder1.currentPos();
Obj.EncFrequency = Encoder1.frequency(ESCvar.Time);
Obj.IndexByte = Encoder1.getIndexState();
Obj.StepGenOut1.ActualPosition = Step1.actPos();
Obj.StepGenOut2.ActualPosition = Step2.actPos();
uint32_t dTim = nowTime - thenTime; // Debug. Getting jitter over the last 200 milliseconds
Tim.push(dTim);
uint32_t max_Tim = 0, min_Tim = UINT32_MAX;
for (decltype(Tim)::index_t i = 0; i < Tim.size(); i++)
{
uint32_t aTim = Tim[i];
if (aTim > max_Tim)
max_Tim = aTim;
if (aTim < min_Tim)
min_Tim = aTim;
}
thenTime = nowTime;
Obj.DiffT = max_Tim - min_Tim; // Debug
}
void ESC_interrupt_enable(uint32_t mask);
void ESC_interrupt_disable(uint32_t mask);
uint16_t dc_checker(void);
void sync0Handler(void);
static esc_cfg_t config =
{
.user_arg = NULL,
.use_interrupt = 1,
.watchdog_cnt = 150,
.set_defaults_hook = NULL,
.pre_state_change_hook = NULL,
.post_state_change_hook = NULL,
.application_hook = handleStepper,
.safeoutput_override = NULL,
.pre_object_download_hook = NULL,
.post_object_download_hook = NULL,
.rxpdo_override = NULL,
.txpdo_override = NULL,
.esc_hw_interrupt_enable = ESC_interrupt_enable,
.esc_hw_interrupt_disable = ESC_interrupt_disable,
.esc_hw_eep_handler = NULL,
.esc_check_dc_handler = dc_checker,
};
volatile byte serveIRQ = 0;
void setup(void)
{
Serial1.begin(115200);
rcc_config(); // probably breaks some timers.
ecat_slv_init(&config);
}
void loop(void)
{
if (serveIRQ)
{
nowTime = micros();
DIG_process(DIG_PROCESS_WD_FLAG | DIG_PROCESS_OUTPUTS_FLAG |
DIG_PROCESS_APP_HOOK_FLAG | DIG_PROCESS_INPUTS_FLAG);
serveIRQ = 0;
ESCvar.PrevTime = ESCvar.Time;
}
uint32_t dTime = micros() - nowTime;
if ((dTime > 200 && dTime < 500) || dTime > 1500) // Don't run ecat_slv_poll when expecting to serve interrupt
ecat_slv_poll();
}
void sync0Handler(void)
{
serveIRQ = 1;
}
void ESC_interrupt_enable(uint32_t mask)
{
// Enable interrupt for SYNC0 or SM2 or SM3
// uint32_t user_int_mask = ESCREG_ALEVENT_DC_SYNC0 | ESCREG_ALEVENT_SM2 | ESCREG_ALEVENT_SM3;
uint32_t user_int_mask = ESCREG_ALEVENT_SM2; // Only SM2
if (mask & user_int_mask)
{
ESC_ALeventmaskwrite(ESC_ALeventmaskread() | (mask & user_int_mask));
attachInterrupt(digitalPinToInterrupt(PC3), sync0Handler, RISING);
// Set LAN9252 interrupt pin driver as push-pull active high
uint32_t bits = 0x00000111;
ESC_write(0x54, &bits, 4);
// Enable LAN9252 interrupt
bits = 0x00000001;
ESC_write(0x5c, &bits, 4);
}
}
void ESC_interrupt_disable(uint32_t mask)
{
// Enable interrupt for SYNC0 or SM2 or SM3
// uint32_t user_int_mask = ESCREG_ALEVENT_DC_SYNC0 | ESCREG_ALEVENT_SM2 | ESCREG_ALEVENT_SM3;
uint32_t user_int_mask = ESCREG_ALEVENT_SM2;
if (mask & user_int_mask)
{
// Disable interrupt from SYNC0
ESC_ALeventmaskwrite(ESC_ALeventmaskread() & ~(mask & user_int_mask));
detachInterrupt(digitalPinToInterrupt(PC3));
// Disable LAN9252 interrupt
uint32_t bits = 0x00000000;
ESC_write(0x5c, &bits, 4);
}
}
extern "C" uint32_t ESC_SYNC0cycletime(void);
// Setup of DC
uint16_t dc_checker(void)
{
// Indicate we run DC
ESCvar.dcsync = 1;
StepGen::sync0CycleTime = ESC_SYNC0cycletime() / 1000; // usecs
return 0;
}

14
Kicad/Ax58100-stm32-ethercat/.gitignore vendored Normal file
View File

@@ -0,0 +1,14 @@
AX58100-stm32-ethercat-backups
.~lock*
fp-info-cache
\#auto_saved_file*
gerbers/
Ax58100-stm32-ethercat-backups/
freerouting.*
*.dsn
*.frb
*.rules
*.ses
Ax58100-stm32-ethercat.csv
Ax58100-stm32-ethercat.ods

View File

@@ -4,6 +4,10 @@
(paper "A4") (paper "A4")
(title_block
(title "MetalMusings EaserCAT 3000")
)
(lib_symbols (lib_symbols
(symbol "Device:C" (pin_numbers hide) (pin_names (offset 0.254)) (in_bom yes) (on_board yes) (symbol "Device:C" (pin_numbers hide) (pin_names (offset 0.254)) (in_bom yes) (on_board yes)
(property "Reference" "C" (at 0.635 2.54 0) (property "Reference" "C" (at 0.635 2.54 0)
@@ -2937,7 +2941,7 @@
(symbol (lib_id "Device:R") (at 245.11 88.9 270) (unit 1) (symbol (lib_id "Device:R") (at 245.11 88.9 270) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 0156fcd2-2fd8-4277-bfea-a43d1b5d2609) (uuid 0156fcd2-2fd8-4277-bfea-a43d1b5d2609)
(property "Reference" "R44" (at 245.11 88.9 90) (property "Reference" "R63" (at 245.11 88.9 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "510" (at 250.19 87.63 90) (property "Value" "510" (at 250.19 87.63 90)
@@ -2952,9 +2956,9 @@
(pin "1" (uuid 3752539c-2c69-46a2-a3d9-8913b7ee49c7)) (pin "1" (uuid 3752539c-2c69-46a2-a3d9-8913b7ee49c7))
(pin "2" (uuid 8f74b202-e220-4289-9977-65720527d874)) (pin "2" (uuid 8f74b202-e220-4289-9977-65720527d874))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R44") (unit 1) (reference "R63") (unit 1)
) )
) )
) )
@@ -2963,7 +2967,7 @@
(symbol (lib_id "Device:FerriteBead_Small") (at 137.16 162.56 90) (unit 1) (symbol (lib_id "Device:FerriteBead_Small") (at 137.16 162.56 90) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 044bfca2-fe85-424e-89e6-85976fdf3676) (uuid 044bfca2-fe85-424e-89e6-85976fdf3676)
(property "Reference" "B7" (at 137.16 160.02 90) (property "Reference" "B6" (at 137.16 160.02 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "BLM18EG221SN1D" (at 137.16 165.1 90) (property "Value" "BLM18EG221SN1D" (at 137.16 165.1 90)
@@ -2978,9 +2982,9 @@
(pin "1" (uuid ce30afd8-a25d-4870-9efa-022fce854733)) (pin "1" (uuid ce30afd8-a25d-4870-9efa-022fce854733))
(pin "2" (uuid 85e1ac12-3de6-46da-8cce-3f5869ed6d28)) (pin "2" (uuid 85e1ac12-3de6-46da-8cce-3f5869ed6d28))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "B7") (unit 1) (reference "B6") (unit 1)
) )
) )
) )
@@ -3003,7 +3007,7 @@
) )
(pin "1" (uuid b4286fda-2783-4812-9fb8-e6104bd26acc)) (pin "1" (uuid b4286fda-2783-4812-9fb8-e6104bd26acc))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -3017,10 +3021,10 @@
(symbol (lib_id "Device:R") (at 222.25 127 270) (unit 1) (symbol (lib_id "Device:R") (at 222.25 127 270) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 137b958d-6c66-4243-b922-13e0d4e0ff22) (uuid 137b958d-6c66-4243-b922-13e0d4e0ff22)
(property "Reference" "R40" (at 222.25 127 90) (property "Reference" "R71" (at 222.25 127 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "4.7k" (at 227.33 125.73 90) (property "Value" "4k7" (at 227.33 125.73 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Footprint" "Resistor_SMD:R_0805_2012Metric" (at 222.25 125.222 90) (property "Footprint" "Resistor_SMD:R_0805_2012Metric" (at 222.25 125.222 90)
@@ -3032,9 +3036,9 @@
(pin "1" (uuid 8aa0f7bb-c0f5-48e6-b540-08704181c12d)) (pin "1" (uuid 8aa0f7bb-c0f5-48e6-b540-08704181c12d))
(pin "2" (uuid 8c988c69-1f95-43c3-9bcb-d12d0b7d82ba)) (pin "2" (uuid 8c988c69-1f95-43c3-9bcb-d12d0b7d82ba))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R40") (unit 1) (reference "R71") (unit 1)
) )
) )
) )
@@ -3057,7 +3061,7 @@
) )
(pin "1" (uuid 150b4d57-c89c-479b-bff0-e2310444c77d)) (pin "1" (uuid 150b4d57-c89c-479b-bff0-e2310444c77d))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "#PWR056") (unit 1) (reference "#PWR056") (unit 1)
) )
@@ -3068,7 +3072,7 @@
(symbol (lib_id "Device:FerriteBead_Small") (at 99.06 154.94 90) (unit 1) (symbol (lib_id "Device:FerriteBead_Small") (at 99.06 154.94 90) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 18c39117-9175-49a5-804f-919c3f463e74) (uuid 18c39117-9175-49a5-804f-919c3f463e74)
(property "Reference" "B3" (at 99.06 152.4 90) (property "Reference" "B1" (at 99.06 152.4 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "BLM18EG221SN1D" (at 99.06 157.48 90) (property "Value" "BLM18EG221SN1D" (at 99.06 157.48 90)
@@ -3083,9 +3087,9 @@
(pin "1" (uuid 30443703-171b-4062-a9a8-d4bb1a6cd79f)) (pin "1" (uuid 30443703-171b-4062-a9a8-d4bb1a6cd79f))
(pin "2" (uuid d5abfeb8-19ea-435e-b773-b63d9d82edd8)) (pin "2" (uuid d5abfeb8-19ea-435e-b773-b63d9d82edd8))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "B3") (unit 1) (reference "B1") (unit 1)
) )
) )
) )
@@ -3094,7 +3098,7 @@
(symbol (lib_id "Device:R") (at 46.99 36.83 180) (unit 1) (symbol (lib_id "Device:R") (at 46.99 36.83 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 1c4db209-5e6a-4cbe-b133-c6f6909b09dd) (uuid 1c4db209-5e6a-4cbe-b133-c6f6909b09dd)
(property "Reference" "R19" (at 46.99 36.83 90) (property "Reference" "R55" (at 46.99 36.83 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "49.9" (at 45.72 31.75 90) (property "Value" "49.9" (at 45.72 31.75 90)
@@ -3109,9 +3113,9 @@
(pin "1" (uuid 9c44675f-5941-4a75-acce-cfa5a16cee28)) (pin "1" (uuid 9c44675f-5941-4a75-acce-cfa5a16cee28))
(pin "2" (uuid 4e2a14c7-60d8-4f96-9157-b88e1863088b)) (pin "2" (uuid 4e2a14c7-60d8-4f96-9157-b88e1863088b))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R19") (unit 1) (reference "R55") (unit 1)
) )
) )
) )
@@ -3126,7 +3130,7 @@
(property "Value" "Green led" (at 209.55 119.38 0) (property "Value" "Green led" (at 209.55 119.38 0)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Footprint" "LED_SMD:LED_0805_2012Metric" (at 209.55 123.19 0) (property "Footprint" "LED_SMD:LED_0603_1608Metric" (at 209.55 123.19 0)
(effects (font (size 1.27 1.27)) hide) (effects (font (size 1.27 1.27)) hide)
) )
(property "Datasheet" "~" (at 209.55 123.19 0) (property "Datasheet" "~" (at 209.55 123.19 0)
@@ -3135,12 +3139,12 @@
(pin "1" (uuid 27bbe9ee-ab28-4046-b67a-1dc794ae83b4)) (pin "1" (uuid 27bbe9ee-ab28-4046-b67a-1dc794ae83b4))
(pin "2" (uuid ca5e92c1-46d8-46d6-aee1-4f1bfd6a9595)) (pin "2" (uuid ca5e92c1-46d8-46d6-aee1-4f1bfd6a9595))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "D?") (unit 1) (reference "D?") (unit 1)
) )
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "D1") (unit 1) (reference "D21") (unit 1)
) )
) )
) )
@@ -3163,7 +3167,7 @@
) )
(pin "1" (uuid ce06647b-866d-40cd-8b9b-dab8c24988c6)) (pin "1" (uuid ce06647b-866d-40cd-8b9b-dab8c24988c6))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "#PWR094") (unit 1) (reference "#PWR094") (unit 1)
) )
@@ -3174,7 +3178,7 @@
(symbol (lib_id "Device:C") (at 58.42 128.27 180) (unit 1) (symbol (lib_id "Device:C") (at 58.42 128.27 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 252ccc0b-afe2-4cfa-9240-bbd4119b8767) (uuid 252ccc0b-afe2-4cfa-9240-bbd4119b8767)
(property "Reference" "C26" (at 59.69 132.08 90) (property "Reference" "C29" (at 59.69 132.08 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "10pF" (at 59.69 124.46 90) (property "Value" "10pF" (at 59.69 124.46 90)
@@ -3189,9 +3193,9 @@
(pin "1" (uuid 1faaa323-05c8-437f-9e53-3fae02ded476)) (pin "1" (uuid 1faaa323-05c8-437f-9e53-3fae02ded476))
(pin "2" (uuid 26c28e23-2a0b-49b1-9ccb-5cbe7e37eeeb)) (pin "2" (uuid 26c28e23-2a0b-49b1-9ccb-5cbe7e37eeeb))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C26") (unit 1) (reference "C29") (unit 1)
) )
) )
) )
@@ -3214,7 +3218,7 @@
) )
(pin "1" (uuid 6c4829bb-1b47-4019-a759-39388763f312)) (pin "1" (uuid 6c4829bb-1b47-4019-a759-39388763f312))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -3243,7 +3247,7 @@
(pin "1" (uuid eb1efbba-d916-4c6d-b713-0da6d7f6730e)) (pin "1" (uuid eb1efbba-d916-4c6d-b713-0da6d7f6730e))
(pin "2" (uuid 09af7273-6b3d-4a8b-8d1b-f39f40c2ea31)) (pin "2" (uuid 09af7273-6b3d-4a8b-8d1b-f39f40c2ea31))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C28") (unit 1) (reference "C28") (unit 1)
) )
@@ -3268,7 +3272,7 @@
) )
(pin "1" (uuid c6b0d3af-51f1-4de8-adfc-13a2363b3890)) (pin "1" (uuid c6b0d3af-51f1-4de8-adfc-13a2363b3890))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -3282,7 +3286,7 @@
(symbol (lib_id "Device:R") (at 52.07 36.83 180) (unit 1) (symbol (lib_id "Device:R") (at 52.07 36.83 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 395e4cb0-42d4-43ec-b523-c62753046557) (uuid 395e4cb0-42d4-43ec-b523-c62753046557)
(property "Reference" "R21" (at 52.07 36.83 90) (property "Reference" "R54" (at 52.07 36.83 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "49.9" (at 50.8 31.75 90) (property "Value" "49.9" (at 50.8 31.75 90)
@@ -3297,9 +3301,9 @@
(pin "1" (uuid 0f107702-d4eb-42fe-a9cb-1892d3116999)) (pin "1" (uuid 0f107702-d4eb-42fe-a9cb-1892d3116999))
(pin "2" (uuid e8d3e7e0-6321-4996-b418-7ec31e2c7dba)) (pin "2" (uuid e8d3e7e0-6321-4996-b418-7ec31e2c7dba))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R21") (unit 1) (reference "R54") (unit 1)
) )
) )
) )
@@ -3322,7 +3326,7 @@
) )
(pin "1" (uuid aed6da48-6f5d-428b-a155-5e5439155c79)) (pin "1" (uuid aed6da48-6f5d-428b-a155-5e5439155c79))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -3350,7 +3354,7 @@
) )
(pin "1" (uuid e783af1e-5de5-47a1-86cf-6567c67655d1)) (pin "1" (uuid e783af1e-5de5-47a1-86cf-6567c67655d1))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR01") (unit 1) (reference "#PWR01") (unit 1)
) )
@@ -3364,7 +3368,7 @@
(symbol (lib_id "Device:R") (at 135.89 59.69 0) (unit 1) (symbol (lib_id "Device:R") (at 135.89 59.69 0) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 43243964-0602-4452-b782-e18672992d26) (uuid 43243964-0602-4452-b782-e18672992d26)
(property "Reference" "R27" (at 135.89 59.69 90) (property "Reference" "R62" (at 135.89 59.69 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "510" (at 134.62 54.61 90) (property "Value" "510" (at 134.62 54.61 90)
@@ -3379,9 +3383,9 @@
(pin "1" (uuid 6ac90f4b-0815-405b-889b-341829faddb4)) (pin "1" (uuid 6ac90f4b-0815-405b-889b-341829faddb4))
(pin "2" (uuid c6ad70e0-3056-48fa-95b2-d6f063e2b233)) (pin "2" (uuid c6ad70e0-3056-48fa-95b2-d6f063e2b233))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R27") (unit 1) (reference "R62") (unit 1)
) )
) )
) )
@@ -3417,7 +3421,7 @@
(pin "9" (uuid 817cd1e4-9788-4c48-9727-07f09efa1d17)) (pin "9" (uuid 817cd1e4-9788-4c48-9727-07f09efa1d17))
(pin "SH" (uuid ac135a42-bab5-4c6d-886d-3627a6140526)) (pin "SH" (uuid ac135a42-bab5-4c6d-886d-3627a6140526))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "OUT1") (unit 1) (reference "OUT1") (unit 1)
) )
@@ -3442,7 +3446,7 @@
) )
(pin "1" (uuid 1fae1061-e7aa-445b-994b-f8a9b2e2ec2a)) (pin "1" (uuid 1fae1061-e7aa-445b-994b-f8a9b2e2ec2a))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR072") (unit 1) (reference "#PWR072") (unit 1)
) )
@@ -3456,7 +3460,7 @@
(symbol (lib_id "Device:R") (at 245.11 49.53 270) (unit 1) (symbol (lib_id "Device:R") (at 245.11 49.53 270) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 52f49fd2-f073-4f65-b85d-4076ede1e08b) (uuid 52f49fd2-f073-4f65-b85d-4076ede1e08b)
(property "Reference" "R41" (at 245.11 49.53 90) (property "Reference" "R57" (at 245.11 49.53 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "510" (at 251.46 48.26 90) (property "Value" "510" (at 251.46 48.26 90)
@@ -3471,9 +3475,9 @@
(pin "1" (uuid 7d906a13-3fe2-447e-831a-59c2497d252f)) (pin "1" (uuid 7d906a13-3fe2-447e-831a-59c2497d252f))
(pin "2" (uuid 8222f5da-4ab5-4383-a237-63d36a12d082)) (pin "2" (uuid 8222f5da-4ab5-4383-a237-63d36a12d082))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R41") (unit 1) (reference "R57") (unit 1)
) )
) )
) )
@@ -3497,7 +3501,7 @@
(pin "1" (uuid aae33058-ad5f-49ab-a3e0-18222db92984)) (pin "1" (uuid aae33058-ad5f-49ab-a3e0-18222db92984))
(pin "2" (uuid 659c955d-3562-4008-adee-2dd41397218c)) (pin "2" (uuid 659c955d-3562-4008-adee-2dd41397218c))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "B4") (unit 1) (reference "B4") (unit 1)
) )
@@ -3508,7 +3512,7 @@
(symbol (lib_id "Device:R") (at 48.26 96.52 180) (unit 1) (symbol (lib_id "Device:R") (at 48.26 96.52 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 5b51c0db-89fb-4b33-acf6-55877b663ddb) (uuid 5b51c0db-89fb-4b33-acf6-55877b663ddb)
(property "Reference" "R20" (at 48.26 96.52 90) (property "Reference" "R51" (at 48.26 96.52 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "49.9" (at 46.99 91.44 90) (property "Value" "49.9" (at 46.99 91.44 90)
@@ -3523,9 +3527,9 @@
(pin "1" (uuid 6c88d2e5-931c-4011-871e-8f1366339240)) (pin "1" (uuid 6c88d2e5-931c-4011-871e-8f1366339240))
(pin "2" (uuid 8d6783e5-4f4f-4b0d-95c5-14e7a72f41dd)) (pin "2" (uuid 8d6783e5-4f4f-4b0d-95c5-14e7a72f41dd))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R20") (unit 1) (reference "R51") (unit 1)
) )
) )
) )
@@ -3549,7 +3553,7 @@
(pin "1" (uuid 9b8fae84-700f-46e0-bfe6-c8911c62718b)) (pin "1" (uuid 9b8fae84-700f-46e0-bfe6-c8911c62718b))
(pin "2" (uuid 99a1fb0a-7bed-4961-8684-6ee4ac7d39ab)) (pin "2" (uuid 99a1fb0a-7bed-4961-8684-6ee4ac7d39ab))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "B2") (unit 1) (reference "B2") (unit 1)
) )
@@ -3560,10 +3564,10 @@
(symbol (lib_id "Device:R") (at 212.09 95.25 270) (unit 1) (symbol (lib_id "Device:R") (at 212.09 95.25 270) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 5d2a3bd4-36a3-4cd5-b2ec-31d44b293cc0) (uuid 5d2a3bd4-36a3-4cd5-b2ec-31d44b293cc0)
(property "Reference" "R38" (at 212.09 95.25 90) (property "Reference" "R64" (at 212.09 95.25 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "4.7k" (at 217.17 93.98 90) (property "Value" "4k7" (at 217.17 93.98 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Footprint" "Resistor_SMD:R_0805_2012Metric" (at 212.09 93.472 90) (property "Footprint" "Resistor_SMD:R_0805_2012Metric" (at 212.09 93.472 90)
@@ -3575,9 +3579,9 @@
(pin "1" (uuid 0ad90d25-2752-48fc-ba38-83a7363aa081)) (pin "1" (uuid 0ad90d25-2752-48fc-ba38-83a7363aa081))
(pin "2" (uuid 419d0f25-e998-4d0b-9239-3fb9ce68106d)) (pin "2" (uuid 419d0f25-e998-4d0b-9239-3fb9ce68106d))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R38") (unit 1) (reference "R64") (unit 1)
) )
) )
) )
@@ -3600,7 +3604,7 @@
) )
(pin "1" (uuid fff4d499-3879-4e19-b110-0b209a883c13)) (pin "1" (uuid fff4d499-3879-4e19-b110-0b209a883c13))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -3614,7 +3618,7 @@
(symbol (lib_id "Device:FerriteBead_Small") (at 62.23 36.83 0) (unit 1) (symbol (lib_id "Device:FerriteBead_Small") (at 62.23 36.83 0) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (fields_autoplaced) (in_bom yes) (on_board yes) (dnp no) (fields_autoplaced)
(uuid 5f64f649-130a-4994-879c-e0ac6e94924e) (uuid 5f64f649-130a-4994-879c-e0ac6e94924e)
(property "Reference" "B1" (at 64.6938 35.5798 0) (property "Reference" "B3" (at 64.6938 35.5798 0)
(effects (font (size 1.27 1.27)) (justify left)) (effects (font (size 1.27 1.27)) (justify left))
) )
(property "Value" "BLM18EG221S" (at 64.6938 38.004 0) (property "Value" "BLM18EG221S" (at 64.6938 38.004 0)
@@ -3629,9 +3633,9 @@
(pin "1" (uuid 5d890a5b-3d41-4477-b877-182c869c0fba)) (pin "1" (uuid 5d890a5b-3d41-4477-b877-182c869c0fba))
(pin "2" (uuid edc1ebdc-fc89-4d82-a46a-f040db1d4923)) (pin "2" (uuid edc1ebdc-fc89-4d82-a46a-f040db1d4923))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "B1") (unit 1) (reference "B3") (unit 1)
) )
) )
) )
@@ -3640,10 +3644,10 @@
(symbol (lib_id "Device:R") (at 209.55 27.94 270) (unit 1) (symbol (lib_id "Device:R") (at 209.55 27.94 270) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 5ff7eb3b-4022-400e-8b2d-e57549faafb6) (uuid 5ff7eb3b-4022-400e-8b2d-e57549faafb6)
(property "Reference" "R30" (at 209.55 27.94 90) (property "Reference" "R46" (at 209.55 27.94 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "4.7k" (at 214.63 26.67 90) (property "Value" "4k7" (at 214.63 26.67 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Footprint" "Resistor_SMD:R_0805_2012Metric" (at 209.55 26.162 90) (property "Footprint" "Resistor_SMD:R_0805_2012Metric" (at 209.55 26.162 90)
@@ -3655,9 +3659,9 @@
(pin "1" (uuid 19809a18-de41-4f43-8706-aac4fa515646)) (pin "1" (uuid 19809a18-de41-4f43-8706-aac4fa515646))
(pin "2" (uuid 30a7ba03-945a-4af3-b39e-49710f1d63c4)) (pin "2" (uuid 30a7ba03-945a-4af3-b39e-49710f1d63c4))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R30") (unit 1) (reference "R46") (unit 1)
) )
) )
) )
@@ -3681,12 +3685,12 @@
(pin "1" (uuid f2c74cbb-4905-4703-829d-2e0d89dca501)) (pin "1" (uuid f2c74cbb-4905-4703-829d-2e0d89dca501))
(pin "2" (uuid 259684e5-5a66-4626-b173-3d4054a0267c)) (pin "2" (uuid 259684e5-5a66-4626-b173-3d4054a0267c))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "C39") (unit 1) (reference "C39") (unit 1)
) )
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C31") (unit 1) (reference "C44") (unit 1)
) )
) )
) )
@@ -3695,7 +3699,7 @@
(symbol (lib_id "Device:C") (at 46.99 68.58 180) (unit 1) (symbol (lib_id "Device:C") (at 46.99 68.58 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 703a5ad5-261f-462a-927b-2f5091816ac1) (uuid 703a5ad5-261f-462a-927b-2f5091816ac1)
(property "Reference" "C21" (at 48.26 72.39 90) (property "Reference" "C36" (at 48.26 72.39 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "10pF" (at 48.26 64.77 90) (property "Value" "10pF" (at 48.26 64.77 90)
@@ -3710,9 +3714,9 @@
(pin "1" (uuid b75f8eb4-da60-49f1-a715-e7496c5e1f46)) (pin "1" (uuid b75f8eb4-da60-49f1-a715-e7496c5e1f46))
(pin "2" (uuid 916c3103-8ea2-487f-b358-de3bad1d1c50)) (pin "2" (uuid 916c3103-8ea2-487f-b358-de3bad1d1c50))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C21") (unit 1) (reference "C36") (unit 1)
) )
) )
) )
@@ -3724,10 +3728,10 @@
(property "Reference" "D?" (at 228.6 46.99 0) (property "Reference" "D?" (at 228.6 46.99 0)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "Green led" (at 228.6 53.34 0) (property "Value" "Green led" (at 231.775 51.435 0)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Footprint" "LED_SMD:LED_0805_2012Metric" (at 228.6 49.53 0) (property "Footprint" "LED_SMD:LED_0603_1608Metric" (at 228.6 49.53 0)
(effects (font (size 1.27 1.27)) hide) (effects (font (size 1.27 1.27)) hide)
) )
(property "Datasheet" "~" (at 228.6 49.53 0) (property "Datasheet" "~" (at 228.6 49.53 0)
@@ -3736,12 +3740,12 @@
(pin "1" (uuid 9a13d0d2-c31d-497e-a30b-639d91db4f78)) (pin "1" (uuid 9a13d0d2-c31d-497e-a30b-639d91db4f78))
(pin "2" (uuid 9cede751-efc2-476c-9f6b-818039dd78c2)) (pin "2" (uuid 9cede751-efc2-476c-9f6b-818039dd78c2))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "D?") (unit 1) (reference "D?") (unit 1)
) )
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "D2") (unit 1) (reference "D19") (unit 1)
) )
) )
) )
@@ -3750,7 +3754,7 @@
(symbol (lib_id "Device:R") (at 41.91 36.83 180) (unit 1) (symbol (lib_id "Device:R") (at 41.91 36.83 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 7e520c4e-ee0b-4ea7-8b18-2be4397e790f) (uuid 7e520c4e-ee0b-4ea7-8b18-2be4397e790f)
(property "Reference" "R17" (at 41.91 36.83 90) (property "Reference" "R56" (at 41.91 36.83 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "49.9" (at 40.64 31.75 90) (property "Value" "49.9" (at 40.64 31.75 90)
@@ -3765,9 +3769,9 @@
(pin "1" (uuid 2f21ad1e-fffb-48c5-8819-0bcbc46337a2)) (pin "1" (uuid 2f21ad1e-fffb-48c5-8819-0bcbc46337a2))
(pin "2" (uuid ac75cb01-8359-4122-b309-5ff593eb8dcd)) (pin "2" (uuid ac75cb01-8359-4122-b309-5ff593eb8dcd))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R17") (unit 1) (reference "R56") (unit 1)
) )
) )
) )
@@ -3776,7 +3780,7 @@
(symbol (lib_id "Device:C") (at 53.34 128.27 180) (unit 1) (symbol (lib_id "Device:C") (at 53.34 128.27 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 817571cd-b71b-4f1f-b21a-2340accaf437) (uuid 817571cd-b71b-4f1f-b21a-2340accaf437)
(property "Reference" "C24" (at 54.61 132.08 90) (property "Reference" "C30" (at 54.61 132.08 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "10pF" (at 54.61 124.46 90) (property "Value" "10pF" (at 54.61 124.46 90)
@@ -3791,9 +3795,9 @@
(pin "1" (uuid ce9020c7-e569-440f-9b91-36b691be4a7a)) (pin "1" (uuid ce9020c7-e569-440f-9b91-36b691be4a7a))
(pin "2" (uuid d17824ba-890a-463a-8055-7485ab2d831c)) (pin "2" (uuid d17824ba-890a-463a-8055-7485ab2d831c))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C24") (unit 1) (reference "C30") (unit 1)
) )
) )
) )
@@ -3816,7 +3820,7 @@
) )
(pin "1" (uuid e063590e-34b0-400c-b743-411bea30774d)) (pin "1" (uuid e063590e-34b0-400c-b743-411bea30774d))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -3844,7 +3848,7 @@
) )
(pin "1" (uuid 529748f6-5d79-49f8-8fda-734244b914ae)) (pin "1" (uuid 529748f6-5d79-49f8-8fda-734244b914ae))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -3872,7 +3876,7 @@
) )
(pin "1" (uuid 4d6779f2-5074-4af9-ac64-a6f96cd98b0f)) (pin "1" (uuid 4d6779f2-5074-4af9-ac64-a6f96cd98b0f))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "#PWR093") (unit 1) (reference "#PWR093") (unit 1)
) )
@@ -3898,7 +3902,7 @@
(pin "1" (uuid 7e60b41a-43e8-4081-bb73-cca0e017a179)) (pin "1" (uuid 7e60b41a-43e8-4081-bb73-cca0e017a179))
(pin "2" (uuid 74867d90-11c9-4ba3-88b3-d3aebb6e7cc9)) (pin "2" (uuid 74867d90-11c9-4ba3-88b3-d3aebb6e7cc9))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "B5") (unit 1) (reference "B5") (unit 1)
) )
@@ -3909,7 +3913,7 @@
(symbol (lib_id "Device:R") (at 57.15 36.83 180) (unit 1) (symbol (lib_id "Device:R") (at 57.15 36.83 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid 94e7971f-a4d4-466b-8bd1-b0a1da13dc73) (uuid 94e7971f-a4d4-466b-8bd1-b0a1da13dc73)
(property "Reference" "R23" (at 57.15 36.83 90) (property "Reference" "R53" (at 57.15 36.83 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "49.9" (at 55.88 31.75 90) (property "Value" "49.9" (at 55.88 31.75 90)
@@ -3924,9 +3928,9 @@
(pin "1" (uuid bcdff5ac-2327-4a3f-8517-fe8ed737d70f)) (pin "1" (uuid bcdff5ac-2327-4a3f-8517-fe8ed737d70f))
(pin "2" (uuid 501ebfd6-1f99-49e1-9dde-35705321adb8)) (pin "2" (uuid 501ebfd6-1f99-49e1-9dde-35705321adb8))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R23") (unit 1) (reference "R53") (unit 1)
) )
) )
) )
@@ -3950,12 +3954,12 @@
(pin "1" (uuid dab96c68-1b90-4f99-af80-706cd880d259)) (pin "1" (uuid dab96c68-1b90-4f99-af80-706cd880d259))
(pin "2" (uuid f083a329-d96b-4b01-a456-9548cf8e7561)) (pin "2" (uuid f083a329-d96b-4b01-a456-9548cf8e7561))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "C30") (unit 1) (reference "C30") (unit 1)
) )
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C29") (unit 1) (reference "C43") (unit 1)
) )
) )
) )
@@ -3978,7 +3982,7 @@
) )
(pin "1" (uuid 436e4c43-9d46-4864-834d-7f41395647f4)) (pin "1" (uuid 436e4c43-9d46-4864-834d-7f41395647f4))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -4006,7 +4010,7 @@
) )
(pin "1" (uuid 82bd38b9-f1f3-43a2-a039-c0cf152fc820)) (pin "1" (uuid 82bd38b9-f1f3-43a2-a039-c0cf152fc820))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -4020,7 +4024,7 @@
(symbol (lib_id "Device:R") (at 222.25 123.19 270) (unit 1) (symbol (lib_id "Device:R") (at 222.25 123.19 270) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid a8f795da-4f57-4266-9dbc-d4b1ec49a21b) (uuid a8f795da-4f57-4266-9dbc-d4b1ec49a21b)
(property "Reference" "R39" (at 222.25 123.19 90) (property "Reference" "R70" (at 222.25 123.19 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "510" (at 228.6 121.92 90) (property "Value" "510" (at 228.6 121.92 90)
@@ -4035,9 +4039,9 @@
(pin "1" (uuid 469f189d-fdf4-4f27-8b9d-c5c17032c111)) (pin "1" (uuid 469f189d-fdf4-4f27-8b9d-c5c17032c111))
(pin "2" (uuid 8f0da2c6-dd77-442c-bb69-dea5e953a08e)) (pin "2" (uuid 8f0da2c6-dd77-442c-bb69-dea5e953a08e))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R39") (unit 1) (reference "R70") (unit 1)
) )
) )
) )
@@ -4060,7 +4064,7 @@
) )
(pin "1" (uuid 0a294b22-7110-4a7f-8168-dfa829b9b5ba)) (pin "1" (uuid 0a294b22-7110-4a7f-8168-dfa829b9b5ba))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -4088,7 +4092,7 @@
) )
(pin "1" (uuid 72620a63-4ea4-434b-ba54-789d0234762d)) (pin "1" (uuid 72620a63-4ea4-434b-ba54-789d0234762d))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -4102,7 +4106,7 @@
(symbol (lib_id "Device:R") (at 53.34 96.52 180) (unit 1) (symbol (lib_id "Device:R") (at 53.34 96.52 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid aaa3a6f9-473c-405e-9246-c50f1418c80a) (uuid aaa3a6f9-473c-405e-9246-c50f1418c80a)
(property "Reference" "R22" (at 53.34 96.52 90) (property "Reference" "R50" (at 53.34 96.52 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "49.9" (at 52.07 91.44 90) (property "Value" "49.9" (at 52.07 91.44 90)
@@ -4117,9 +4121,9 @@
(pin "1" (uuid 4f7fb9b8-83bb-41a8-9a65-765e17b382ac)) (pin "1" (uuid 4f7fb9b8-83bb-41a8-9a65-765e17b382ac))
(pin "2" (uuid c9fc11bf-5137-4c12-8669-afb9a215a7b3)) (pin "2" (uuid c9fc11bf-5137-4c12-8669-afb9a215a7b3))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R22") (unit 1) (reference "R50") (unit 1)
) )
) )
) )
@@ -4128,7 +4132,7 @@
(symbol (lib_id "Device:C") (at 48.26 128.27 180) (unit 1) (symbol (lib_id "Device:C") (at 48.26 128.27 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid acd922bf-b439-49a5-93b9-08d057963a14) (uuid acd922bf-b439-49a5-93b9-08d057963a14)
(property "Reference" "C22" (at 49.53 132.08 90) (property "Reference" "C31" (at 49.53 132.08 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "10pF" (at 49.53 124.46 90) (property "Value" "10pF" (at 49.53 124.46 90)
@@ -4143,9 +4147,9 @@
(pin "1" (uuid 6ddef0ae-8be0-4cda-923c-74b5196b0441)) (pin "1" (uuid 6ddef0ae-8be0-4cda-923c-74b5196b0441))
(pin "2" (uuid 3bcc60cd-b15b-409f-b0ea-b8e0e4bae10e)) (pin "2" (uuid 3bcc60cd-b15b-409f-b0ea-b8e0e4bae10e))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C22") (unit 1) (reference "C31") (unit 1)
) )
) )
) )
@@ -4168,7 +4172,7 @@
) )
(pin "1" (uuid e5a674e0-57a1-4b6f-8414-07b99cb9dd05)) (pin "1" (uuid e5a674e0-57a1-4b6f-8414-07b99cb9dd05))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -4182,7 +4186,7 @@
(symbol (lib_id "Device:C") (at 43.18 128.27 180) (unit 1) (symbol (lib_id "Device:C") (at 43.18 128.27 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid b297d9a7-f493-4b05-81ae-f0b3d7b2667f) (uuid b297d9a7-f493-4b05-81ae-f0b3d7b2667f)
(property "Reference" "C20" (at 44.45 132.08 90) (property "Reference" "C32" (at 44.45 132.08 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "10pF" (at 44.45 124.46 90) (property "Value" "10pF" (at 44.45 124.46 90)
@@ -4197,9 +4201,9 @@
(pin "1" (uuid c6e1b5a5-eebb-4ef2-b093-5512c6da6af1)) (pin "1" (uuid c6e1b5a5-eebb-4ef2-b093-5512c6da6af1))
(pin "2" (uuid ba36a1e9-aceb-4cf8-a032-bf9a64429e4d)) (pin "2" (uuid ba36a1e9-aceb-4cf8-a032-bf9a64429e4d))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C20") (unit 1) (reference "C32") (unit 1)
) )
) )
) )
@@ -4208,10 +4212,10 @@
(symbol (lib_id "Device:R") (at 209.55 55.88 270) (unit 1) (symbol (lib_id "Device:R") (at 209.55 55.88 270) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid b5c12ec7-2ca4-4236-a5f3-044e9cc59673) (uuid b5c12ec7-2ca4-4236-a5f3-044e9cc59673)
(property "Reference" "R33" (at 209.55 55.88 90) (property "Reference" "R48" (at 209.55 55.88 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "4.7k" (at 215.9 54.61 90) (property "Value" "4k7" (at 215.9 54.61 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Footprint" "Resistor_SMD:R_0805_2012Metric" (at 209.55 54.102 90) (property "Footprint" "Resistor_SMD:R_0805_2012Metric" (at 209.55 54.102 90)
@@ -4223,9 +4227,9 @@
(pin "1" (uuid 3054861d-03f0-476c-a69d-a4135a07cbf5)) (pin "1" (uuid 3054861d-03f0-476c-a69d-a4135a07cbf5))
(pin "2" (uuid 22a65f2f-8576-4a5e-982d-59c158caec02)) (pin "2" (uuid 22a65f2f-8576-4a5e-982d-59c158caec02))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R33") (unit 1) (reference "R48") (unit 1)
) )
) )
) )
@@ -4234,7 +4238,7 @@
(symbol (lib_id "Device:R") (at 43.18 96.52 180) (unit 1) (symbol (lib_id "Device:R") (at 43.18 96.52 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid b79bae43-c327-493d-a038-855680f06fe3) (uuid b79bae43-c327-493d-a038-855680f06fe3)
(property "Reference" "R18" (at 43.18 96.52 90) (property "Reference" "R52" (at 43.18 96.52 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "49.9" (at 41.91 91.44 90) (property "Value" "49.9" (at 41.91 91.44 90)
@@ -4249,9 +4253,9 @@
(pin "1" (uuid c63aad62-261e-454d-8cde-5d3b9e8e6bee)) (pin "1" (uuid c63aad62-261e-454d-8cde-5d3b9e8e6bee))
(pin "2" (uuid c2657820-6139-48c9-ac60-3056679753ae)) (pin "2" (uuid c2657820-6139-48c9-ac60-3056679753ae))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R18") (unit 1) (reference "R52") (unit 1)
) )
) )
) )
@@ -4274,7 +4278,7 @@
) )
(pin "1" (uuid e8944e69-8cc5-433d-bd5d-62029af4cc4b)) (pin "1" (uuid e8944e69-8cc5-433d-bd5d-62029af4cc4b))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -4304,12 +4308,12 @@
(pin "2" (uuid d913a363-97ba-4827-b453-8fb0703a3900)) (pin "2" (uuid d913a363-97ba-4827-b453-8fb0703a3900))
(pin "3" (uuid b273c120-c078-47c2-a767-363253c602b8)) (pin "3" (uuid b273c120-c078-47c2-a767-363253c602b8))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "U3") (unit 1) (reference "U3") (unit 1)
) )
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "U3") (unit 1) (reference "U9") (unit 1)
) )
) )
) )
@@ -4324,7 +4328,7 @@
(property "Value" "Red led" (at 228.6 92.71 0) (property "Value" "Red led" (at 228.6 92.71 0)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Footprint" "LED_SMD:LED_0805_2012Metric" (at 228.6 88.9 0) (property "Footprint" "LED_SMD:LED_0603_1608Metric" (at 228.6 88.9 0)
(effects (font (size 1.27 1.27)) hide) (effects (font (size 1.27 1.27)) hide)
) )
(property "Datasheet" "~" (at 228.6 88.9 0) (property "Datasheet" "~" (at 228.6 88.9 0)
@@ -4333,12 +4337,12 @@
(pin "1" (uuid f4bdf53a-1004-4a8d-9aa5-5ce88c32b080)) (pin "1" (uuid f4bdf53a-1004-4a8d-9aa5-5ce88c32b080))
(pin "2" (uuid 3fefe425-fceb-410e-bcfc-b5145544b90c)) (pin "2" (uuid 3fefe425-fceb-410e-bcfc-b5145544b90c))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "D?") (unit 1) (reference "D?") (unit 1)
) )
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "D3") (unit 1) (reference "D20") (unit 1)
) )
) )
) )
@@ -4374,7 +4378,7 @@
(pin "9" (uuid 73e32536-95b1-46be-aafb-811b97413aea)) (pin "9" (uuid 73e32536-95b1-46be-aafb-811b97413aea))
(pin "SH" (uuid 230f9adb-d1fe-4846-9878-30900fa82379)) (pin "SH" (uuid 230f9adb-d1fe-4846-9878-30900fa82379))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "IN1") (unit 1) (reference "IN1") (unit 1)
) )
@@ -4385,7 +4389,7 @@
(symbol (lib_id "Device:R") (at 130.81 48.26 270) (unit 1) (symbol (lib_id "Device:R") (at 130.81 48.26 270) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid d135b0c1-00a9-4a15-bf69-2c050be870d3) (uuid d135b0c1-00a9-4a15-bf69-2c050be870d3)
(property "Reference" "R25" (at 130.81 48.26 90) (property "Reference" "R61" (at 130.81 48.26 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "510" (at 135.89 46.99 90) (property "Value" "510" (at 135.89 46.99 90)
@@ -4400,9 +4404,9 @@
(pin "1" (uuid a2883c41-055a-4cfc-8e64-f2e8e7a6ab3a)) (pin "1" (uuid a2883c41-055a-4cfc-8e64-f2e8e7a6ab3a))
(pin "2" (uuid cc7cbf0c-b069-49a4-b4bd-29bedb17cbb9)) (pin "2" (uuid cc7cbf0c-b069-49a4-b4bd-29bedb17cbb9))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R25") (unit 1) (reference "R61") (unit 1)
) )
) )
) )
@@ -4411,7 +4415,7 @@
(symbol (lib_id "Device:C") (at 52.07 68.58 180) (unit 1) (symbol (lib_id "Device:C") (at 52.07 68.58 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid d97aea31-efd3-4805-a26e-93bfe540f39c) (uuid d97aea31-efd3-4805-a26e-93bfe540f39c)
(property "Reference" "C23" (at 53.34 72.39 90) (property "Reference" "C35" (at 53.34 72.39 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "10pF" (at 53.34 64.77 90) (property "Value" "10pF" (at 53.34 64.77 90)
@@ -4426,9 +4430,9 @@
(pin "1" (uuid a79adf07-4279-47bc-bc99-62376a50cad1)) (pin "1" (uuid a79adf07-4279-47bc-bc99-62376a50cad1))
(pin "2" (uuid 21ae26ea-5e5a-4709-aba6-8ecd8033be5f)) (pin "2" (uuid 21ae26ea-5e5a-4709-aba6-8ecd8033be5f))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C23") (unit 1) (reference "C35") (unit 1)
) )
) )
) )
@@ -4437,7 +4441,7 @@
(symbol (lib_id "Device:R") (at 58.42 96.52 180) (unit 1) (symbol (lib_id "Device:R") (at 58.42 96.52 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid dcb1369b-bcf1-4c3e-bd29-50410ac94349) (uuid dcb1369b-bcf1-4c3e-bd29-50410ac94349)
(property "Reference" "R24" (at 58.42 96.52 90) (property "Reference" "R49" (at 58.42 96.52 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "49.9" (at 57.15 91.44 90) (property "Value" "49.9" (at 57.15 91.44 90)
@@ -4452,9 +4456,9 @@
(pin "1" (uuid af23c4b1-0fe3-4b66-81a4-3e314e24626c)) (pin "1" (uuid af23c4b1-0fe3-4b66-81a4-3e314e24626c))
(pin "2" (uuid a99fcc80-5ada-41b3-acd9-0cc40ce350b9)) (pin "2" (uuid a99fcc80-5ada-41b3-acd9-0cc40ce350b9))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R24") (unit 1) (reference "R49") (unit 1)
) )
) )
) )
@@ -4463,7 +4467,7 @@
(symbol (lib_id "Device:C") (at 57.15 68.58 180) (unit 1) (symbol (lib_id "Device:C") (at 57.15 68.58 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid e0f26f8b-8985-49e6-8c97-f11bdae1e3a3) (uuid e0f26f8b-8985-49e6-8c97-f11bdae1e3a3)
(property "Reference" "C25" (at 58.42 72.39 90) (property "Reference" "C34" (at 58.42 72.39 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "10pF" (at 58.42 64.77 90) (property "Value" "10pF" (at 58.42 64.77 90)
@@ -4478,9 +4482,9 @@
(pin "1" (uuid e15952f4-c3e9-4dfd-925c-3bee598dab86)) (pin "1" (uuid e15952f4-c3e9-4dfd-925c-3bee598dab86))
(pin "2" (uuid 6e42821d-dcb5-4750-8ba7-3aaa59c0ca77)) (pin "2" (uuid 6e42821d-dcb5-4750-8ba7-3aaa59c0ca77))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C25") (unit 1) (reference "C34") (unit 1)
) )
) )
) )
@@ -4503,7 +4507,7 @@
) )
(pin "1" (uuid 81caf3f2-0098-48eb-a202-af0f48031eea)) (pin "1" (uuid 81caf3f2-0098-48eb-a202-af0f48031eea))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR076") (unit 1) (reference "#PWR076") (unit 1)
) )
@@ -4517,7 +4521,7 @@
(symbol (lib_id "Device:C") (at 62.23 68.58 180) (unit 1) (symbol (lib_id "Device:C") (at 62.23 68.58 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid e534b46c-80d1-4c34-8578-50b240333e0c) (uuid e534b46c-80d1-4c34-8578-50b240333e0c)
(property "Reference" "C27" (at 63.5 72.39 90) (property "Reference" "C33" (at 63.5 72.39 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "0.1uF" (at 63.5 64.77 90) (property "Value" "0.1uF" (at 63.5 64.77 90)
@@ -4532,9 +4536,9 @@
(pin "1" (uuid a494194d-e3e9-4e84-8f25-57021a681151)) (pin "1" (uuid a494194d-e3e9-4e84-8f25-57021a681151))
(pin "2" (uuid fda7cb74-15e1-4095-86ad-f40f74f32994)) (pin "2" (uuid fda7cb74-15e1-4095-86ad-f40f74f32994))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C27") (unit 1) (reference "C33") (unit 1)
) )
) )
) )
@@ -4543,7 +4547,7 @@
(symbol (lib_id "Device:R") (at 133.35 107.95 270) (unit 1) (symbol (lib_id "Device:R") (at 133.35 107.95 270) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid e59e1dd2-d274-40ca-a8b1-cb4b3dd2162e) (uuid e59e1dd2-d274-40ca-a8b1-cb4b3dd2162e)
(property "Reference" "R26" (at 133.35 107.95 90) (property "Reference" "R59" (at 133.35 107.95 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "510" (at 138.43 106.68 90) (property "Value" "510" (at 138.43 106.68 90)
@@ -4558,9 +4562,9 @@
(pin "1" (uuid e69298fd-5d70-4531-8e3f-b8874f7ca308)) (pin "1" (uuid e69298fd-5d70-4531-8e3f-b8874f7ca308))
(pin "2" (uuid 84f1b763-3dd2-4f94-a728-23eb2c7796a1)) (pin "2" (uuid 84f1b763-3dd2-4f94-a728-23eb2c7796a1))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R26") (unit 1) (reference "R59") (unit 1)
) )
) )
) )
@@ -4583,7 +4587,7 @@
) )
(pin "1" (uuid 74c16fc2-2f7f-4219-a10d-cf4d95b7a13d)) (pin "1" (uuid 74c16fc2-2f7f-4219-a10d-cf4d95b7a13d))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -4612,12 +4616,12 @@
(pin "1" (uuid 29258ff3-4fe0-4432-b3ff-89955c464507)) (pin "1" (uuid 29258ff3-4fe0-4432-b3ff-89955c464507))
(pin "2" (uuid fec31ab5-a849-42cc-a850-7ddcfa2a77ff)) (pin "2" (uuid fec31ab5-a849-42cc-a850-7ddcfa2a77ff))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "C33") (unit 1) (reference "C33") (unit 1)
) )
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C30") (unit 1) (reference "C41") (unit 1)
) )
) )
) )
@@ -4640,7 +4644,7 @@
) )
(pin "1" (uuid b2972075-1562-47db-afb1-79554c578966)) (pin "1" (uuid b2972075-1562-47db-afb1-79554c578966))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -4668,7 +4672,7 @@
) )
(pin "1" (uuid fcfa09ab-80ac-4dc6-ba9c-88dd0a5125d5)) (pin "1" (uuid fcfa09ab-80ac-4dc6-ba9c-88dd0a5125d5))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "#PWR?") (unit 1) (reference "#PWR?") (unit 1)
) )
@@ -4682,7 +4686,7 @@
(symbol (lib_id "Device:C") (at 41.91 68.58 180) (unit 1) (symbol (lib_id "Device:C") (at 41.91 68.58 180) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid f493fbdd-16cf-47a4-8571-5bdeffa77b8e) (uuid f493fbdd-16cf-47a4-8571-5bdeffa77b8e)
(property "Reference" "C19" (at 43.18 72.39 90) (property "Reference" "C37" (at 43.18 72.39 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "10pF" (at 43.18 64.77 90) (property "Value" "10pF" (at 43.18 64.77 90)
@@ -4697,9 +4701,9 @@
(pin "1" (uuid e54f216a-ea35-40fd-aa1a-c01d8d1f7d8f)) (pin "1" (uuid e54f216a-ea35-40fd-aa1a-c01d8d1f7d8f))
(pin "2" (uuid c6622106-637b-49de-9814-56476189b207)) (pin "2" (uuid c6622106-637b-49de-9814-56476189b207))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C19") (unit 1) (reference "C37") (unit 1)
) )
) )
) )
@@ -4723,12 +4727,12 @@
(pin "1" (uuid 090848c6-f3e5-45eb-98fb-58e65424c4c1)) (pin "1" (uuid 090848c6-f3e5-45eb-98fb-58e65424c4c1))
(pin "2" (uuid 29c609db-ee06-4a19-a4ca-ca0bef5009fe)) (pin "2" (uuid 29c609db-ee06-4a19-a4ca-ca0bef5009fe))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/d564400f-40ba-4aca-9c2a-14ec52a8353b"
(reference "C41") (unit 1) (reference "C41") (unit 1)
) )
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "C32") (unit 1) (reference "C42") (unit 1)
) )
) )
) )
@@ -4737,7 +4741,7 @@
(symbol (lib_id "Device:FerriteBead_Small") (at 137.16 154.94 90) (unit 1) (symbol (lib_id "Device:FerriteBead_Small") (at 137.16 154.94 90) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid f76a00b9-0511-4931-90f1-d259b14389f9) (uuid f76a00b9-0511-4931-90f1-d259b14389f9)
(property "Reference" "B6" (at 137.16 152.4 90) (property "Reference" "B7" (at 137.16 152.4 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "BLM18EG221SN1D" (at 137.16 157.48 90) (property "Value" "BLM18EG221SN1D" (at 137.16 157.48 90)
@@ -4752,9 +4756,9 @@
(pin "1" (uuid 8f7870e9-0ecb-4199-98c4-4167acd78afa)) (pin "1" (uuid 8f7870e9-0ecb-4199-98c4-4167acd78afa))
(pin "2" (uuid 40420d30-3763-4098-9a65-10e3fbe31313)) (pin "2" (uuid 40420d30-3763-4098-9a65-10e3fbe31313))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "B6") (unit 1) (reference "B7") (unit 1)
) )
) )
) )
@@ -4763,7 +4767,7 @@
(symbol (lib_id "Device:R") (at 138.43 119.38 0) (unit 1) (symbol (lib_id "Device:R") (at 138.43 119.38 0) (unit 1)
(in_bom yes) (on_board yes) (dnp no) (in_bom yes) (on_board yes) (dnp no)
(uuid f8848c60-f91f-414b-a5b0-c8e97aca000a) (uuid f8848c60-f91f-414b-a5b0-c8e97aca000a)
(property "Reference" "R28" (at 138.43 119.38 90) (property "Reference" "R60" (at 138.43 119.38 90)
(effects (font (size 1.27 1.27))) (effects (font (size 1.27 1.27)))
) )
(property "Value" "510" (at 137.16 114.3 90) (property "Value" "510" (at 137.16 114.3 90)
@@ -4778,9 +4782,9 @@
(pin "1" (uuid a6c9a9ea-cdb1-4a0c-aa67-80e3e5544517)) (pin "1" (uuid a6c9a9ea-cdb1-4a0c-aa67-80e3e5544517))
(pin "2" (uuid 313cc12d-9b4d-405e-ba92-c1e1b836e59b)) (pin "2" (uuid 313cc12d-9b4d-405e-ba92-c1e1b836e59b))
(instances (instances
(project "AX58100-stm32-ethercat" (project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622" (path "/5597aedc-b607-407f-bbfd-31b3b298ecb1/5bf93325-f5d9-4344-9bf3-f5fc91bc1622"
(reference "R28") (unit 1) (reference "R60") (unit 1)
) )
) )
) )

File diff suppressed because it is too large Load Diff

View File

@@ -1,6 +1,6 @@
{ {
"board": { "board": {
"active_layer": 0, "active_layer": 36,
"active_layer_preset": "", "active_layer_preset": "",
"auto_track_width": true, "auto_track_width": true,
"hidden_netclasses": [], "hidden_netclasses": [],
@@ -14,6 +14,7 @@
"vias": 1.0, "vias": 1.0,
"zones": 0.6 "zones": 0.6
}, },
"ratsnest_display_mode": 0,
"selection_filter": { "selection_filter": {
"dimensions": true, "dimensions": true,
"footprints": true, "footprints": true,
@@ -64,7 +65,7 @@
39, 39,
40 40
], ],
"visible_layers": "7ffffff_80000001", "visible_layers": "ffc0000_ffffffff",
"zone_display_mode": 0 "zone_display_mode": 0
}, },
"meta": { "meta": {

View File

@@ -23,13 +23,13 @@
}, },
"fab_line_width": 0.09999999999999999, "fab_line_width": 0.09999999999999999,
"fab_text_italic": false, "fab_text_italic": false,
"fab_text_size_h": 1.0, "fab_text_size_h": 0.6,
"fab_text_size_v": 1.0, "fab_text_size_v": 1.0,
"fab_text_thickness": 0.15, "fab_text_thickness": 0.15,
"fab_text_upright": false, "fab_text_upright": false,
"other_line_width": 0.15, "other_line_width": 0.15,
"other_text_italic": false, "other_text_italic": false,
"other_text_size_h": 1.0, "other_text_size_h": 0.6,
"other_text_size_v": 1.0, "other_text_size_v": 1.0,
"other_text_thickness": 0.15, "other_text_thickness": 0.15,
"other_text_upright": false, "other_text_upright": false,
@@ -40,12 +40,13 @@
}, },
"silk_line_width": 0.15, "silk_line_width": 0.15,
"silk_text_italic": false, "silk_text_italic": false,
"silk_text_size_h": 1.0, "silk_text_size_h": 0.6,
"silk_text_size_v": 1.0, "silk_text_size_v": 1.0,
"silk_text_thickness": 0.15, "silk_text_thickness": 0.15,
"silk_text_upright": false, "silk_text_upright": false,
"zones": { "zones": {
"min_clearance": 0.5 "45_degree_only": false,
"min_clearance": 0.0
} }
}, },
"diff_pair_dimensions": [ "diff_pair_dimensions": [
@@ -72,7 +73,7 @@
"duplicate_footprints": "warning", "duplicate_footprints": "warning",
"extra_footprint": "warning", "extra_footprint": "warning",
"footprint": "error", "footprint": "error",
"footprint_type_mismatch": "ignore", "footprint_type_mismatch": "warning",
"hole_clearance": "error", "hole_clearance": "error",
"hole_near_hole": "error", "hole_near_hole": "error",
"invalid_outline": "error", "invalid_outline": "error",
@@ -84,12 +85,12 @@
"lib_footprint_mismatch": "warning", "lib_footprint_mismatch": "warning",
"malformed_courtyard": "error", "malformed_courtyard": "error",
"microvia_drill_out_of_range": "error", "microvia_drill_out_of_range": "error",
"missing_courtyard": "ignore", "missing_courtyard": "error",
"missing_footprint": "warning", "missing_footprint": "warning",
"net_conflict": "warning", "net_conflict": "warning",
"npth_inside_courtyard": "ignore", "npth_inside_courtyard": "warning",
"padstack": "warning", "padstack": "warning",
"pth_inside_courtyard": "ignore", "pth_inside_courtyard": "warning",
"shorting_items": "error", "shorting_items": "error",
"silk_edge_clearance": "warning", "silk_edge_clearance": "warning",
"silk_over_copper": "warning", "silk_over_copper": "warning",
@@ -110,6 +111,8 @@
"zones_intersect": "error" "zones_intersect": "error"
}, },
"rules": { "rules": {
"allow_blind_buried_vias": false,
"allow_microvias": false,
"max_error": 0.005, "max_error": 0.005,
"min_clearance": 0.0, "min_clearance": 0.0,
"min_connection": 0.0, "min_connection": 0.0,
@@ -120,10 +123,10 @@
"min_microvia_drill": 0.09999999999999999, "min_microvia_drill": 0.09999999999999999,
"min_resolved_spokes": 2, "min_resolved_spokes": 2,
"min_silk_clearance": 0.0, "min_silk_clearance": 0.0,
"min_text_height": 0.7999999999999999, "min_text_height": 0.6,
"min_text_thickness": 0.08, "min_text_thickness": 0.08,
"min_through_hole_diameter": 0.3, "min_through_hole_diameter": 0.3,
"min_track_width": 0.0, "min_track_width": 0.19999999999999998,
"min_via_annular_width": 0.09999999999999999, "min_via_annular_width": 0.09999999999999999,
"min_via_diameter": 0.5, "min_via_diameter": 0.5,
"solder_mask_clearance": 0.0, "solder_mask_clearance": 0.0,
@@ -180,7 +183,8 @@
"drill": 0.0 "drill": 0.0
} }
], ],
"zones_allow_external_fillets": false "zones_allow_external_fillets": false,
"zones_use_no_outline": true
}, },
"layer_presets": [], "layer_presets": [],
"viewports": [] "viewports": []
@@ -390,7 +394,7 @@
"no_connect_dangling": "warning", "no_connect_dangling": "warning",
"pin_not_connected": "error", "pin_not_connected": "error",
"pin_not_driven": "error", "pin_not_driven": "error",
"pin_to_pin": "warning", "pin_to_pin": "error",
"power_pin_not_driven": "error", "power_pin_not_driven": "error",
"similar_labels": "warning", "similar_labels": "warning",
"simulation_model_issue": "ignore", "simulation_model_issue": "ignore",
@@ -499,7 +503,11 @@
], ],
[ [
"0a376a6c-0f15-42f8-81f6-3a55619be267", "0a376a6c-0f15-42f8-81f6-3a55619be267",
"Peripherals" "Input-Output"
],
[
"cd91a270-7393-4003-91a3-e42304da540b",
"Stepper+encoder"
] ]
], ],
"text_variables": {} "text_variables": {}

View File

@@ -0,0 +1,103 @@
(kicad_sch (version 20230121) (generator eeschema)
(uuid 5597aedc-b607-407f-bbfd-31b3b298ecb1)
(paper "A4")
(title_block
(title "MetalMusings EaserCAT 3000")
)
(lib_symbols
)
(sheet (at 57.15 156.21) (size 93.98 39.37) (fields_autoplaced)
(stroke (width 0.1524) (type solid))
(fill (color 0 0 0 0.0000))
(uuid 0a376a6c-0f15-42f8-81f6-3a55619be267)
(property "Sheetname" "Input-Output" (at 57.15 155.4984 0)
(effects (font (size 1.27 1.27)) (justify left bottom))
)
(property "Sheetfile" "peripherals.kicad_sch" (at 57.15 196.1646 0)
(effects (font (size 1.27 1.27)) (justify left top))
)
(instances
(project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1" (page "5"))
)
)
)
(sheet (at 170.18 31.75) (size 101.6 58.42) (fields_autoplaced)
(stroke (width 0.1524) (type solid))
(fill (color 0 0 0 0.0000))
(uuid 5bf93325-f5d9-4344-9bf3-f5fc91bc1622)
(property "Sheetname" "AX58100 phys etc" (at 170.18 31.0384 0)
(effects (font (size 1.27 1.27)) (justify left bottom))
)
(property "Sheetfile" "AX58100_phy_etc.kicad_sch" (at 170.18 90.7546 0)
(effects (font (size 1.27 1.27)) (justify left top))
)
(instances
(project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1" (page "3"))
)
)
)
(sheet (at 57.15 31.75) (size 93.98 60.96) (fields_autoplaced)
(stroke (width 0.1524) (type solid))
(fill (color 0 0 0 0.0000))
(uuid 9f485422-734f-43d3-94ea-443cbc453d2e)
(property "Sheetname" "AX58100" (at 57.15 31.0384 0)
(effects (font (size 1.27 1.27)) (justify left bottom))
)
(property "Sheetfile" "AX48100.kicad_sch" (at 57.15 93.2946 0)
(effects (font (size 1.27 1.27)) (justify left top))
)
(instances
(project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1" (page "2"))
)
)
)
(sheet (at 171.45 156.21) (size 105.41 39.37) (fields_autoplaced)
(stroke (width 0.1524) (type solid))
(fill (color 0 0 0 0.0000))
(uuid cd91a270-7393-4003-91a3-e42304da540b)
(property "Sheetname" "Stepper+encoder" (at 171.45 155.4984 0)
(effects (font (size 1.27 1.27)) (justify left bottom))
)
(property "Sheetfile" "Steppers.kicad_sch" (at 171.45 196.1646 0)
(effects (font (size 1.27 1.27)) (justify left top))
)
(instances
(project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1" (page "6"))
)
)
)
(sheet (at 57.15 106.68) (size 93.98 35.56) (fields_autoplaced)
(stroke (width 0.1524) (type solid))
(fill (color 0 0 0 0.0000))
(uuid d564400f-40ba-4aca-9c2a-14ec52a8353b)
(property "Sheetname" "STM32F4" (at 57.15 105.9684 0)
(effects (font (size 1.27 1.27)) (justify left bottom))
)
(property "Sheetfile" "STM32F4.kicad_sch" (at 57.15 142.8246 0)
(effects (font (size 1.27 1.27)) (justify left top))
)
(instances
(project "Ax58100-stm32-ethercat"
(path "/5597aedc-b607-407f-bbfd-31b3b298ecb1" (page "4"))
)
)
)
(sheet_instances
(path "/" (page "1"))
)
)

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@@ -64,7 +64,7 @@
39, 39,
40 40
], ],
"visible_layers": "002202a_00000001", "visible_layers": "002202b_80000005",
"zone_display_mode": 0 "zone_display_mode": 0
}, },
"meta": { "meta": {

Some files were not shown because too many files have changed in this diff Show More