mirror of
https://github.com/eddyem/stm32samples.git
synced 2025-12-06 18:55:13 +03:00
Add F0-F1-F3 LQFP48 testboard schematic
This commit is contained in:
parent
d2576412a5
commit
e432492281
1
F0-nolib/CANbus_stepper/TODO
Normal file
1
F0-nolib/CANbus_stepper/TODO
Normal file
@ -0,0 +1 @@
|
|||||||
|
Rx RS485 должен быть в режиме подтяжки к плюсу!
|
||||||
BIN
F0-nolib/usbcan/kicad/stm32-backups/stm32-2021-04-10_184318.zip
Normal file
BIN
F0-nolib/usbcan/kicad/stm32-backups/stm32-2021-04-10_184318.zip
Normal file
Binary file not shown.
BIN
F0-nolib/usbcan/kicad/stm32-backups/stm32-2021-04-11_222546.zip
Normal file
BIN
F0-nolib/usbcan/kicad/stm32-backups/stm32-2021-04-11_222546.zip
Normal file
Binary file not shown.
76
F0-nolib/usbcan/kicad/stm32.kicad_prl
Normal file
76
F0-nolib/usbcan/kicad/stm32.kicad_prl
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
{
|
||||||
|
"board": {
|
||||||
|
"active_layer": 0,
|
||||||
|
"active_layer_preset": "All Layers",
|
||||||
|
"auto_track_width": true,
|
||||||
|
"hidden_nets": [],
|
||||||
|
"high_contrast_mode": 0,
|
||||||
|
"net_color_mode": 1,
|
||||||
|
"opacity": {
|
||||||
|
"pads": 1.0,
|
||||||
|
"tracks": 1.0,
|
||||||
|
"vias": 1.0,
|
||||||
|
"zones": 0.6
|
||||||
|
},
|
||||||
|
"ratsnest_display_mode": 0,
|
||||||
|
"selection_filter": {
|
||||||
|
"dimensions": true,
|
||||||
|
"footprints": true,
|
||||||
|
"graphics": true,
|
||||||
|
"keepouts": true,
|
||||||
|
"lockedItems": true,
|
||||||
|
"otherItems": true,
|
||||||
|
"pads": true,
|
||||||
|
"text": true,
|
||||||
|
"tracks": true,
|
||||||
|
"vias": true,
|
||||||
|
"zones": true
|
||||||
|
},
|
||||||
|
"visible_items": [
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
2,
|
||||||
|
3,
|
||||||
|
4,
|
||||||
|
5,
|
||||||
|
6,
|
||||||
|
8,
|
||||||
|
9,
|
||||||
|
10,
|
||||||
|
11,
|
||||||
|
12,
|
||||||
|
13,
|
||||||
|
14,
|
||||||
|
15,
|
||||||
|
16,
|
||||||
|
17,
|
||||||
|
18,
|
||||||
|
19,
|
||||||
|
20,
|
||||||
|
21,
|
||||||
|
22,
|
||||||
|
23,
|
||||||
|
24,
|
||||||
|
25,
|
||||||
|
26,
|
||||||
|
27,
|
||||||
|
28,
|
||||||
|
29,
|
||||||
|
30,
|
||||||
|
32,
|
||||||
|
33,
|
||||||
|
34,
|
||||||
|
35,
|
||||||
|
36
|
||||||
|
],
|
||||||
|
"visible_layers": "fffffff_ffffffff",
|
||||||
|
"zone_display_mode": 0
|
||||||
|
},
|
||||||
|
"meta": {
|
||||||
|
"filename": "stm32.kicad_prl",
|
||||||
|
"version": 3
|
||||||
|
},
|
||||||
|
"project": {
|
||||||
|
"files": []
|
||||||
|
}
|
||||||
|
}
|
||||||
462
F0-nolib/usbcan/kicad/stm32.kicad_pro
Normal file
462
F0-nolib/usbcan/kicad/stm32.kicad_pro
Normal file
@ -0,0 +1,462 @@
|
|||||||
|
{
|
||||||
|
"board": {
|
||||||
|
"design_settings": {
|
||||||
|
"defaults": {
|
||||||
|
"board_outline_line_width": 0.15,
|
||||||
|
"copper_line_width": 0.19999999999999998,
|
||||||
|
"copper_text_italic": false,
|
||||||
|
"copper_text_size_h": 1.5,
|
||||||
|
"copper_text_size_v": 1.5,
|
||||||
|
"copper_text_thickness": 0.3,
|
||||||
|
"copper_text_upright": false,
|
||||||
|
"courtyard_line_width": 0.049999999999999996,
|
||||||
|
"dimension_precision": 4,
|
||||||
|
"dimension_units": 3,
|
||||||
|
"dimensions": {
|
||||||
|
"arrow_length": 1270000,
|
||||||
|
"extension_offset": 500000,
|
||||||
|
"keep_text_aligned": true,
|
||||||
|
"suppress_zeroes": false,
|
||||||
|
"text_position": 0,
|
||||||
|
"units_format": 1
|
||||||
|
},
|
||||||
|
"fab_line_width": 0.09999999999999999,
|
||||||
|
"fab_text_italic": false,
|
||||||
|
"fab_text_size_h": 1.0,
|
||||||
|
"fab_text_size_v": 1.0,
|
||||||
|
"fab_text_thickness": 0.15,
|
||||||
|
"fab_text_upright": false,
|
||||||
|
"other_line_width": 0.09999999999999999,
|
||||||
|
"other_text_italic": false,
|
||||||
|
"other_text_size_h": 1.0,
|
||||||
|
"other_text_size_v": 1.0,
|
||||||
|
"other_text_thickness": 0.15,
|
||||||
|
"other_text_upright": false,
|
||||||
|
"pads": {
|
||||||
|
"drill": 0.8,
|
||||||
|
"height": 1.5,
|
||||||
|
"width": 1.5
|
||||||
|
},
|
||||||
|
"silk_line_width": 0.15,
|
||||||
|
"silk_text_italic": false,
|
||||||
|
"silk_text_size_h": 1.0,
|
||||||
|
"silk_text_size_v": 1.0,
|
||||||
|
"silk_text_thickness": 0.15,
|
||||||
|
"silk_text_upright": false,
|
||||||
|
"zones": {
|
||||||
|
"45_degree_only": true,
|
||||||
|
"min_clearance": 0.5
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"diff_pair_dimensions": [],
|
||||||
|
"drc_exclusions": [],
|
||||||
|
"meta": {
|
||||||
|
"filename": "board_design_settings.json",
|
||||||
|
"version": 2
|
||||||
|
},
|
||||||
|
"rule_severities": {
|
||||||
|
"annular_width": "error",
|
||||||
|
"clearance": "error",
|
||||||
|
"copper_edge_clearance": "error",
|
||||||
|
"courtyards_overlap": "error",
|
||||||
|
"diff_pair_gap_out_of_range": "error",
|
||||||
|
"diff_pair_uncoupled_length_too_long": "error",
|
||||||
|
"drill_out_of_range": "error",
|
||||||
|
"duplicate_footprints": "warning",
|
||||||
|
"extra_footprint": "warning",
|
||||||
|
"hole_clearance": "error",
|
||||||
|
"hole_near_hole": "error",
|
||||||
|
"invalid_outline": "error",
|
||||||
|
"item_on_disabled_layer": "error",
|
||||||
|
"items_not_allowed": "error",
|
||||||
|
"length_out_of_range": "error",
|
||||||
|
"malformed_courtyard": "error",
|
||||||
|
"microvia_drill_out_of_range": "error",
|
||||||
|
"missing_courtyard": "ignore",
|
||||||
|
"missing_footprint": "warning",
|
||||||
|
"net_conflict": "warning",
|
||||||
|
"npth_inside_courtyard": "ignore",
|
||||||
|
"padstack": "error",
|
||||||
|
"pth_inside_courtyard": "ignore",
|
||||||
|
"shorting_items": "error",
|
||||||
|
"silk_over_copper": "error",
|
||||||
|
"silk_overlap": "error",
|
||||||
|
"skew_out_of_range": "error",
|
||||||
|
"too_many_vias": "error",
|
||||||
|
"track_dangling": "warning",
|
||||||
|
"track_width": "error",
|
||||||
|
"tracks_crossing": "error",
|
||||||
|
"unconnected_items": "error",
|
||||||
|
"unresolved_variable": "error",
|
||||||
|
"via_dangling": "warning",
|
||||||
|
"zone_has_empty_net": "error",
|
||||||
|
"zones_intersect": "error"
|
||||||
|
},
|
||||||
|
"rule_severitieslegacy_courtyards_overlap": true,
|
||||||
|
"rule_severitieslegacy_no_courtyard_defined": false,
|
||||||
|
"rules": {
|
||||||
|
"allow_blind_buried_vias": false,
|
||||||
|
"allow_microvias": false,
|
||||||
|
"max_error": 0.005,
|
||||||
|
"min_clearance": 0.0,
|
||||||
|
"min_copper_edge_clearance": 0.075,
|
||||||
|
"min_hole_clearance": 0.0,
|
||||||
|
"min_hole_to_hole": 0.25,
|
||||||
|
"min_microvia_diameter": 0.19999999999999998,
|
||||||
|
"min_microvia_drill": 0.09999999999999999,
|
||||||
|
"min_silk_clearance": 0.0,
|
||||||
|
"min_through_hole_diameter": 0.6,
|
||||||
|
"min_track_width": 0.19999999999999998,
|
||||||
|
"min_via_annular_width": 0.049999999999999996,
|
||||||
|
"min_via_diameter": 0.7999999999999999
|
||||||
|
},
|
||||||
|
"track_widths": [
|
||||||
|
0.0,
|
||||||
|
0.2,
|
||||||
|
0.3,
|
||||||
|
0.5,
|
||||||
|
1.0,
|
||||||
|
2.0
|
||||||
|
],
|
||||||
|
"via_dimensions": [
|
||||||
|
{
|
||||||
|
"diameter": 0.0,
|
||||||
|
"drill": 0.0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"diameter": 1.5,
|
||||||
|
"drill": 0.8
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"zones_allow_external_fillets": false,
|
||||||
|
"zones_use_no_outline": true
|
||||||
|
},
|
||||||
|
"layer_presets": []
|
||||||
|
},
|
||||||
|
"boards": [],
|
||||||
|
"cvpcb": {
|
||||||
|
"equivalence_files": []
|
||||||
|
},
|
||||||
|
"erc": {
|
||||||
|
"erc_exclusions": [],
|
||||||
|
"meta": {
|
||||||
|
"version": 0
|
||||||
|
},
|
||||||
|
"pin_map": [
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
2,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
1,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"rule_severities": {
|
||||||
|
"bus_definition_conflict": "error",
|
||||||
|
"bus_label_syntax": "error",
|
||||||
|
"bus_to_bus_conflict": "error",
|
||||||
|
"bus_to_net_conflict": "error",
|
||||||
|
"different_unit_footprint": "error",
|
||||||
|
"different_unit_net": "error",
|
||||||
|
"duplicate_reference": "error",
|
||||||
|
"duplicate_sheet_names": "error",
|
||||||
|
"extra_units": "error",
|
||||||
|
"global_label_dangling": "warning",
|
||||||
|
"hier_label_mismatch": "error",
|
||||||
|
"label_dangling": "error",
|
||||||
|
"lib_symbol_issues": "warning",
|
||||||
|
"multiple_net_names": "warning",
|
||||||
|
"net_not_bus_member": "warning",
|
||||||
|
"no_connect_connected": "warning",
|
||||||
|
"no_connect_dangling": "warning",
|
||||||
|
"pin_not_connected": "error",
|
||||||
|
"pin_not_driven": "error",
|
||||||
|
"pin_to_pin": "warning",
|
||||||
|
"power_pin_not_driven": "error",
|
||||||
|
"similar_labels": "warning",
|
||||||
|
"unannotated": "error",
|
||||||
|
"unit_value_mismatch": "error",
|
||||||
|
"unresolved_variable": "error",
|
||||||
|
"wire_dangling": "error"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"libraries": {
|
||||||
|
"pinned_footprint_libs": [],
|
||||||
|
"pinned_symbol_libs": []
|
||||||
|
},
|
||||||
|
"meta": {
|
||||||
|
"filename": "stm32.kicad_pro",
|
||||||
|
"version": 1
|
||||||
|
},
|
||||||
|
"net_settings": {
|
||||||
|
"classes": [
|
||||||
|
{
|
||||||
|
"bus_width": 12.0,
|
||||||
|
"clearance": 0.2,
|
||||||
|
"diff_pair_gap": 0.25,
|
||||||
|
"diff_pair_via_gap": 0.25,
|
||||||
|
"diff_pair_width": 0.2,
|
||||||
|
"line_style": 0,
|
||||||
|
"microvia_diameter": 0.3,
|
||||||
|
"microvia_drill": 0.1,
|
||||||
|
"name": "Default",
|
||||||
|
"pcb_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"schematic_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"track_width": 0.2,
|
||||||
|
"via_diameter": 1.0,
|
||||||
|
"via_drill": 0.6,
|
||||||
|
"wire_width": 6.0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"bus_width": 12.0,
|
||||||
|
"clearance": 0.3,
|
||||||
|
"diff_pair_gap": 0.25,
|
||||||
|
"diff_pair_via_gap": 0.25,
|
||||||
|
"diff_pair_width": 0.2,
|
||||||
|
"line_style": 0,
|
||||||
|
"microvia_diameter": 0.3,
|
||||||
|
"microvia_drill": 0.1,
|
||||||
|
"name": "0.5",
|
||||||
|
"nets": [],
|
||||||
|
"pcb_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"schematic_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"track_width": 0.5,
|
||||||
|
"via_diameter": 1.5,
|
||||||
|
"via_drill": 0.8,
|
||||||
|
"wire_width": 6.0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"bus_width": 12.0,
|
||||||
|
"clearance": 0.5,
|
||||||
|
"diff_pair_gap": 0.25,
|
||||||
|
"diff_pair_via_gap": 0.25,
|
||||||
|
"diff_pair_width": 0.2,
|
||||||
|
"line_style": 0,
|
||||||
|
"microvia_diameter": 0.3,
|
||||||
|
"microvia_drill": 0.1,
|
||||||
|
"name": "1",
|
||||||
|
"nets": [],
|
||||||
|
"pcb_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"schematic_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"track_width": 1.0,
|
||||||
|
"via_diameter": 1.5,
|
||||||
|
"via_drill": 0.8,
|
||||||
|
"wire_width": 6.0
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"meta": {
|
||||||
|
"version": 0
|
||||||
|
},
|
||||||
|
"net_colors": null
|
||||||
|
},
|
||||||
|
"pcbnew": {
|
||||||
|
"last_paths": {
|
||||||
|
"gencad": "",
|
||||||
|
"idf": "",
|
||||||
|
"netlist": "stm32.net",
|
||||||
|
"specctra_dsn": "",
|
||||||
|
"step": "",
|
||||||
|
"vrml": ""
|
||||||
|
},
|
||||||
|
"page_layout_descr_file": ""
|
||||||
|
},
|
||||||
|
"schematic": {
|
||||||
|
"drawing": {
|
||||||
|
"default_bus_thickness": 12.0,
|
||||||
|
"default_junction_size": 40.0,
|
||||||
|
"default_line_thickness": 6.0,
|
||||||
|
"default_text_size": 50.0,
|
||||||
|
"default_wire_thickness": 6.0,
|
||||||
|
"field_names": [],
|
||||||
|
"intersheets_ref_own_page": false,
|
||||||
|
"intersheets_ref_prefix": "",
|
||||||
|
"intersheets_ref_short": false,
|
||||||
|
"intersheets_ref_show": false,
|
||||||
|
"intersheets_ref_suffix": "",
|
||||||
|
"junction_size_choice": 3,
|
||||||
|
"pin_symbol_size": 25.0,
|
||||||
|
"text_offset_ratio": 0.3
|
||||||
|
},
|
||||||
|
"legacy_lib_dir": "",
|
||||||
|
"legacy_lib_list": [],
|
||||||
|
"meta": {
|
||||||
|
"version": 0
|
||||||
|
},
|
||||||
|
"net_format_name": "Pcbnew",
|
||||||
|
"ngspice": {
|
||||||
|
"meta": {
|
||||||
|
"version": 0
|
||||||
|
},
|
||||||
|
"model_mode": 0
|
||||||
|
},
|
||||||
|
"page_layout_descr_file": "",
|
||||||
|
"plot_directory": "",
|
||||||
|
"spice_adjust_passive_values": false,
|
||||||
|
"spice_external_command": "spice \"%I\"",
|
||||||
|
"subpart_first_id": 65,
|
||||||
|
"subpart_id_separator": 0
|
||||||
|
},
|
||||||
|
"sheets": [],
|
||||||
|
"text_variables": {}
|
||||||
|
}
|
||||||
147
F0-nolib/usbcan_relay/Makefile
Normal file
147
F0-nolib/usbcan_relay/Makefile
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
BINARY = usbcan
|
||||||
|
BOOTPORT ?= /dev/ttyUSB0
|
||||||
|
BOOTSPEED ?= 57600
|
||||||
|
# MCU FAMILY
|
||||||
|
FAMILY = F0
|
||||||
|
# MCU code
|
||||||
|
MCU = F042x6
|
||||||
|
# hardware definitions
|
||||||
|
#DEFS += -DEBUG
|
||||||
|
# change this linking script depending on particular MCU model,
|
||||||
|
# for example, if you have STM32F103VBT6, you should write:
|
||||||
|
LDSCRIPT = stm32f042k.ld
|
||||||
|
|
||||||
|
INDEPENDENT_HEADERS=
|
||||||
|
|
||||||
|
FP_FLAGS ?= -msoft-float
|
||||||
|
ASM_FLAGS = -mthumb -mcpu=cortex-m0 -march=armv6-m -mtune=cortex-m0
|
||||||
|
ARCH_FLAGS = $(ASM_FLAGS) $(FP_FLAGS)
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# Executables
|
||||||
|
OPREFIX ?= /opt/bin/arm-none-eabi
|
||||||
|
#PREFIX ?= /usr/x86_64-pc-linux-gnu/arm-none-eabi/gcc-bin/7.3.0/arm-none-eabi
|
||||||
|
PREFIX ?= $(OPREFIX)
|
||||||
|
|
||||||
|
RM := rm -f
|
||||||
|
RMDIR := rmdir
|
||||||
|
CC := $(PREFIX)-gcc
|
||||||
|
LD := $(PREFIX)-gcc
|
||||||
|
AR := $(PREFIX)-ar
|
||||||
|
AS := $(PREFIX)-as
|
||||||
|
OBJCOPY := $(OPREFIX)-objcopy
|
||||||
|
OBJDUMP := $(OPREFIX)-objdump
|
||||||
|
GDB := $(OPREFIX)-gdb
|
||||||
|
STFLASH := $(shell which st-flash)
|
||||||
|
STBOOT := $(shell which stm32flash)
|
||||||
|
DFUUTIL := $(shell which dfu-util)
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# Source files
|
||||||
|
OBJDIR = mk
|
||||||
|
LDSCRIPT ?= $(BINARY).ld
|
||||||
|
SRC := $(wildcard *.c)
|
||||||
|
OBJS := $(addprefix $(OBJDIR)/, $(SRC:%.c=%.o))
|
||||||
|
STARTUP = $(OBJDIR)/startup.o
|
||||||
|
OBJS += $(STARTUP)
|
||||||
|
DEPS := $(OBJS:.o=.d)
|
||||||
|
|
||||||
|
INC_DIR ?= ../inc
|
||||||
|
|
||||||
|
INCLUDE := -I$(INC_DIR)/Fx -I$(INC_DIR)/cm
|
||||||
|
LIB_DIR := $(INC_DIR)/ld
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# C flags
|
||||||
|
CFLAGS += -O2 -g -MD -D__thumb2__=1
|
||||||
|
CFLAGS += -Wall -Werror -Wextra -Wshadow -Wimplicit-function-declaration
|
||||||
|
CFLAGS += -Wredundant-decls $(INCLUDE)
|
||||||
|
# -Wmissing-prototypes -Wstrict-prototypes
|
||||||
|
CFLAGS += -fno-common -ffunction-sections -fdata-sections
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# Linker flags
|
||||||
|
LDFLAGS += --static -nostartfiles
|
||||||
|
#--specs=nano.specs
|
||||||
|
LDFLAGS += -L$(LIB_DIR)
|
||||||
|
LDFLAGS += -T$(LDSCRIPT)
|
||||||
|
LDFLAGS += -Wl,-Map=$(OBJDIR)/$(BINARY).map
|
||||||
|
LDFLAGS += -Wl,--gc-sections
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# Used libraries
|
||||||
|
LDLIBS += -Wl,--start-group -lc -lgcc -Wl,--end-group
|
||||||
|
LDLIBS += $(shell $(CC) $(CFLAGS) -print-libgcc-file-name)
|
||||||
|
|
||||||
|
DEFS += -DSTM32$(FAMILY) -DSTM32$(MCU)
|
||||||
|
|
||||||
|
#.SUFFIXES: .elf .bin .hex .srec .list .map .images
|
||||||
|
#.SECONDEXPANSION:
|
||||||
|
#.SECONDARY:
|
||||||
|
|
||||||
|
ELF := $(OBJDIR)/$(BINARY).elf
|
||||||
|
LIST := $(OBJDIR)/$(BINARY).list
|
||||||
|
BIN := $(BINARY).bin
|
||||||
|
HEX := $(BINARY).hex
|
||||||
|
|
||||||
|
all: bin list
|
||||||
|
|
||||||
|
elf: $(ELF)
|
||||||
|
bin: $(BIN)
|
||||||
|
hex: $(HEX)
|
||||||
|
list: $(LIST)
|
||||||
|
|
||||||
|
ifneq ($(MAKECMDGOALS),clean)
|
||||||
|
-include $(DEPS)
|
||||||
|
endif
|
||||||
|
|
||||||
|
$(OBJDIR):
|
||||||
|
mkdir $(OBJDIR)
|
||||||
|
|
||||||
|
$(STARTUP): $(INC_DIR)/startup/vector.c
|
||||||
|
$(CC) $(CFLAGS) $(DEFS) $(INCLUDE) $(ARCH_FLAGS) -o $@ -c $<
|
||||||
|
|
||||||
|
$(OBJDIR)/%.o: %.c
|
||||||
|
@echo " CC $<"
|
||||||
|
$(CC) $(CFLAGS) $(DEFS) $(INCLUDE) $(ARCH_FLAGS) -o $@ -c $<
|
||||||
|
|
||||||
|
#$(OBJDIR)/%.d: %.c $(OBJDIR)
|
||||||
|
# $(CC) -MM -MG $< | sed -e 's,^\([^:]*\)\.o[ ]*:,$(@D)/\1.o $(@D)/\1.d:,' >$@
|
||||||
|
|
||||||
|
$(BIN): $(ELF)
|
||||||
|
@echo " OBJCOPY $(BIN)"
|
||||||
|
$(OBJCOPY) -Obinary $(ELF) $(BIN)
|
||||||
|
|
||||||
|
$(HEX): $(ELF)
|
||||||
|
@echo " OBJCOPY $(HEX)"
|
||||||
|
$(OBJCOPY) -Oihex $(ELF) $(HEX)
|
||||||
|
|
||||||
|
$(LIST): $(ELF)
|
||||||
|
@echo " OBJDUMP $(LIST)"
|
||||||
|
$(OBJDUMP) -S $(ELF) > $(LIST)
|
||||||
|
|
||||||
|
$(ELF): $(OBJDIR) $(OBJS)
|
||||||
|
@echo " LD $(ELF)"
|
||||||
|
$(LD) $(LDFLAGS) $(ARCH_FLAGS) $(OBJS) $(LDLIBS) -o $(ELF)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
@echo " CLEAN"
|
||||||
|
$(RM) $(OBJS) $(DEPS) $(ELF) $(HEX) $(LIST) $(OBJDIR)/*.map *.d
|
||||||
|
@rmdir $(OBJDIR) 2>/dev/null || true
|
||||||
|
|
||||||
|
dfuboot: $(BIN)
|
||||||
|
@echo " LOAD $(BIN) THROUGH DFU"
|
||||||
|
$(DFUUTIL) -a0 -D $(BIN) -s 0x08000000
|
||||||
|
|
||||||
|
flash: $(BIN)
|
||||||
|
@echo " FLASH $(BIN)"
|
||||||
|
$(STFLASH) write $(BIN) 0x8000000
|
||||||
|
|
||||||
|
boot: $(BIN)
|
||||||
|
@echo " LOAD $(BIN) through bootloader"
|
||||||
|
$(STBOOT) -b$(BOOTSPEED) $(BOOTPORT) -w $(BIN)
|
||||||
|
|
||||||
|
gentags:
|
||||||
|
CFLAGS="$(CFLAGS) $(DEFS)" geany -g $(BINARY).c.tags *[hc] 2>/dev/null
|
||||||
|
|
||||||
|
.PHONY: clean flash boot gentags
|
||||||
10
F0-nolib/usbcan_relay/Readme.md
Normal file
10
F0-nolib/usbcan_relay/Readme.md
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
Simple code for CAN/USB development board
|
||||||
|
Simultaneous work of USB CDC (PL2303 emulation) and CAN
|
||||||
|
|
||||||
|
Pinout:
|
||||||
|
PB0 - LED0 - short blink when message received
|
||||||
|
PB1 - LED1 - shine when line OK
|
||||||
|
|
||||||
|
PB8, PB9 - CAN Rx/Tx
|
||||||
|
|
||||||
|
PA11. PA12 - USB DM/DP
|
||||||
355
F0-nolib/usbcan_relay/can.c
Normal file
355
F0-nolib/usbcan_relay/can.c
Normal file
@ -0,0 +1,355 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* can.c
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#include "can.h"
|
||||||
|
#include "hardware.h"
|
||||||
|
#include "proto.h"
|
||||||
|
|
||||||
|
#include <string.h> // memcpy
|
||||||
|
|
||||||
|
// circular buffer for received messages
|
||||||
|
static CAN_message messages[CAN_INMESSAGE_SIZE];
|
||||||
|
static uint8_t first_free_idx = 0; // index of first empty cell
|
||||||
|
static int8_t first_nonfree_idx = -1; // index of first data cell
|
||||||
|
static uint16_t oldspeed = 100; // speed of last init
|
||||||
|
|
||||||
|
#ifdef EBUG
|
||||||
|
static uint32_t last_err_code = 0;
|
||||||
|
#endif
|
||||||
|
static CAN_status can_status = CAN_STOP;
|
||||||
|
|
||||||
|
static void can_process_fifo(uint8_t fifo_num);
|
||||||
|
|
||||||
|
static CAN_message loc_flood_msg;
|
||||||
|
static CAN_message *flood_msg = NULL; // == loc_flood_msg - to flood
|
||||||
|
|
||||||
|
CAN_status CAN_get_status(){
|
||||||
|
CAN_status st = can_status;
|
||||||
|
// give overrun message only once
|
||||||
|
#ifdef EBUG
|
||||||
|
if(st == CAN_FIFO_OVERRUN) MSG("fifo 0 overrun\n");
|
||||||
|
#endif
|
||||||
|
if(st == CAN_FIFO_OVERRUN) can_status = CAN_READY;
|
||||||
|
return st;
|
||||||
|
}
|
||||||
|
|
||||||
|
// push next message into buffer; return 1 if buffer overfull
|
||||||
|
static int CAN_messagebuf_push(CAN_message *msg){
|
||||||
|
//MSG("Try to push\n");
|
||||||
|
if(first_free_idx == first_nonfree_idx) return 1; // no free space
|
||||||
|
if(first_nonfree_idx < 0) first_nonfree_idx = 0; // first message in empty buffer
|
||||||
|
memcpy(&messages[first_free_idx++], msg, sizeof(CAN_message));
|
||||||
|
// need to roll?
|
||||||
|
if(first_free_idx == CAN_INMESSAGE_SIZE) first_free_idx = 0;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// pop message from buffer
|
||||||
|
CAN_message *CAN_messagebuf_pop(){
|
||||||
|
if(first_nonfree_idx < 0) return NULL;
|
||||||
|
#ifdef EBUG
|
||||||
|
//MSG("read from idx "); printu(first_nonfree_idx); NL();
|
||||||
|
#endif
|
||||||
|
CAN_message *msg = &messages[first_nonfree_idx++];
|
||||||
|
if(first_nonfree_idx == CAN_INMESSAGE_SIZE) first_nonfree_idx = 0;
|
||||||
|
if(first_nonfree_idx == first_free_idx){ // buffer is empty - refresh it
|
||||||
|
first_nonfree_idx = -1;
|
||||||
|
first_free_idx = 0;
|
||||||
|
}
|
||||||
|
return msg;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CAN_reinit(uint16_t speed){
|
||||||
|
CAN->TSR |= CAN_TSR_ABRQ0 | CAN_TSR_ABRQ1 | CAN_TSR_ABRQ2;
|
||||||
|
RCC->APB1RSTR |= RCC_APB1RSTR_CANRST;
|
||||||
|
RCC->APB1RSTR &= ~RCC_APB1RSTR_CANRST;
|
||||||
|
CAN_setup(speed);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
Can filtering: FSCx=0 (CAN->FS1R) -> 16-bit identifiers
|
||||||
|
MASK: FBMx=0 (CAN->FM1R), two filters (n in FR1 and n+1 in FR2)
|
||||||
|
ID: CAN->sFilterRegister[x].FRn[0..15]
|
||||||
|
MASK: CAN->sFilterRegister[x].FRn[16..31]
|
||||||
|
FR bits: STID[10:0] RTR IDE EXID[17:15]
|
||||||
|
LIST: FBMx=1, four filters (n&n+1 in FR1, n+2&n+3 in FR2)
|
||||||
|
IDn: CAN->sFilterRegister[x].FRn[0..15]
|
||||||
|
IDn+1: CAN->sFilterRegister[x].FRn[16..31]
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
Can timing: main freq - APB (PLL=48MHz)
|
||||||
|
segment = 1sync + TBS1 + TBS2, sample point is between TBS1 and TBS2,
|
||||||
|
so if TBS1=4 and TBS2=3, sum=8, bit sampling freq is 48/8 = 6MHz
|
||||||
|
-> to get 100kbps we need prescaler=60
|
||||||
|
250kbps - 24
|
||||||
|
500kbps - 12
|
||||||
|
1MBps - 6
|
||||||
|
*/
|
||||||
|
|
||||||
|
// speed - in kbps
|
||||||
|
void CAN_setup(uint16_t speed){
|
||||||
|
LED_off(LED1);
|
||||||
|
if(speed == 0) speed = oldspeed;
|
||||||
|
else if(speed < 50) speed = 50;
|
||||||
|
else if(speed > 3000) speed = 3000;
|
||||||
|
oldspeed = speed;
|
||||||
|
uint32_t tmout = 16000000;
|
||||||
|
// Configure GPIO: PB8 - CAN_Rx, PB9 - CAN_Tx
|
||||||
|
/* (1) Select AF mode (10) on PB8 and PB9 */
|
||||||
|
/* (2) AF4 for CAN signals */
|
||||||
|
GPIOB->MODER = (GPIOB->MODER & ~(GPIO_MODER_MODER8 | GPIO_MODER_MODER9))
|
||||||
|
| (GPIO_MODER_MODER8_AF | GPIO_MODER_MODER9_AF); /* (1) */
|
||||||
|
GPIOB->AFR[1] = (GPIOB->AFR[1] &~ (GPIO_AFRH_AFRH0 | GPIO_AFRH_AFRH1))\
|
||||||
|
| (4 << (0 * 4)) | (4 << (1 * 4)); /* (2) */
|
||||||
|
/* Enable the peripheral clock CAN */
|
||||||
|
RCC->APB1ENR |= RCC_APB1ENR_CANEN;
|
||||||
|
/* Configure CAN */
|
||||||
|
/* (1) Enter CAN init mode to write the configuration */
|
||||||
|
/* (2) Wait the init mode entering */
|
||||||
|
/* (3) Exit sleep mode */
|
||||||
|
/* (4) Normal mode, set timing to 100kb/s: TBS1 = 4, TBS2 = 3, prescaler = 60 */
|
||||||
|
/* (5) Leave init mode */
|
||||||
|
/* (6) Wait the init mode leaving */
|
||||||
|
/* (7) Enter filter init mode, (16-bit + mask, bank 0 for FIFO 0) */
|
||||||
|
/* (8) Acivate filter 0 for two IDs */
|
||||||
|
/* (9) Identifier list mode */
|
||||||
|
/* (10) Set the Id list */
|
||||||
|
/* (12) Leave filter init */
|
||||||
|
/* (13) Set error interrupts enable */
|
||||||
|
CAN->MCR |= CAN_MCR_INRQ; /* (1) */
|
||||||
|
while((CAN->MSR & CAN_MSR_INAK)!=CAN_MSR_INAK) /* (2) */
|
||||||
|
{
|
||||||
|
if(--tmout == 0) break;
|
||||||
|
}
|
||||||
|
CAN->MCR &=~ CAN_MCR_SLEEP; /* (3) */
|
||||||
|
CAN->MCR |= CAN_MCR_ABOM; /* allow automatically bus-off */
|
||||||
|
|
||||||
|
CAN->BTR = 2 << 20 | 3 << 16 | (6000/speed - 1); /* (4) */
|
||||||
|
CAN->MCR &=~ CAN_MCR_INRQ; /* (5) */
|
||||||
|
tmout = 16000000;
|
||||||
|
while((CAN->MSR & CAN_MSR_INAK)==CAN_MSR_INAK) if(--tmout == 0) break; /* (6) */
|
||||||
|
// accept ALL
|
||||||
|
CAN->FMR = CAN_FMR_FINIT; /* (7) */
|
||||||
|
CAN->FA1R = CAN_FA1R_FACT0 | CAN_FA1R_FACT1; /* (8) */
|
||||||
|
// set to 1 all needed bits of CAN->FFA1R to switch given filters to FIFO1
|
||||||
|
CAN->sFilterRegister[0].FR1 = (1<<21)|(1<<5); // all odd IDs
|
||||||
|
CAN->FFA1R = 2; // filter 1 for FIFO1, filter 0 - for FIFO0
|
||||||
|
CAN->sFilterRegister[1].FR1 = (1<<21); // all even IDs
|
||||||
|
CAN->FMR &=~ CAN_FMR_FINIT; /* (12) */
|
||||||
|
CAN->IER |= CAN_IER_ERRIE | CAN_IER_FOVIE0 | CAN_IER_FOVIE1; /* (13) */
|
||||||
|
|
||||||
|
/* Configure IT */
|
||||||
|
/* (14) Set priority for CAN_IRQn */
|
||||||
|
/* (15) Enable CAN_IRQn */
|
||||||
|
NVIC_SetPriority(CEC_CAN_IRQn, 0); /* (14) */
|
||||||
|
NVIC_EnableIRQ(CEC_CAN_IRQn); /* (15) */
|
||||||
|
can_status = CAN_READY;
|
||||||
|
}
|
||||||
|
|
||||||
|
void can_proc(){
|
||||||
|
#ifdef EBUG
|
||||||
|
if(last_err_code){
|
||||||
|
MSG("Error, ESR=");
|
||||||
|
printu(last_err_code);
|
||||||
|
NL();
|
||||||
|
last_err_code = 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
// check for messages in FIFO0 & FIFO1
|
||||||
|
if(CAN->RF0R & CAN_RF0R_FMP0){
|
||||||
|
can_process_fifo(0);
|
||||||
|
}
|
||||||
|
if(CAN->RF1R & CAN_RF1R_FMP1){
|
||||||
|
can_process_fifo(1);
|
||||||
|
}
|
||||||
|
IWDG->KR = IWDG_REFRESH;
|
||||||
|
if(CAN->ESR & (CAN_ESR_BOFF | CAN_ESR_EPVF | CAN_ESR_EWGF)){ // much errors - restart CAN BUS
|
||||||
|
SEND("\nToo much errors, restarting CAN!\n");
|
||||||
|
SEND("Receive error counter: ");
|
||||||
|
printu((CAN->ESR & CAN_ESR_REC)>>24);
|
||||||
|
SEND("\nTransmit error counter: ");
|
||||||
|
printu((CAN->ESR & CAN_ESR_TEC)>>16);
|
||||||
|
SEND("\nLast error code: ");
|
||||||
|
int lec = (CAN->ESR & CAN_ESR_LEC) >> 4;
|
||||||
|
const char *errmsg = "No";
|
||||||
|
switch(lec){
|
||||||
|
case 1: errmsg = "Stuff"; break;
|
||||||
|
case 2: errmsg = "Form"; break;
|
||||||
|
case 3: errmsg = "Ack"; break;
|
||||||
|
case 4: errmsg = "Bit recessive"; break;
|
||||||
|
case 5: errmsg = "Bit dominant"; break;
|
||||||
|
case 6: errmsg = "CRC"; break;
|
||||||
|
case 7: errmsg = "(set by software)"; break;
|
||||||
|
}
|
||||||
|
SEND(errmsg); SEND(" error\n");
|
||||||
|
if(CAN->ESR & CAN_ESR_BOFF) SEND("Bus off");
|
||||||
|
if(CAN->ESR & CAN_ESR_EPVF) SEND("Passive error limit");
|
||||||
|
if(CAN->ESR & CAN_ESR_EWGF) SEND("Error counter limit");
|
||||||
|
NL();
|
||||||
|
// request abort for all mailboxes
|
||||||
|
CAN->TSR |= CAN_TSR_ABRQ0 | CAN_TSR_ABRQ1 | CAN_TSR_ABRQ2;
|
||||||
|
// reset CAN bus
|
||||||
|
RCC->APB1RSTR |= RCC_APB1RSTR_CANRST;
|
||||||
|
RCC->APB1RSTR &= ~RCC_APB1RSTR_CANRST;
|
||||||
|
CAN_setup(0);
|
||||||
|
}
|
||||||
|
static uint32_t lastFloodTime = 0;
|
||||||
|
if(flood_msg && (Tms - lastFloodTime) > (FLOOD_PERIOD_MS-1)){ // flood every ~5ms
|
||||||
|
lastFloodTime = Tms;
|
||||||
|
can_send(flood_msg->data, flood_msg->length, flood_msg->ID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CAN_status can_send(uint8_t *msg, uint8_t len, uint16_t target_id){
|
||||||
|
uint8_t mailbox = 0;
|
||||||
|
// check first free mailbox
|
||||||
|
if(CAN->TSR & (CAN_TSR_TME)){
|
||||||
|
mailbox = (CAN->TSR & CAN_TSR_CODE) >> 24;
|
||||||
|
}else{ // no free mailboxes
|
||||||
|
#ifdef EBUG
|
||||||
|
MSG("No free mailboxes"); NL();
|
||||||
|
#endif
|
||||||
|
return CAN_BUSY;
|
||||||
|
}
|
||||||
|
#ifdef EBUG
|
||||||
|
MSG("Send data. Len="); printu(len);
|
||||||
|
SEND(", tagid="); printuhex(target_id);
|
||||||
|
SEND(", data=");
|
||||||
|
for(int i = 0; i < len; ++i){
|
||||||
|
SEND(" "); printuhex(msg[i]);
|
||||||
|
}
|
||||||
|
NL();
|
||||||
|
#endif
|
||||||
|
CAN_TxMailBox_TypeDef *box = &CAN->sTxMailBox[mailbox];
|
||||||
|
uint32_t lb = 0, hb = 0;
|
||||||
|
switch(len){
|
||||||
|
case 8:
|
||||||
|
hb |= (uint32_t)msg[7] << 24;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 7:
|
||||||
|
hb |= (uint32_t)msg[6] << 16;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 6:
|
||||||
|
hb |= (uint32_t)msg[5] << 8;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 5:
|
||||||
|
hb |= (uint32_t)msg[4];
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 4:
|
||||||
|
lb |= (uint32_t)msg[3] << 24;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 3:
|
||||||
|
lb |= (uint32_t)msg[2] << 16;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 2:
|
||||||
|
lb |= (uint32_t)msg[1] << 8;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
default:
|
||||||
|
lb |= (uint32_t)msg[0];
|
||||||
|
}
|
||||||
|
box->TDLR = lb;
|
||||||
|
box->TDHR = hb;
|
||||||
|
box->TDTR = len;
|
||||||
|
box->TIR = (target_id & 0x7FF) << 21 | CAN_TI0R_TXRQ;
|
||||||
|
return CAN_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_flood(CAN_message *msg){
|
||||||
|
if(!msg) flood_msg = NULL;
|
||||||
|
else{
|
||||||
|
memcpy(&loc_flood_msg, msg, sizeof(CAN_message));
|
||||||
|
flood_msg = &loc_flood_msg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void can_process_fifo(uint8_t fifo_num){
|
||||||
|
if(fifo_num > 1) return;
|
||||||
|
LED_on(LED1); // Turn on LED1 - message received
|
||||||
|
CAN_FIFOMailBox_TypeDef *box = &CAN->sFIFOMailBox[fifo_num];
|
||||||
|
volatile uint32_t *RFxR = (fifo_num) ? &CAN->RF1R : &CAN->RF0R;
|
||||||
|
// read all
|
||||||
|
while(*RFxR & CAN_RF0R_FMP0){ // amount of messages pending
|
||||||
|
// CAN_RDTxR: (16-31) - timestamp, (8-15) - filter match index, (0-3) - data length
|
||||||
|
/* TODO: check filter match index if more than one ID can receive */
|
||||||
|
CAN_message msg;
|
||||||
|
uint8_t *dat = msg.data;
|
||||||
|
uint8_t len = box->RDTR & 0x0f;
|
||||||
|
msg.length = len;
|
||||||
|
msg.ID = box->RIR >> 21;
|
||||||
|
//msg.filterNo = (box->RDTR >> 8) & 0xff;
|
||||||
|
//msg.fifoNum = fifo_num;
|
||||||
|
if(len){ // message can be without data
|
||||||
|
uint32_t hb = box->RDHR, lb = box->RDLR;
|
||||||
|
switch(len){
|
||||||
|
case 8:
|
||||||
|
dat[7] = hb>>24;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 7:
|
||||||
|
dat[6] = (hb>>16) & 0xff;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 6:
|
||||||
|
dat[5] = (hb>>8) & 0xff;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 5:
|
||||||
|
dat[4] = hb & 0xff;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 4:
|
||||||
|
dat[3] = lb>>24;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 3:
|
||||||
|
dat[2] = (lb>>16) & 0xff;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 2:
|
||||||
|
dat[1] = (lb>>8) & 0xff;
|
||||||
|
__attribute__((fallthrough));
|
||||||
|
case 1:
|
||||||
|
dat[0] = lb & 0xff;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(CAN_messagebuf_push(&msg)) return; // error: buffer is full, try later
|
||||||
|
*RFxR |= CAN_RF0R_RFOM0; // release fifo for access to next message
|
||||||
|
}
|
||||||
|
//if(*RFxR & CAN_RF0R_FULL0) *RFxR &= ~CAN_RF0R_FULL0;
|
||||||
|
*RFxR = 0; // clear FOVR & FULL
|
||||||
|
}
|
||||||
|
|
||||||
|
void cec_can_isr(){
|
||||||
|
if(CAN->RF0R & CAN_RF0R_FOVR0){ // FIFO overrun
|
||||||
|
CAN->RF0R &= ~CAN_RF0R_FOVR0;
|
||||||
|
can_status = CAN_FIFO_OVERRUN;
|
||||||
|
}
|
||||||
|
if(CAN->RF1R & CAN_RF1R_FOVR1){
|
||||||
|
CAN->RF1R &= ~CAN_RF1R_FOVR1;
|
||||||
|
can_status = CAN_FIFO_OVERRUN;
|
||||||
|
}
|
||||||
|
if(CAN->MSR & CAN_MSR_ERRI){ // Error
|
||||||
|
CAN->MSR &= ~CAN_MSR_ERRI;
|
||||||
|
// request abort for problem mailbox
|
||||||
|
if(CAN->TSR & CAN_TSR_TERR0) CAN->TSR |= CAN_TSR_ABRQ0;
|
||||||
|
if(CAN->TSR & CAN_TSR_TERR1) CAN->TSR |= CAN_TSR_ABRQ1;
|
||||||
|
if(CAN->TSR & CAN_TSR_TERR2) CAN->TSR |= CAN_TSR_ABRQ2;
|
||||||
|
#ifdef EBUG
|
||||||
|
last_err_code = CAN->ESR;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
64
F0-nolib/usbcan_relay/can.h
Normal file
64
F0-nolib/usbcan_relay/can.h
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* can.h
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#pragma once
|
||||||
|
#ifndef __CAN_H__
|
||||||
|
#define __CAN_H__
|
||||||
|
|
||||||
|
#include "hardware.h"
|
||||||
|
|
||||||
|
// amount of filter banks in STM32F0
|
||||||
|
#define STM32F0FBANKNO 28
|
||||||
|
// flood period in milliseconds
|
||||||
|
#define FLOOD_PERIOD_MS 5
|
||||||
|
|
||||||
|
// incoming message buffer size
|
||||||
|
#define CAN_INMESSAGE_SIZE (8)
|
||||||
|
|
||||||
|
// CAN message
|
||||||
|
typedef struct{
|
||||||
|
uint8_t data[8]; // up to 8 bytes of data
|
||||||
|
uint8_t length; // data length
|
||||||
|
uint16_t ID; // ID of receiver
|
||||||
|
} CAN_message;
|
||||||
|
|
||||||
|
typedef enum{
|
||||||
|
CAN_STOP,
|
||||||
|
CAN_READY,
|
||||||
|
CAN_BUSY,
|
||||||
|
CAN_OK,
|
||||||
|
CAN_FIFO_OVERRUN
|
||||||
|
} CAN_status;
|
||||||
|
|
||||||
|
CAN_status CAN_get_status();
|
||||||
|
|
||||||
|
void CAN_reinit(uint16_t speed);
|
||||||
|
void CAN_setup(uint16_t speed);
|
||||||
|
|
||||||
|
CAN_status can_send(uint8_t *msg, uint8_t len, uint16_t target_id);
|
||||||
|
void can_proc();
|
||||||
|
|
||||||
|
CAN_message *CAN_messagebuf_pop();
|
||||||
|
|
||||||
|
void set_flood(CAN_message *msg);
|
||||||
|
|
||||||
|
#endif // __CAN_H__
|
||||||
97
F0-nolib/usbcan_relay/hardware.c
Normal file
97
F0-nolib/usbcan_relay/hardware.c
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* hardware.c - hardware-dependent macros & functions
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "hardware.h"
|
||||||
|
|
||||||
|
uint8_t ledsON = 0;
|
||||||
|
|
||||||
|
void gpio_setup(void){
|
||||||
|
RCC->AHBENR |= RCC_AHBENR_GPIOBEN;
|
||||||
|
// Set LEDS (PB0/1) as output
|
||||||
|
pin_set(LED0_port, LED0_pin); // clear LEDs
|
||||||
|
pin_set(LED1_port, LED1_pin);
|
||||||
|
GPIOB->MODER = (GPIOB->MODER & ~(GPIO_MODER_MODER0 | GPIO_MODER_MODER1)
|
||||||
|
) |
|
||||||
|
GPIO_MODER_MODER0_O | GPIO_MODER_MODER1_O;
|
||||||
|
}
|
||||||
|
|
||||||
|
void iwdg_setup(){
|
||||||
|
uint32_t tmout = 16000000;
|
||||||
|
/* Enable the peripheral clock RTC */
|
||||||
|
/* (1) Enable the LSI (40kHz) */
|
||||||
|
/* (2) Wait while it is not ready */
|
||||||
|
RCC->CSR |= RCC_CSR_LSION; /* (1) */
|
||||||
|
while((RCC->CSR & RCC_CSR_LSIRDY) != RCC_CSR_LSIRDY){if(--tmout == 0) break;} /* (2) */
|
||||||
|
/* Configure IWDG */
|
||||||
|
/* (1) Activate IWDG (not needed if done in option bytes) */
|
||||||
|
/* (2) Enable write access to IWDG registers */
|
||||||
|
/* (3) Set prescaler by 64 (1.6ms for each tick) */
|
||||||
|
/* (4) Set reload value to have a rollover each 2s */
|
||||||
|
/* (5) Check if flags are reset */
|
||||||
|
/* (6) Refresh counter */
|
||||||
|
IWDG->KR = IWDG_START; /* (1) */
|
||||||
|
IWDG->KR = IWDG_WRITE_ACCESS; /* (2) */
|
||||||
|
IWDG->PR = IWDG_PR_PR_1; /* (3) */
|
||||||
|
IWDG->RLR = 1250; /* (4) */
|
||||||
|
tmout = 16000000;
|
||||||
|
while(IWDG->SR){if(--tmout == 0) break;} /* (5) */
|
||||||
|
IWDG->KR = IWDG_REFRESH; /* (6) */
|
||||||
|
}
|
||||||
|
|
||||||
|
// pause in milliseconds for some purposes
|
||||||
|
void pause_ms(uint32_t pause){
|
||||||
|
uint32_t Tnxt = Tms + pause;
|
||||||
|
while(Tms < Tnxt) nop();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Jump2Boot(){
|
||||||
|
void (*SysMemBootJump)(void);
|
||||||
|
volatile uint32_t addr = 0x1FFFC800;
|
||||||
|
// reset systick
|
||||||
|
SysTick->CTRL = 0;
|
||||||
|
// reset clocks
|
||||||
|
|
||||||
|
RCC->APB1RSTR = RCC_APB1RSTR_CECRST | RCC_APB1RSTR_DACRST | RCC_APB1RSTR_PWRRST | RCC_APB1RSTR_CRSRST |
|
||||||
|
RCC_APB1RSTR_CANRST | RCC_APB1RSTR_USBRST | RCC_APB1RSTR_I2C2RST | RCC_APB1RSTR_I2C1RST |
|
||||||
|
RCC_APB1RSTR_USART4RST | RCC_APB1RSTR_USART3RST | RCC_APB1RSTR_USART2RST | RCC_APB1RSTR_SPI2RST |
|
||||||
|
RCC_APB1RSTR_WWDGRST | RCC_APB1RSTR_TIM14RST |
|
||||||
|
#ifdef STM32F072xB
|
||||||
|
RCC_APB1RSTR_TIM7RST | RCC_APB1RSTR_TIM6RST |
|
||||||
|
#endif
|
||||||
|
RCC_APB1RSTR_TIM3RST | RCC_APB1RSTR_TIM2RST;
|
||||||
|
RCC->APB2RSTR = RCC_APB2RSTR_DBGMCURST | RCC_APB2RSTR_TIM17RST | RCC_APB2RSTR_TIM16RST |
|
||||||
|
#ifdef STM32F072xB
|
||||||
|
RCC_APB2RSTR_TIM15RST |
|
||||||
|
#endif
|
||||||
|
RCC_APB2RSTR_USART1RST | RCC_APB2RSTR_SPI1RST | RCC_APB2RSTR_TIM1RST | RCC_APB2RSTR_ADCRST | RCC_APB2RSTR_SYSCFGRST;
|
||||||
|
RCC->AHBRSTR = 0;
|
||||||
|
RCC->APB1RSTR = 0;
|
||||||
|
RCC->APB2RSTR = 0;
|
||||||
|
// remap memory to 0 (only for STM32F0)
|
||||||
|
SYSCFG->CFGR1 = 0x01; __DSB(); __ISB();
|
||||||
|
SysMemBootJump = (void (*)(void)) (*((uint32_t *)(addr + 4)));
|
||||||
|
// set main stack pointer
|
||||||
|
__set_MSP(*((uint32_t *)addr));
|
||||||
|
// jump to bootloader
|
||||||
|
SysMemBootJump();
|
||||||
|
}
|
||||||
62
F0-nolib/usbcan_relay/hardware.h
Normal file
62
F0-nolib/usbcan_relay/hardware.h
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* hardware.h
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#pragma once
|
||||||
|
#ifndef __HARDWARE_H__
|
||||||
|
#define __HARDWARE_H__
|
||||||
|
|
||||||
|
#include <stm32f0.h>
|
||||||
|
|
||||||
|
#define CONCAT(a,b) a ## b
|
||||||
|
#define STR_HELPER(s) #s
|
||||||
|
#define STR(s) STR_HELPER(s)
|
||||||
|
|
||||||
|
#define FORMUSART(X) CONCAT(USART, X)
|
||||||
|
#define USARTX FORMUSART(USARTNUM)
|
||||||
|
|
||||||
|
// LEDS: 0 - PB0, 1 - PB1
|
||||||
|
// LED0
|
||||||
|
#define LED0_port GPIOB
|
||||||
|
#define LED0_pin (1<<0)
|
||||||
|
// LED1
|
||||||
|
#define LED1_port GPIOB
|
||||||
|
#define LED1_pin (1<<1)
|
||||||
|
|
||||||
|
#define LED_blink(x) do{if(ledsON) pin_toggle(x ## _port, x ## _pin);}while(0)
|
||||||
|
#define LED_on(x) do{if(ledsON) pin_clear(x ## _port, x ## _pin);}while(0)
|
||||||
|
#define LED_off(x) do{pin_set(x ## _port, x ## _pin);}while(0)
|
||||||
|
|
||||||
|
|
||||||
|
// CAN address - PB14(0), PB15(1), PA8(2)
|
||||||
|
#define READ_CAN_INV_ADDR() (((GPIOA->IDR & (1<<8))>>6)|((GPIOB->IDR & (3<<14))>>14))
|
||||||
|
|
||||||
|
|
||||||
|
extern volatile uint32_t Tms;
|
||||||
|
|
||||||
|
extern uint8_t ledsON;
|
||||||
|
|
||||||
|
void gpio_setup(void);
|
||||||
|
void iwdg_setup();
|
||||||
|
void pause_ms(uint32_t pause);
|
||||||
|
void Jump2Boot();
|
||||||
|
|
||||||
|
#endif // __HARDWARE_H__
|
||||||
BIN
F0-nolib/usbcan_relay/kicad/Board3D-back.jpg
Normal file
BIN
F0-nolib/usbcan_relay/kicad/Board3D-back.jpg
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 169 KiB |
BIN
F0-nolib/usbcan_relay/kicad/Board3D-front.jpg
Normal file
BIN
F0-nolib/usbcan_relay/kicad/Board3D-front.jpg
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 176 KiB |
7693
F0-nolib/usbcan_relay/kicad/_autosave-stm32.kicad_pcb
Normal file
7693
F0-nolib/usbcan_relay/kicad/_autosave-stm32.kicad_pcb
Normal file
File diff suppressed because it is too large
Load Diff
210
F0-nolib/usbcan_relay/kicad/elements.lib
Normal file
210
F0-nolib/usbcan_relay/kicad/elements.lib
Normal file
@ -0,0 +1,210 @@
|
|||||||
|
EESchema-LIBRARY Version 2.4
|
||||||
|
#encoding utf-8
|
||||||
|
#
|
||||||
|
# 74HC4051
|
||||||
|
#
|
||||||
|
DEF 74HC4051 U 0 10 Y Y 1 F N
|
||||||
|
F0 "U" 0 0 50 H V C CNN
|
||||||
|
F1 "74HC4051" 0 -150 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
$FPLIST
|
||||||
|
SO16
|
||||||
|
TSSOP16
|
||||||
|
SSOP16
|
||||||
|
DHVQFN16
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -400 450 400 -450 0 1 0 N
|
||||||
|
X Y4 1 700 -50 300 L 50 50 1 1 B
|
||||||
|
X S1 10 -700 250 300 R 50 50 1 1 I
|
||||||
|
X S0 11 -700 350 300 R 50 50 1 1 I
|
||||||
|
X Y3 12 700 50 300 L 50 50 1 1 B
|
||||||
|
X Y0 13 700 350 300 L 50 50 1 1 B
|
||||||
|
X Y1 14 700 250 300 L 50 50 1 1 B
|
||||||
|
X Y2 15 700 150 300 L 50 50 1 1 B
|
||||||
|
X VCC 16 -700 -100 300 R 50 50 1 1 W
|
||||||
|
X Y6 2 700 -250 300 L 50 50 1 1 B
|
||||||
|
X Z 3 0 -750 300 U 50 50 1 1 B
|
||||||
|
X Y7 4 700 -350 300 L 50 50 1 1 B
|
||||||
|
X Y5 5 700 -150 300 L 50 50 1 1 B
|
||||||
|
X ~E 6 -700 -350 300 R 50 50 1 1 I I
|
||||||
|
X VEE 7 -700 0 300 R 50 50 1 1 W
|
||||||
|
X GND 8 -700 -200 300 R 50 50 1 1 W
|
||||||
|
X S2 9 -700 150 300 R 50 50 1 1 I
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# B0x0xS-1W
|
||||||
|
#
|
||||||
|
DEF B0x0xS-1W Q? 0 40 Y Y 1 F N
|
||||||
|
F0 "Q?" 0 250 50 H V C CNN
|
||||||
|
F1 "B0x0xS-1W" 0 -250 50 H V C CNN
|
||||||
|
F2 "my_footprints:B0x0xS" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
ALIAS B0305S B0505S
|
||||||
|
$FPLIST
|
||||||
|
b0x0xs
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -200 200 200 -200 0 1 0 N
|
||||||
|
X GND 1 -400 -100 200 R 50 50 1 1 W
|
||||||
|
X Vin 2 -400 100 200 R 50 50 1 1 W
|
||||||
|
X 0V 3 400 -100 200 L 50 50 1 1 w
|
||||||
|
X +Vo 4 400 100 200 L 50 50 1 1 w
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# D_Schottky_x2_ACom_AKK
|
||||||
|
#
|
||||||
|
DEF D_Schottky_x2_ACom_AKK D 0 30 Y N 1 F N
|
||||||
|
F0 "D" 50 -100 50 H V C CNN
|
||||||
|
F1 "D_Schottky_x2_ACom_AKK" 0 100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 -140 0 150 0 N
|
||||||
|
P 2 0 1 0 0 0 0 -100 N
|
||||||
|
P 3 0 1 8 -150 50 -150 -50 -150 -50 N
|
||||||
|
P 3 0 1 8 150 50 150 -50 150 -50 N
|
||||||
|
P 4 0 1 8 -150 50 -170 50 -170 40 -170 40 N
|
||||||
|
P 4 0 1 8 150 -50 170 -50 170 -40 170 -40 N
|
||||||
|
P 4 0 1 8 150 50 130 50 130 40 130 40 N
|
||||||
|
P 5 0 1 8 -130 -40 -130 -50 -150 -50 -150 -50 -150 -50 N
|
||||||
|
P 6 0 1 8 -50 -50 -150 0 -50 50 -50 -50 -50 -50 -50 -50 N
|
||||||
|
P 6 0 1 8 50 50 150 0 50 -50 50 50 50 50 50 50 N
|
||||||
|
X A 1 0 -200 100 U 50 50 0 1 P
|
||||||
|
X K 2 -300 0 150 R 50 50 0 1 P
|
||||||
|
X K 3 300 0 150 L 50 50 0 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# LM1117-ADJ
|
||||||
|
#
|
||||||
|
DEF LM1117-ADJ U 0 30 Y Y 1 F N
|
||||||
|
F0 "U" 100 -250 50 H V C CNN
|
||||||
|
F1 "LM1117-ADJ" 0 250 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
ALIAS LM1117-1.8 LM1117-2.5 LM1117-3.3 LM1117-5.0
|
||||||
|
$FPLIST
|
||||||
|
SOT-223*
|
||||||
|
TO-263*
|
||||||
|
TO-252*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -200 -200 200 200 0 1 10 f
|
||||||
|
X GND/ADJ 1 0 -300 100 U 50 50 1 1 W
|
||||||
|
X VO 2 300 0 100 L 50 50 1 1 w
|
||||||
|
X VI 3 -300 0 100 R 50 50 1 1 W
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# PESD1CAN
|
||||||
|
#
|
||||||
|
DEF PESD1CAN D 0 30 Y N 1 F N
|
||||||
|
F0 "D" 0 -350 50 H V C CNN
|
||||||
|
F1 "PESD1CAN" 50 150 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
$FPLIST
|
||||||
|
SOT23
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -200 100 300 -300 0 1 0 N
|
||||||
|
P 2 0 1 0 -140 -200 150 -200 N
|
||||||
|
P 2 0 1 0 -140 0 150 0 N
|
||||||
|
P 3 0 1 8 -150 -150 -150 -250 -150 -250 N
|
||||||
|
P 3 0 1 8 -150 50 -150 -50 -150 -50 N
|
||||||
|
P 3 0 1 8 150 -150 150 -250 150 -250 N
|
||||||
|
P 3 0 1 8 150 50 150 -50 150 -50 N
|
||||||
|
P 4 0 1 8 -150 -150 -170 -150 -170 -160 -170 -160 N
|
||||||
|
P 4 0 1 8 -150 50 -170 50 -170 40 -170 40 N
|
||||||
|
P 4 0 1 8 150 -250 170 -250 170 -240 170 -240 N
|
||||||
|
P 4 0 1 8 150 -150 130 -150 130 -160 130 -160 N
|
||||||
|
P 4 0 1 8 150 -50 170 -50 170 -40 170 -40 N
|
||||||
|
P 4 0 1 0 150 0 250 0 250 -200 150 -200 N
|
||||||
|
P 4 0 1 8 150 50 130 50 130 40 130 40 N
|
||||||
|
P 5 0 1 8 -130 -240 -130 -250 -150 -250 -150 -250 -150 -250 N
|
||||||
|
P 5 0 1 8 -130 -40 -130 -50 -150 -50 -150 -50 -150 -50 N
|
||||||
|
P 6 0 1 8 -50 -250 -150 -200 -50 -150 -50 -250 -50 -250 -50 -250 N
|
||||||
|
P 6 0 1 8 -50 -50 -150 0 -50 50 -50 -50 -50 -50 -50 -50 N
|
||||||
|
P 6 0 1 8 50 -150 150 -200 50 -250 50 -150 50 -150 50 -150 N
|
||||||
|
P 6 0 1 8 50 50 150 0 50 -50 50 50 50 50 50 50 N
|
||||||
|
X K 1 -300 0 150 R 50 50 0 1 P
|
||||||
|
X K 2 -300 -200 150 R 50 50 0 1 P
|
||||||
|
X O 3 400 -100 150 L 50 50 0 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# TPS2051
|
||||||
|
#
|
||||||
|
DEF TPS2051 U 0 40 Y Y 1 F N
|
||||||
|
F0 "U" 0 -300 60 H V C CNN
|
||||||
|
F1 "TPS2051" 0 300 60 H V C CNN
|
||||||
|
F2 "" 0 0 60 H I C CNN
|
||||||
|
F3 "" 0 0 60 H I C CNN
|
||||||
|
DRAW
|
||||||
|
S -250 250 250 -250 0 1 0 N
|
||||||
|
X GND 1 -450 150 200 R 50 50 1 1 W
|
||||||
|
X IN 2 -450 50 200 R 50 50 1 1 W
|
||||||
|
X IN 3 -450 -50 200 R 50 50 1 1 P
|
||||||
|
X EN 4 -450 -150 200 R 50 50 1 1 I
|
||||||
|
X ~OC 5 450 -150 200 L 50 50 1 1 O
|
||||||
|
X OUT 6 450 -50 200 L 50 50 1 1 P
|
||||||
|
X OUT 7 450 50 200 L 50 50 1 1 P
|
||||||
|
X OUT 8 450 150 200 L 50 50 1 1 w
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# USB6B1
|
||||||
|
#
|
||||||
|
DEF USB6B1 D 0 30 Y N 1 F N
|
||||||
|
F0 "D" 0 -450 50 H V C CNN
|
||||||
|
F1 "USB6B1" 0 400 50 H V C CNN
|
||||||
|
F2 "" 200 -100 50 V V C CNN
|
||||||
|
F3 "" 200 -100 50 V V C CNN
|
||||||
|
$FPLIST
|
||||||
|
SO8
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
C -150 -300 7 0 1 0 N
|
||||||
|
C -150 100 7 0 1 0 N
|
||||||
|
C -150 300 7 0 1 0 N
|
||||||
|
C 0 -300 7 0 1 0 N
|
||||||
|
C 0 -100 7 0 1 0 N
|
||||||
|
C 0 300 7 0 1 0 N
|
||||||
|
C 200 -300 7 0 1 0 N
|
||||||
|
C 200 300 7 0 1 0 N
|
||||||
|
S -300 -100 300 -100 0 1 0 N
|
||||||
|
S -300 300 300 300 0 1 0 N
|
||||||
|
S -200 -150 -100 -150 0 1 0 N
|
||||||
|
S -200 250 -100 250 0 1 0 N
|
||||||
|
S -150 300 -150 -300 0 1 0 N
|
||||||
|
S -50 -150 50 -150 0 1 0 N
|
||||||
|
S -50 250 50 250 0 1 0 N
|
||||||
|
S 0 300 0 -300 0 1 0 N
|
||||||
|
S 200 300 200 -300 0 1 0 N
|
||||||
|
S 300 -300 -300 -300 0 1 0 N
|
||||||
|
S 300 100 -300 100 0 1 0 N
|
||||||
|
P 3 0 1 8 150 50 250 50 250 50 N
|
||||||
|
P 4 0 1 8 150 50 150 30 160 30 160 30 N
|
||||||
|
P 4 0 1 8 250 50 250 70 240 70 240 70 N
|
||||||
|
P 5 0 1 0 -250 350 300 350 300 -350 -250 -350 -250 350 N
|
||||||
|
P 6 0 1 8 -200 -250 -150 -150 -100 -250 -200 -250 -200 -250 -200 -250 N
|
||||||
|
P 6 0 1 8 -200 150 -150 250 -100 150 -200 150 -200 150 -200 150 N
|
||||||
|
P 6 0 1 8 -50 -250 0 -150 50 -250 -50 -250 -50 -250 -50 -250 N
|
||||||
|
P 6 0 1 8 -50 150 0 250 50 150 -50 150 -50 150 -50 150 N
|
||||||
|
P 6 0 1 8 150 -50 200 50 250 -50 150 -50 150 -50 150 -50 N
|
||||||
|
X VCC 1 -500 300 200 R 50 50 1 1 P
|
||||||
|
X I/O1 2 -500 100 200 R 50 50 1 1 P
|
||||||
|
X I/O2 3 -500 -100 200 R 50 50 1 1 P
|
||||||
|
X GND 4 -500 -300 200 R 50 50 1 1 P
|
||||||
|
X GND 5 500 -300 200 L 50 50 1 1 P
|
||||||
|
X I/O2 6 500 -100 200 L 50 50 1 1 P
|
||||||
|
X I/O1 7 500 100 200 L 50 50 1 1 P
|
||||||
|
X VCC 8 500 300 200 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
#End Library
|
||||||
21589
F0-nolib/usbcan_relay/kicad/fp-info-cache
Normal file
21589
F0-nolib/usbcan_relay/kicad/fp-info-cache
Normal file
File diff suppressed because it is too large
Load Diff
7
F0-nolib/usbcan_relay/kicad/fp-lib-table
Normal file
7
F0-nolib/usbcan_relay/kicad/fp-lib-table
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
(fp_lib_table
|
||||||
|
(lib (name my_footprints)(type KiCad)(uri "$(KIPRJMOD)/my_footprints.pretty")(options "")(descr ""))
|
||||||
|
(lib (name Connector_Dsub)(type KiCad)(uri ${KISYSMOD}/Connector_Dsub.pretty)(options "")(descr ""))
|
||||||
|
(lib (name Inductor_SMD)(type KiCad)(uri ${KISYSMOD}/Inductor_SMD.pretty)(options "")(descr ""))
|
||||||
|
(lib (name Inductor_THT)(type KiCad)(uri ${KISYSMOD}/Inductor_THT.pretty)(options "")(descr ""))
|
||||||
|
(lib (name Relay_THT)(type KiCad)(uri ${KISYSMOD}/Relay_THT.pretty)(options "")(descr ""))
|
||||||
|
)
|
||||||
@ -0,0 +1,18 @@
|
|||||||
|
(module B0x0xS (layer F.Cu) (tedit 5EC4EFC6)
|
||||||
|
(fp_text reference REF** (at 0.127 2.286) (layer F.SilkS)
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(fp_text value B0x0xS (at 0 -3.048) (layer F.Fab)
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(fp_line (start -5.8 0.9) (end 5.8 0.9) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_line (start -5.8 -5.1) (end 5.8 -5.1) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_line (start -5.8 -5.1) (end -5.8 0.9) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_line (start 5.8 -5.1) (end 5.8 0.9) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_line (start -0.381 -5.334) (end -0.381 1.27) (layer F.SilkS) (width 0.15))
|
||||||
|
(fp_line (start 0.381 1.27) (end 0.381 -5.334) (layer F.SilkS) (width 0.15))
|
||||||
|
(pad 1 thru_hole circle (at -3.81 0) (size 1.5 1.5) (drill 0.8) (layers *.Cu *.Mask))
|
||||||
|
(pad 2 thru_hole circle (at -1.27 0) (size 1.5 1.5) (drill 0.8) (layers *.Cu *.Mask))
|
||||||
|
(pad 3 thru_hole circle (at 1.27 0) (size 1.5 1.5) (drill 0.8) (layers *.Cu *.Mask))
|
||||||
|
(pad 4 thru_hole circle (at 3.81 0) (size 1.5 1.5) (drill 0.8) (layers *.Cu *.Mask))
|
||||||
|
)
|
||||||
@ -0,0 +1,9 @@
|
|||||||
|
(module Hole_3mm (layer F.Cu) (tedit 5913F6E4)
|
||||||
|
(fp_text reference REF** (at 0 3.81) (layer F.SilkS) hide
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(fp_text value Hole_3mm (at 0 -7.62) (layer F.Fab) hide
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(pad 1 thru_hole circle (at 0 0) (size 5 5) (drill 3) (layers *.Cu *.Mask))
|
||||||
|
)
|
||||||
801
F0-nolib/usbcan_relay/kicad/stm32-rescue.lib
Normal file
801
F0-nolib/usbcan_relay/kicad/stm32-rescue.lib
Normal file
@ -0,0 +1,801 @@
|
|||||||
|
EESchema-LIBRARY Version 2.4
|
||||||
|
#encoding utf-8
|
||||||
|
#
|
||||||
|
# +3.3V
|
||||||
|
#
|
||||||
|
DEF +3.3V #PWR 0 0 Y Y 1 F P
|
||||||
|
F0 "#PWR" 0 -150 50 H I C CNN
|
||||||
|
F1 "+3.3V" 0 140 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 -30 50 0 100 N
|
||||||
|
P 2 0 1 0 0 0 0 100 N
|
||||||
|
P 2 0 1 0 0 100 30 50 N
|
||||||
|
X +3V3 1 0 0 0 U 50 50 1 1 W N
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# +5V
|
||||||
|
#
|
||||||
|
DEF +5V #PWR 0 0 Y Y 1 F P
|
||||||
|
F0 "#PWR" 0 -150 50 H I C CNN
|
||||||
|
F1 "+5V" 0 140 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 -30 50 0 100 N
|
||||||
|
P 2 0 1 0 0 0 0 100 N
|
||||||
|
P 2 0 1 0 0 100 30 50 N
|
||||||
|
X +5V 1 0 0 0 U 50 50 1 1 W N
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# B0505S-elements
|
||||||
|
#
|
||||||
|
DEF B0505S-elements Q? 0 40 Y Y 1 F N
|
||||||
|
F0 "Q?" 0 250 50 H V C CNN
|
||||||
|
F1 "B0505S-elements" 0 -250 50 H V C CNN
|
||||||
|
F2 "my_footprints:B0x0xS" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
b0x0xs
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -200 200 200 -200 0 1 0 N
|
||||||
|
X GND 1 -400 -100 200 R 50 50 1 1 W
|
||||||
|
X Vin 2 -400 100 200 R 50 50 1 1 W
|
||||||
|
X 0V 3 400 -100 200 L 50 50 1 1 w
|
||||||
|
X +Vo 4 400 100 200 L 50 50 1 1 w
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# C
|
||||||
|
#
|
||||||
|
DEF C C 0 10 N Y 1 F N
|
||||||
|
F0 "C" 25 100 50 H V L CNN
|
||||||
|
F1 "C" 25 -100 50 H V L CNN
|
||||||
|
F2 "" 38 -150 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
C_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 20 -80 -30 80 -30 N
|
||||||
|
P 2 0 1 20 -80 30 80 30 N
|
||||||
|
X ~ 1 0 150 110 D 50 50 1 1 P
|
||||||
|
X ~ 2 0 -150 110 U 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# CONN_01X01
|
||||||
|
#
|
||||||
|
DEF CONN_01X01 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 100 50 H V C CNN
|
||||||
|
F1 "CONN_01X01" 100 0 50 V V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Pin_Header_Straight_1X*
|
||||||
|
Pin_Header_Angled_1X*
|
||||||
|
Socket_Strip_Straight_1X*
|
||||||
|
Socket_Strip_Angled_1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 5 10 -5 0 1 0 N
|
||||||
|
S -50 50 50 -50 0 1 0 N
|
||||||
|
X P1 1 -200 0 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# CONN_01X03
|
||||||
|
#
|
||||||
|
DEF CONN_01X03 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 200 50 H V C CNN
|
||||||
|
F1 "CONN_01X03" 100 0 50 V V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Pin_Header_Straight_1X*
|
||||||
|
Pin_Header_Angled_1X*
|
||||||
|
Socket_Strip_Straight_1X*
|
||||||
|
Socket_Strip_Angled_1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 -95 10 -105 0 1 0 N
|
||||||
|
S -50 5 10 -5 0 1 0 N
|
||||||
|
S -50 105 10 95 0 1 0 N
|
||||||
|
S -50 150 50 -150 0 1 0 N
|
||||||
|
X P1 1 -200 100 150 R 50 50 1 1 P
|
||||||
|
X P2 2 -200 0 150 R 50 50 1 1 P
|
||||||
|
X P3 3 -200 -100 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# CONN_02X03
|
||||||
|
#
|
||||||
|
DEF CONN_02X03 J 0 1 Y N 1 F N
|
||||||
|
F0 "J" 0 200 50 H V C CNN
|
||||||
|
F1 "CONN_02X03" 0 -200 50 H V C CNN
|
||||||
|
F2 "" 0 -1200 50 H I C CNN
|
||||||
|
F3 "" 0 -1200 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Pin_Header_Straight_2X*
|
||||||
|
Pin_Header_Angled_2X*
|
||||||
|
Socket_Strip_Straight_2X*
|
||||||
|
Socket_Strip_Angled_2X*
|
||||||
|
IDC_Header_Straight_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -100 -95 -50 -105 0 1 0 N
|
||||||
|
S -100 5 -50 -5 0 1 0 N
|
||||||
|
S -100 105 -50 95 0 1 0 N
|
||||||
|
S -100 150 100 -150 0 1 0 N
|
||||||
|
S 50 -95 100 -105 0 1 0 N
|
||||||
|
S 50 5 100 -5 0 1 0 N
|
||||||
|
S 50 105 100 95 0 1 0 N
|
||||||
|
X P1 1 -250 100 150 R 50 50 1 1 P
|
||||||
|
X P2 2 250 100 150 L 50 50 1 1 P
|
||||||
|
X P3 3 -250 0 150 R 50 50 1 1 P
|
||||||
|
X P4 4 250 0 150 L 50 50 1 1 P
|
||||||
|
X P5 5 -250 -100 150 R 50 50 1 1 P
|
||||||
|
X P6 6 250 -100 150 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# CP
|
||||||
|
#
|
||||||
|
DEF CP C 0 10 N Y 1 F N
|
||||||
|
F0 "C" 25 100 50 H V L CNN
|
||||||
|
F1 "CP" 25 -100 50 H V L CNN
|
||||||
|
F2 "" 38 -150 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
CP_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -90 20 -90 40 0 1 0 N
|
||||||
|
S -90 20 90 20 0 1 0 N
|
||||||
|
S 90 -20 -90 -40 0 1 0 F
|
||||||
|
S 90 40 -90 40 0 1 0 N
|
||||||
|
S 90 40 90 20 0 1 0 N
|
||||||
|
P 2 0 1 0 -70 90 -30 90 N
|
||||||
|
P 2 0 1 0 -50 110 -50 70 N
|
||||||
|
X ~ 1 0 150 110 D 50 50 1 1 P
|
||||||
|
X ~ 2 0 -150 110 U 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Conn_01x01
|
||||||
|
#
|
||||||
|
DEF Conn_01x01 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 100 50 H V C CNN
|
||||||
|
F1 "Conn_01x01" 0 -100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Connector*:*_??x*mm*
|
||||||
|
Connector*:*1x??x*mm*
|
||||||
|
Pin?Header?Straight?1X*
|
||||||
|
Pin?Header?Angled?1X*
|
||||||
|
Socket?Strip?Straight?1X*
|
||||||
|
Socket?Strip?Angled?1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 5 0 -5 1 1 6 N
|
||||||
|
S -50 50 50 -50 1 1 10 f
|
||||||
|
X Pin_1 1 -200 0 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Conn_01x02
|
||||||
|
#
|
||||||
|
DEF Conn_01x02 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 100 50 H V C CNN
|
||||||
|
F1 "Conn_01x02" 0 -200 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Connector*:*_??x*mm*
|
||||||
|
Connector*:*1x??x*mm*
|
||||||
|
Pin?Header?Straight?1X*
|
||||||
|
Pin?Header?Angled?1X*
|
||||||
|
Socket?Strip?Straight?1X*
|
||||||
|
Socket?Strip?Angled?1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 -95 0 -105 1 1 6 N
|
||||||
|
S -50 5 0 -5 1 1 6 N
|
||||||
|
S -50 50 50 -150 1 1 10 f
|
||||||
|
X Pin_1 1 -200 0 150 R 50 50 1 1 P
|
||||||
|
X Pin_2 2 -200 -100 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Conn_01x07
|
||||||
|
#
|
||||||
|
DEF Conn_01x07 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 400 50 H V C CNN
|
||||||
|
F1 "Conn_01x07" 0 -400 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Connector*:*_??x*mm*
|
||||||
|
Connector*:*1x??x*mm*
|
||||||
|
Pin?Header?Straight?1X*
|
||||||
|
Pin?Header?Angled?1X*
|
||||||
|
Socket?Strip?Straight?1X*
|
||||||
|
Socket?Strip?Angled?1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 -295 0 -305 1 1 6 N
|
||||||
|
S -50 -195 0 -205 1 1 6 N
|
||||||
|
S -50 -95 0 -105 1 1 6 N
|
||||||
|
S -50 5 0 -5 1 1 6 N
|
||||||
|
S -50 105 0 95 1 1 6 N
|
||||||
|
S -50 205 0 195 1 1 6 N
|
||||||
|
S -50 305 0 295 1 1 6 N
|
||||||
|
S -50 350 50 -350 1 1 10 f
|
||||||
|
X Pin_1 1 -200 300 150 R 50 50 1 1 P
|
||||||
|
X Pin_2 2 -200 200 150 R 50 50 1 1 P
|
||||||
|
X Pin_3 3 -200 100 150 R 50 50 1 1 P
|
||||||
|
X Pin_4 4 -200 0 150 R 50 50 1 1 P
|
||||||
|
X Pin_5 5 -200 -100 150 R 50 50 1 1 P
|
||||||
|
X Pin_6 6 -200 -200 150 R 50 50 1 1 P
|
||||||
|
X Pin_7 7 -200 -300 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# DB9_Female
|
||||||
|
#
|
||||||
|
DEF DB9_Female J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 550 50 H V C CNN
|
||||||
|
F1 "DB9_Female" 0 -575 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
DB*F*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
C -70 -400 30 0 1 0 N
|
||||||
|
C -70 -200 30 0 1 0 N
|
||||||
|
C -70 0 30 0 1 0 N
|
||||||
|
C -70 200 30 0 1 0 N
|
||||||
|
C -70 400 30 0 1 0 N
|
||||||
|
C 50 -300 30 0 1 0 N
|
||||||
|
C 50 -100 30 0 1 0 N
|
||||||
|
C 50 100 30 0 1 0 N
|
||||||
|
C 50 300 30 0 1 0 N
|
||||||
|
P 2 0 1 0 -150 -400 -100 -400 N
|
||||||
|
P 2 0 1 0 -150 -300 20 -300 N
|
||||||
|
P 2 0 1 0 -150 -200 -100 -200 N
|
||||||
|
P 2 0 1 0 -150 -100 20 -100 N
|
||||||
|
P 2 0 1 0 -150 0 -100 0 N
|
||||||
|
P 2 0 1 0 -150 100 20 100 N
|
||||||
|
P 2 0 1 0 -150 200 -100 200 N
|
||||||
|
P 2 0 1 0 -150 300 20 300 N
|
||||||
|
P 2 0 1 0 -150 400 -100 400 N
|
||||||
|
P 5 0 1 10 -150 525 -150 -525 150 -375 150 375 -150 525 f
|
||||||
|
X 1 1 -300 400 150 R 50 50 1 1 P
|
||||||
|
X 2 2 -300 200 150 R 50 50 1 1 P
|
||||||
|
X 3 3 -300 0 150 R 50 50 1 1 P
|
||||||
|
X 4 4 -300 -200 150 R 50 50 1 1 P
|
||||||
|
X 5 5 -300 -400 150 R 50 50 1 1 P
|
||||||
|
X 6 6 -300 300 150 R 50 50 1 1 P
|
||||||
|
X 7 7 -300 100 150 R 50 50 1 1 P
|
||||||
|
X 8 8 -300 -100 150 R 50 50 1 1 P
|
||||||
|
X 9 9 -300 -300 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# DB9_Male
|
||||||
|
#
|
||||||
|
DEF DB9_Male J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 550 50 H V C CNN
|
||||||
|
F1 "DB9_Male" 0 -575 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
DB*M*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
C -70 -400 30 0 1 0 F
|
||||||
|
C -70 -200 30 0 1 0 F
|
||||||
|
C -70 0 30 0 1 0 F
|
||||||
|
C -70 200 30 0 1 0 F
|
||||||
|
C -70 400 30 0 1 0 F
|
||||||
|
C 50 -300 30 0 1 0 F
|
||||||
|
C 50 -100 30 0 1 0 F
|
||||||
|
C 50 100 30 0 1 0 F
|
||||||
|
C 50 300 30 0 1 0 F
|
||||||
|
P 2 0 1 0 -150 -400 -100 -400 N
|
||||||
|
P 2 0 1 0 -150 -300 20 -300 N
|
||||||
|
P 2 0 1 0 -150 -200 -100 -200 N
|
||||||
|
P 2 0 1 0 -150 -100 20 -100 N
|
||||||
|
P 2 0 1 0 -150 0 -100 0 N
|
||||||
|
P 2 0 1 0 -150 100 20 100 N
|
||||||
|
P 2 0 1 0 -150 200 -100 200 N
|
||||||
|
P 2 0 1 0 -150 300 20 300 N
|
||||||
|
P 2 0 1 0 -150 400 -100 400 N
|
||||||
|
P 5 0 1 10 -150 -525 -150 525 150 375 150 -375 -150 -525 f
|
||||||
|
X 1 1 -300 -400 150 R 50 50 1 1 P
|
||||||
|
X 2 2 -300 -200 150 R 50 50 1 1 P
|
||||||
|
X 3 3 -300 0 150 R 50 50 1 1 P
|
||||||
|
X 4 4 -300 200 150 R 50 50 1 1 P
|
||||||
|
X 5 5 -300 400 150 R 50 50 1 1 P
|
||||||
|
X 6 6 -300 -300 150 R 50 50 1 1 P
|
||||||
|
X 7 7 -300 -100 150 R 50 50 1 1 P
|
||||||
|
X 8 8 -300 100 150 R 50 50 1 1 P
|
||||||
|
X 9 9 -300 300 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# D_Schottky
|
||||||
|
#
|
||||||
|
DEF D_Schottky D 0 40 N N 1 F N
|
||||||
|
F0 "D" 0 100 50 H V C CNN
|
||||||
|
F1 "D_Schottky" 0 -100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
TO-???*
|
||||||
|
*SingleDiode
|
||||||
|
*_Diode_*
|
||||||
|
*SingleDiode*
|
||||||
|
D_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 50 0 -50 0 N
|
||||||
|
P 4 0 1 8 50 50 50 -50 -50 0 50 50 N
|
||||||
|
P 6 0 1 8 -75 25 -75 50 -50 50 -50 -50 -25 -50 -25 -25 N
|
||||||
|
X K 1 -150 0 100 R 50 50 1 1 P
|
||||||
|
X A 2 150 0 100 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# D_Zener
|
||||||
|
#
|
||||||
|
DEF D_Zener D 0 40 N N 1 F N
|
||||||
|
F0 "D" 0 100 50 H V C CNN
|
||||||
|
F1 "D_Zener" 0 -100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
TO-???*
|
||||||
|
*SingleDiode
|
||||||
|
*_Diode_*
|
||||||
|
*SingleDiode*
|
||||||
|
D_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 50 0 -50 0 N
|
||||||
|
P 3 0 1 8 -50 -50 -50 50 -30 50 N
|
||||||
|
P 4 0 1 8 50 -50 50 50 -50 0 50 -50 N
|
||||||
|
X K 1 -150 0 100 R 50 50 1 1 P
|
||||||
|
X A 2 150 0 100 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# GND
|
||||||
|
#
|
||||||
|
DEF GND #PWR 0 0 Y Y 1 F P
|
||||||
|
F0 "#PWR" 0 -250 50 H I C CNN
|
||||||
|
F1 "GND" 0 -150 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
P 6 0 1 0 0 0 0 -50 50 -50 0 -100 -50 -50 0 -50 N
|
||||||
|
X GND 1 0 0 0 D 50 50 1 1 W N
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Jumper_NO_Small
|
||||||
|
#
|
||||||
|
DEF Jumper_NO_Small JP 0 30 N N 1 F N
|
||||||
|
F0 "JP" 0 80 50 H V C CNN
|
||||||
|
F1 "Jumper_NO_Small" 10 -60 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
C -40 0 20 0 1 0 N
|
||||||
|
C 40 0 20 0 1 0 N
|
||||||
|
X 1 1 -100 0 40 R 50 50 0 1 P
|
||||||
|
X 2 2 100 0 40 L 50 50 0 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# LED-RESCUE-stm32
|
||||||
|
#
|
||||||
|
DEF LED-RESCUE-stm32 D 0 40 Y N 1 F N
|
||||||
|
F0 "D" 0 100 50 H V C CNN
|
||||||
|
F1 "LED-RESCUE-stm32" 0 -100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
$FPLIST
|
||||||
|
LED*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 8 -50 -50 -50 50 N
|
||||||
|
P 2 0 1 0 -50 0 50 0 N
|
||||||
|
P 4 0 1 8 50 -50 50 50 -50 0 50 -50 N
|
||||||
|
P 5 0 1 0 -120 -30 -180 -90 -150 -90 -180 -90 -180 -60 N
|
||||||
|
P 5 0 1 0 -70 -30 -130 -90 -100 -90 -130 -90 -130 -60 N
|
||||||
|
X K 1 -150 0 100 R 50 50 1 1 P
|
||||||
|
X A 2 150 0 100 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# LM1117-3.3-RESCUE-stm32
|
||||||
|
#
|
||||||
|
DEF LM1117-3.3-RESCUE-stm32 U 0 30 Y Y 1 F N
|
||||||
|
F0 "U" 100 -250 50 H V C CNN
|
||||||
|
F1 "LM1117-3.3-RESCUE-stm32" 0 250 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
SOT-223*
|
||||||
|
TO-263*
|
||||||
|
TO-252*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -200 -200 200 200 0 1 10 f
|
||||||
|
X GND/ADJ 1 0 -300 100 U 50 50 1 1 W
|
||||||
|
X VO 2 300 50 100 L 50 50 1 1 P
|
||||||
|
X VI 3 -300 0 100 R 50 50 1 1 W
|
||||||
|
X VO 4 300 -50 100 L 50 50 1 1 w
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# MAX471-RESCUE-stm32
|
||||||
|
#
|
||||||
|
DEF MAX471-RESCUE-stm32 U 0 40 Y Y 1 F N
|
||||||
|
F0 "U" -300 350 50 H V L CNN
|
||||||
|
F1 "MAX471-RESCUE-stm32" -300 -350 50 H V L CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
S -300 300 300 -300 0 1 10 f
|
||||||
|
X SHDN 1 -400 -100 100 R 50 50 1 1 I
|
||||||
|
X RS+ 2 -400 200 100 R 50 50 1 1 W
|
||||||
|
X RS+ 3 -400 100 100 R 50 50 1 1 P
|
||||||
|
X GND 4 -400 -200 100 R 50 50 1 1 W
|
||||||
|
X SIGN 5 400 -100 100 L 50 50 1 1 C
|
||||||
|
X RS- 6 400 200 100 L 50 50 1 1 w
|
||||||
|
X RS- 7 400 100 100 L 50 50 1 1 P
|
||||||
|
X OUT 8 400 -200 100 L 50 50 1 1 O
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# MCP2551-I_SN
|
||||||
|
#
|
||||||
|
DEF MCP2551-I_SN U 0 40 Y Y 1 F N
|
||||||
|
F0 "U" -400 350 50 H V L CNN
|
||||||
|
F1 "MCP2551-I_SN" 100 350 50 H V L CNN
|
||||||
|
F2 "Housings_SOIC:SOIC-8_3.9x4.9mm_Pitch1.27mm" 0 -500 50 H I C CIN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
SOIC*Pitch1.27mm*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -400 300 400 -300 0 1 10 f
|
||||||
|
X TXD 1 -500 200 100 R 50 50 1 1 I
|
||||||
|
X VSS 2 0 -400 100 U 50 50 1 1 W
|
||||||
|
X VDD 3 0 400 100 D 50 50 1 1 W
|
||||||
|
X RXD 4 -500 100 100 R 50 50 1 1 O
|
||||||
|
X Vref 5 -500 -100 100 R 50 50 1 1 w
|
||||||
|
X CANL 6 500 -100 100 L 50 50 1 1 B
|
||||||
|
X CANH 7 500 100 100 L 50 50 1 1 B
|
||||||
|
X Rs 8 -500 -200 100 R 50 50 1 1 I
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# PESD1CAN-elements
|
||||||
|
#
|
||||||
|
DEF PESD1CAN-elements D 0 30 Y N 1 F N
|
||||||
|
F0 "D" 0 -350 50 H V C CNN
|
||||||
|
F1 "PESD1CAN-elements" 50 150 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
$FPLIST
|
||||||
|
SOT23
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -200 100 300 -300 0 1 0 N
|
||||||
|
P 2 0 1 0 -140 -200 150 -200 N
|
||||||
|
P 2 0 1 0 -140 0 150 0 N
|
||||||
|
P 3 0 1 8 -150 -150 -150 -250 -150 -250 N
|
||||||
|
P 3 0 1 8 -150 50 -150 -50 -150 -50 N
|
||||||
|
P 3 0 1 8 150 -150 150 -250 150 -250 N
|
||||||
|
P 3 0 1 8 150 50 150 -50 150 -50 N
|
||||||
|
P 4 0 1 8 -150 -150 -170 -150 -170 -160 -170 -160 N
|
||||||
|
P 4 0 1 8 -150 50 -170 50 -170 40 -170 40 N
|
||||||
|
P 4 0 1 8 150 -250 170 -250 170 -240 170 -240 N
|
||||||
|
P 4 0 1 8 150 -150 130 -150 130 -160 130 -160 N
|
||||||
|
P 4 0 1 8 150 -50 170 -50 170 -40 170 -40 N
|
||||||
|
P 4 0 1 0 150 0 250 0 250 -200 150 -200 N
|
||||||
|
P 4 0 1 8 150 50 130 50 130 40 130 40 N
|
||||||
|
P 5 0 1 8 -130 -240 -130 -250 -150 -250 -150 -250 -150 -250 N
|
||||||
|
P 5 0 1 8 -130 -40 -130 -50 -150 -50 -150 -50 -150 -50 N
|
||||||
|
P 6 0 1 8 -50 -250 -150 -200 -50 -150 -50 -250 -50 -250 -50 -250 N
|
||||||
|
P 6 0 1 8 -50 -50 -150 0 -50 50 -50 -50 -50 -50 -50 -50 N
|
||||||
|
P 6 0 1 8 50 -150 150 -200 50 -250 50 -150 50 -150 50 -150 N
|
||||||
|
P 6 0 1 8 50 50 150 0 50 -50 50 50 50 50 50 50 N
|
||||||
|
X K 1 -300 0 150 R 50 50 0 1 P
|
||||||
|
X K 2 -300 -200 150 R 50 50 0 1 P
|
||||||
|
X O 3 400 -100 150 L 50 50 0 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# PWR_FLAG
|
||||||
|
#
|
||||||
|
DEF PWR_FLAG #FLG 0 0 N N 1 F P
|
||||||
|
F0 "#FLG" 0 75 50 H I C CNN
|
||||||
|
F1 "PWR_FLAG" 0 150 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
P 6 0 1 0 0 0 0 50 -40 75 0 100 40 75 0 50 N
|
||||||
|
X pwr 1 0 0 0 U 50 50 0 0 w
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Q_NMOS_GSD
|
||||||
|
#
|
||||||
|
DEF Q_NMOS_GSD Q 0 0 Y N 1 F N
|
||||||
|
F0 "Q" 200 50 50 H V L CNN
|
||||||
|
F1 "Q_NMOS_GSD" 200 -50 50 H V L CNN
|
||||||
|
F2 "" 200 100 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
C 65 0 111 0 1 10 N
|
||||||
|
C 100 -70 11 0 1 0 F
|
||||||
|
C 100 70 11 0 1 0 F
|
||||||
|
P 2 0 1 0 2 0 10 0 N
|
||||||
|
P 2 0 1 0 30 -70 100 -70 N
|
||||||
|
P 2 0 1 10 30 -50 30 -90 N
|
||||||
|
P 2 0 1 0 30 0 100 0 N
|
||||||
|
P 2 0 1 10 30 20 30 -20 N
|
||||||
|
P 2 0 1 0 30 70 100 70 N
|
||||||
|
P 2 0 1 10 30 90 30 50 N
|
||||||
|
P 2 0 1 0 100 -70 100 -100 N
|
||||||
|
P 2 0 1 0 100 -70 100 0 N
|
||||||
|
P 2 0 1 0 100 100 100 70 N
|
||||||
|
P 3 0 1 10 10 75 10 -75 10 -75 N
|
||||||
|
P 4 0 1 0 40 0 80 15 80 -15 40 0 F
|
||||||
|
P 4 0 1 0 100 -70 130 -70 130 70 100 70 N
|
||||||
|
P 4 0 1 0 110 20 115 15 145 15 150 10 N
|
||||||
|
P 4 0 1 0 130 15 115 -10 145 -10 130 15 N
|
||||||
|
X G 1 -200 0 200 R 50 50 1 1 I
|
||||||
|
X S 2 100 -200 100 U 50 50 1 1 P
|
||||||
|
X D 3 100 200 100 D 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Q_PMOS_GSD
|
||||||
|
#
|
||||||
|
DEF Q_PMOS_GSD Q 0 0 Y N 1 F N
|
||||||
|
F0 "Q" 200 50 50 H V L CNN
|
||||||
|
F1 "Q_PMOS_GSD" 200 -50 50 H V L CNN
|
||||||
|
F2 "" 200 100 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
C 65 0 111 0 1 10 N
|
||||||
|
C 100 -70 11 0 1 0 F
|
||||||
|
C 100 70 11 0 1 0 F
|
||||||
|
P 2 0 1 0 2 0 10 0 N
|
||||||
|
P 2 0 1 0 30 -70 100 -70 N
|
||||||
|
P 2 0 1 10 30 -50 30 -90 N
|
||||||
|
P 2 0 1 0 30 0 100 0 N
|
||||||
|
P 2 0 1 10 30 20 30 -20 N
|
||||||
|
P 2 0 1 0 30 70 100 70 N
|
||||||
|
P 2 0 1 10 30 90 30 50 N
|
||||||
|
P 2 0 1 0 100 -70 100 -100 N
|
||||||
|
P 2 0 1 0 100 -70 100 0 N
|
||||||
|
P 2 0 1 0 100 100 100 70 N
|
||||||
|
P 3 0 1 10 10 75 10 -75 10 -75 N
|
||||||
|
P 4 0 1 0 90 0 50 -15 50 15 90 0 F
|
||||||
|
P 4 0 1 0 100 -70 130 -70 130 70 100 70 N
|
||||||
|
P 4 0 1 0 110 -20 115 -15 145 -15 150 -10 N
|
||||||
|
P 4 0 1 0 130 -15 115 10 145 10 130 -15 N
|
||||||
|
X G 1 -200 0 200 R 50 50 1 1 I
|
||||||
|
X S 2 100 -200 100 U 50 50 1 1 P
|
||||||
|
X D 3 100 200 100 D 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# R
|
||||||
|
#
|
||||||
|
DEF R R 0 0 N Y 1 F N
|
||||||
|
F0 "R" 80 0 50 V V C CNN
|
||||||
|
F1 "R" 0 0 50 V V C CNN
|
||||||
|
F2 "" -70 0 50 V I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
R_*
|
||||||
|
R_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -40 -100 40 100 0 1 10 N
|
||||||
|
X ~ 1 0 150 50 D 50 50 1 1 P
|
||||||
|
X ~ 2 0 -150 50 U 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# SP0502BAHT
|
||||||
|
#
|
||||||
|
DEF SP0502BAHT D 0 40 Y N 1 F N
|
||||||
|
F0 "D" 225 100 50 H V L CNN
|
||||||
|
F1 "SP0502BAHT" 225 25 50 H V L CNN
|
||||||
|
F2 "TO_SOT_Packages_SMD:SOT-23" 225 -50 50 H I L CNN
|
||||||
|
F3 "" 125 125 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
SOT?23*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -175 100 175 -100 0 1 10 f
|
||||||
|
P 2 0 1 0 -100 100 -100 50 N
|
||||||
|
P 2 0 1 0 0 -50 0 -100 N
|
||||||
|
P 2 0 1 0 100 100 100 50 N
|
||||||
|
P 4 0 1 0 -150 75 -125 50 -75 50 -50 25 N
|
||||||
|
P 4 0 1 0 -100 0 -100 -50 100 -50 100 0 N
|
||||||
|
P 4 0 1 0 -100 50 -75 0 -125 0 -100 50 F
|
||||||
|
P 4 0 1 0 50 75 75 50 125 50 150 25 N
|
||||||
|
P 4 0 1 0 100 50 75 0 125 0 100 50 F
|
||||||
|
X A 3 0 -200 100 U 50 50 0 0 I
|
||||||
|
X K 1 -100 200 100 D 50 50 1 1 I
|
||||||
|
X K 2 100 200 100 D 50 50 1 1 I
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# STM32F042C6Tx
|
||||||
|
#
|
||||||
|
DEF STM32F042C6Tx U 0 40 Y Y 1 L N
|
||||||
|
F0 "U" -3000 1725 50 H V L BNN
|
||||||
|
F1 "STM32F042C6Tx" 3000 1725 50 H V R BNN
|
||||||
|
F2 "LQFP48" 3000 1675 50 H V R TNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
DRAW
|
||||||
|
S -3000 -1700 3000 1700 0 1 10 f
|
||||||
|
X VBAT 1 -3100 1100 100 R 50 50 1 1 W
|
||||||
|
X ADC_IN0/RTC_TAMP2/SYS_WKUP1/TIM2_CH1/TIM2_ETR/TSC_G1_IO1/USART2_CTS/PA0 10 3100 100 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN1/TIM2_CH2/TSC_G1_IO2/USART2_DE/USART2_RTS/PA1 11 3100 0 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN2/SYS_WKUP4/TIM2_CH3/TSC_G1_IO3/USART2_TX/PA2 12 3100 -100 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN3/TIM2_CH4/TSC_G1_IO4/USART2_RX/PA3 13 3100 -200 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN4/I2S1_WS/SPI1_NSS/TIM14_CH1/TSC_G2_IO1/USART2_CK/USB_OE/PA4 14 3100 -300 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN5/CEC/I2S1_CK/SPI1_SCK/TIM2_CH1/TIM2_ETR/TSC_G2_IO2/PA5 15 3100 -400 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN6/I2S1_MCK/SPI1_MISO/TIM16_CH1/TIM1_BKIN/TIM3_CH1/TSC_G2_IO3/PA6 16 3100 -500 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN7/I2S1_SD/SPI1_MOSI/TIM14_CH1/TIM17_CH1/TIM1_CH1N/TIM3_CH2/TSC_G2_IO4/PA7 17 3100 -600 100 L 50 50 1 1 B
|
||||||
|
X PB0/ADC_IN8/TIM1_CH2N/TIM3_CH3/TSC_G3_IO2 18 -3100 100 100 R 50 50 1 1 B
|
||||||
|
X PB1/ADC_IN9/TIM14_CH1/TIM1_CH3N/TIM3_CH4/TSC_G3_IO3 19 -3100 0 100 R 50 50 1 1 B
|
||||||
|
X PC13/RTC_OUT_ALARM/RTC_OUT_CALIB/RTC_TAMP1/RTC_TS/SYS_WKUP2 2 -3100 500 100 R 50 50 1 1 B
|
||||||
|
X PB2/TSC_G3_IO4 20 -3100 -100 100 R 50 50 1 1 B
|
||||||
|
X PB10/CEC/I2C1_SCL/SPI2_SCK/TIM2_CH3/TSC_SYNC 21 -3100 -900 100 R 50 50 1 1 B
|
||||||
|
X PB11/I2C1_SDA/TIM2_CH4 22 -3100 -1000 100 R 50 50 1 1 B
|
||||||
|
X VSS 23 -200 -1800 100 U 50 50 1 1 W
|
||||||
|
X VDD 24 -200 1800 100 D 50 50 1 1 W
|
||||||
|
X PB12/SPI2_NSS/TIM1_BKIN 25 -3100 -1100 100 R 50 50 1 1 B
|
||||||
|
X PB13/I2C1_SCL/SPI2_SCK/TIM1_CH1N 26 -3100 -1200 100 R 50 50 1 1 B
|
||||||
|
X PB14/I2C1_SDA/SPI2_MISO/TIM1_CH2N 27 -3100 -1300 100 R 50 50 1 1 B
|
||||||
|
X PB15/RTC_REFIN/SPI2_MOSI/SYS_WKUP7/TIM1_CH3N 28 -3100 -1400 100 R 50 50 1 1 B
|
||||||
|
X CRS_SYNC/RCC_MCO/TIM1_CH1/USART1_CK/PA8 29 3100 -700 100 L 50 50 1 1 B
|
||||||
|
X PC14/RCC_OSC32_IN 3 -3100 400 100 R 50 50 1 1 B
|
||||||
|
X I2C1_SCL/TIM1_CH2/TSC_G4_IO1/USART1_TX/PA9 30 3100 -800 100 L 50 50 1 1 B
|
||||||
|
X I2C1_SDA/TIM17_BKIN/TIM1_CH3/TSC_G4_IO2/USART1_RX/PA10 31 3100 -900 100 L 50 50 1 1 B
|
||||||
|
X CAN_RX/I2C1_SCL/TIM1_CH4/TSC_G4_IO3/USART1_CTS/USB_DM/PA11 32 3100 -1000 100 L 50 50 1 1 B
|
||||||
|
X CAN_TX/I2C1_SDA/TIM1_ETR/TSC_G4_IO4/USART1_DE/USART1_RTS/USB_DP/PA12 33 3100 -1100 100 L 50 50 1 1 B
|
||||||
|
X IR_OUT/SYS_SWDIO/USB_OE/PA13 34 3100 -1200 100 L 50 50 1 1 B
|
||||||
|
X VSS 35 -100 -1800 100 U 50 50 1 1 W
|
||||||
|
X VDDIO2 36 100 1800 100 D 50 50 1 1 W
|
||||||
|
X SYS_SWCLK/USART2_TX/PA14 37 3100 -1300 100 L 50 50 1 1 B
|
||||||
|
X I2S1_WS/SPI1_NSS/TIM2_CH1/TIM2_ETR/USART2_RX/USB_OE/PA15 38 3100 -1400 100 L 50 50 1 1 B
|
||||||
|
X PB3/I2S1_CK/SPI1_SCK/TIM2_CH2/TSC_G5_IO1 39 -3100 -200 100 R 50 50 1 1 B
|
||||||
|
X PC15/RCC_OSC32_OUT 4 -3100 300 100 R 50 50 1 1 B
|
||||||
|
X PB4/I2S1_MCK/SPI1_MISO/TIM17_BKIN/TIM3_CH1/TSC_G5_IO2 40 -3100 -300 100 R 50 50 1 1 B
|
||||||
|
X PB5/I2C1_SMBA/I2S1_SD/SPI1_MOSI/SYS_WKUP6/TIM16_BKIN/TIM3_CH2 41 -3100 -400 100 R 50 50 1 1 B
|
||||||
|
X PB6/I2C1_SCL/TIM16_CH1N/TSC_G5_IO3/USART1_TX 42 -3100 -500 100 R 50 50 1 1 B
|
||||||
|
X PB7/I2C1_SDA/TIM17_CH1N/TSC_G5_IO4/USART1_RX 43 -3100 -600 100 R 50 50 1 1 B
|
||||||
|
X PF11 44 -3100 700 100 R 50 50 1 1 B
|
||||||
|
X PB8/CAN_RX/CEC/I2C1_SCL/TIM16_CH1/TSC_SYNC 45 -3100 -700 100 R 50 50 1 1 B
|
||||||
|
X PB9/CAN_TX/I2C1_SDA/IR_OUT/SPI2_NSS/TIM17_CH1 46 -3100 -800 100 R 50 50 1 1 B
|
||||||
|
X VSS 47 0 -1800 100 U 50 50 1 1 W
|
||||||
|
X VDD 48 -100 1800 100 D 50 50 1 1 W
|
||||||
|
X PF0/CRS_SYNC/I2C1_SDA/RCC_OSC_IN 5 -3100 900 100 R 50 50 1 1 I
|
||||||
|
X PF1/I2C1_SCL/RCC_OSC_OUT 6 -3100 800 100 R 50 50 1 1 I
|
||||||
|
X NRST 7 -3100 1300 100 R 50 50 1 1 I
|
||||||
|
X VSSA 8 100 -1800 100 U 50 50 1 1 W
|
||||||
|
X VDDA 9 0 1800 100 D 50 50 1 1 W
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# SW_Push
|
||||||
|
#
|
||||||
|
DEF SW_Push SW 0 40 N N 1 F N
|
||||||
|
F0 "SW" 50 100 50 H V L CNN
|
||||||
|
F1 "SW_Push" 0 -60 50 H V C CNN
|
||||||
|
F2 "" 0 200 50 H I C CNN
|
||||||
|
F3 "" 0 200 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
C -80 0 20 0 1 0 N
|
||||||
|
C 80 0 20 0 1 0 N
|
||||||
|
P 2 0 1 0 0 50 0 120 N
|
||||||
|
P 2 0 1 0 100 50 -100 50 N
|
||||||
|
X 1 1 -200 0 100 R 50 50 0 1 P
|
||||||
|
X 2 2 200 0 100 L 50 50 0 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# USB6B1-elements
|
||||||
|
#
|
||||||
|
DEF USB6B1-elements D 0 30 Y N 1 F N
|
||||||
|
F0 "D" 0 -450 50 H V C CNN
|
||||||
|
F1 "USB6B1-elements" 0 400 50 H V C CNN
|
||||||
|
F2 "" 200 -100 50 V V C CNN
|
||||||
|
F3 "" 200 -100 50 V V C CNN
|
||||||
|
$FPLIST
|
||||||
|
SO8
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
C -150 -300 7 0 1 0 N
|
||||||
|
C -150 100 7 0 1 0 N
|
||||||
|
C -150 300 7 0 1 0 N
|
||||||
|
C 0 -300 7 0 1 0 N
|
||||||
|
C 0 -100 7 0 1 0 N
|
||||||
|
C 0 300 7 0 1 0 N
|
||||||
|
C 200 -300 7 0 1 0 N
|
||||||
|
C 200 300 7 0 1 0 N
|
||||||
|
S -300 -100 300 -100 0 1 0 N
|
||||||
|
S -300 300 300 300 0 1 0 N
|
||||||
|
S -200 -150 -100 -150 0 1 0 N
|
||||||
|
S -200 250 -100 250 0 1 0 N
|
||||||
|
S -150 300 -150 -300 0 1 0 N
|
||||||
|
S -50 -150 50 -150 0 1 0 N
|
||||||
|
S -50 250 50 250 0 1 0 N
|
||||||
|
S 0 300 0 -300 0 1 0 N
|
||||||
|
S 200 300 200 -300 0 1 0 N
|
||||||
|
S 300 -300 -300 -300 0 1 0 N
|
||||||
|
S 300 100 -300 100 0 1 0 N
|
||||||
|
P 3 0 1 8 150 50 250 50 250 50 N
|
||||||
|
P 4 0 1 8 150 50 150 30 160 30 160 30 N
|
||||||
|
P 4 0 1 8 250 50 250 70 240 70 240 70 N
|
||||||
|
P 5 0 1 0 -250 350 300 350 300 -350 -250 -350 -250 350 N
|
||||||
|
P 6 0 1 8 -200 -250 -150 -150 -100 -250 -200 -250 -200 -250 -200 -250 N
|
||||||
|
P 6 0 1 8 -200 150 -150 250 -100 150 -200 150 -200 150 -200 150 N
|
||||||
|
P 6 0 1 8 -50 -250 0 -150 50 -250 -50 -250 -50 -250 -50 -250 N
|
||||||
|
P 6 0 1 8 -50 150 0 250 50 150 -50 150 -50 150 -50 150 N
|
||||||
|
P 6 0 1 8 150 -50 200 50 250 -50 150 -50 150 -50 150 -50 N
|
||||||
|
X VCC 1 -500 300 200 R 50 50 1 1 P
|
||||||
|
X I/O1 2 -500 100 200 R 50 50 1 1 P
|
||||||
|
X I/O2 3 -500 -100 200 R 50 50 1 1 P
|
||||||
|
X GND 4 -500 -300 200 R 50 50 1 1 P
|
||||||
|
X GND 5 500 -300 200 L 50 50 1 1 P
|
||||||
|
X I/O2 6 500 -100 200 L 50 50 1 1 P
|
||||||
|
X I/O1 7 500 100 200 L 50 50 1 1 P
|
||||||
|
X VCC 8 500 300 200 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# USB_A-RESCUE-stm32
|
||||||
|
#
|
||||||
|
DEF USB_A-RESCUE-stm32 P 0 40 Y Y 1 F N
|
||||||
|
F0 "P" 200 -200 50 H V C CNN
|
||||||
|
F1 "USB_A-RESCUE-stm32" -50 200 50 H V C CNN
|
||||||
|
F2 "" -50 -100 50 V V C CNN
|
||||||
|
F3 "" -50 -100 50 V V C CNN
|
||||||
|
$FPLIST
|
||||||
|
USB*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -250 -150 150 150 0 1 0 N
|
||||||
|
S -205 -150 -195 -120 0 1 0 N
|
||||||
|
S -105 -150 -95 -120 0 1 0 N
|
||||||
|
S -5 -150 5 -120 0 1 0 N
|
||||||
|
S 95 -150 105 -120 0 1 0 N
|
||||||
|
X VBUS 1 -200 -300 150 U 50 50 1 1 W
|
||||||
|
X D- 2 -100 -300 150 U 50 50 1 1 P
|
||||||
|
X D+ 3 0 -300 150 U 50 50 1 1 P
|
||||||
|
X GND 4 100 -300 150 U 50 50 1 1 W
|
||||||
|
X shield 5 300 100 150 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
#End Library
|
||||||
151
F0-nolib/usbcan_relay/kicad/stm32.csv
Normal file
151
F0-nolib/usbcan_relay/kicad/stm32.csv
Normal file
@ -0,0 +1,151 @@
|
|||||||
|
"Source:","/home/eddy/Docs/SAO/ELECTRONICS/STM32/F0-srcs/CANUSB+relays/kicad/stm32.sch"
|
||||||
|
"Date:","óÒ 16 ÉÀÎ 2021 11:40:04"
|
||||||
|
"Tool:","Eeschema 5.1.7"
|
||||||
|
"Generator:","/usr/local/share/kicad/plugins/bom_csv_grouped_by_value.py"
|
||||||
|
"Component Count:","93"
|
||||||
|
|
||||||
|
"Individual Components:"
|
||||||
|
|
||||||
|
"Item","Qty","Reference(s)","Value","LibPart","Footprint","Datasheet","Manufacturer"
|
||||||
|
"","","C1","1","stm32-rescue:C","Capacitor_SMD:C_0805_2012Metric_Pad1.15x1.40mm_HandSolder","",""
|
||||||
|
"","","C2","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"","","C3","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"","","C4","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"","","C5","1","stm32-rescue:C","Capacitor_SMD:C_0805_2012Metric_Pad1.15x1.40mm_HandSolder","",""
|
||||||
|
"","","C6","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"","","C7","0.1","Device:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","C8","0.1","Device:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","C9","0.1","Device:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","C10","47u 16V","Device:CP","Capacitor_Tantalum_SMD:CP_EIA-6032-28_Kemet-C_Pad2.25x2.35mm_HandSolder","~",""
|
||||||
|
"","","C11","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"","","C12","47u 10V","stm32-rescue:CP","Capacitor_Tantalum_SMD:CP_EIA-1608-08_AVX-J_Pad1.25x1.05mm_HandSolder","",""
|
||||||
|
"","","C13","47u 10V","Device:CP","Capacitor_Tantalum_SMD:CP_EIA-1608-08_AVX-J_Pad1.25x1.05mm_HandSolder","~",""
|
||||||
|
"","","C14","0.1","Device:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","C15","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"","","D1","PESD1CAN","elements:PESD1CAN","TO_SOT_Packages_SMD:SOT-23","",""
|
||||||
|
"","","D2","SS14","Device:D_Schottky","Diode_SMD:D_SMA-SMB_Universal_Handsoldering","~",""
|
||||||
|
"","","D3","USB6B1","elements:USB6B1","Package_SO:SOIC-8_3.9x4.9mm_P1.27mm","",""
|
||||||
|
"","","D4","SS14","Device:D_Schottky","Diode_SMD:D_SMA-SMB_Universal_Handsoldering","~",""
|
||||||
|
"","","D5","MM3Z7V5","Device:D_Zener","Diode_SMD:D_0805_2012Metric_Pad1.15x1.40mm_HandSolder","~",""
|
||||||
|
"","","D6","CESD3v3","Device:D","Diode_SMD:D_SOD-523","~",""
|
||||||
|
"","","D7","CESD3v3","Device:D","Diode_SMD:D_SOD-523","~",""
|
||||||
|
"","","D8","SS14","Device:D_Schottky","Diode_SMD:D_SMA-SMB_Universal_Handsoldering","~",""
|
||||||
|
"","","D9","SS14","Device:D_Schottky","Diode_SMD:D_SMA-SMB_Universal_Handsoldering","~",""
|
||||||
|
"","","D10","SS14","Device:D_Schottky","Diode_SMD:D_SMA-SMB_Universal_Handsoldering","~",""
|
||||||
|
"","","D11","1N5822","Device:D","Diode_THT:D_DO-201_P12.70mm_Horizontal","~",""
|
||||||
|
"","","J1","Conn_01x01_Female","Connector:Conn_01x01_Female","Connector_PinHeader_2.54mm:PinHeader_1x01_P2.54mm_Vertical","~",""
|
||||||
|
"","","J2","Conn_01x01_Female","Connector:Conn_01x01_Female","Connector_PinHeader_2.54mm:PinHeader_1x01_P2.54mm_Vertical","~",""
|
||||||
|
"","","J3","Conn_01x01_Female","Connector:Conn_01x01_Female","Connector_PinHeader_2.54mm:PinHeader_1x01_P2.54mm_Vertical","~",""
|
||||||
|
"","","J4","Conn_01x01_Female","Connector:Conn_01x01_Female","Connector_PinHeader_2.54mm:PinHeader_1x01_P2.54mm_Vertical","~",""
|
||||||
|
"","","J5","Conn_01x01_Female","Connector:Conn_01x01_Female","Connector_PinHeader_2.54mm:PinHeader_1x01_P2.54mm_Vertical","~",""
|
||||||
|
"","","J6","Conn_01x01_Female","Connector:Conn_01x01_Female","Connector_PinHeader_2.54mm:PinHeader_1x01_P2.54mm_Vertical","~",""
|
||||||
|
"","","J7","01x05","Connector:Conn_01x05_Male","Connector_PinHeader_2.54mm:PinHeader_1x05_P2.54mm_Vertical","~",""
|
||||||
|
"","","J8","Connector_Generic:Conn_02x04_Odd_Even","Connector_Generic:Conn_02x04_Odd_Even","Connector_PinHeader_2.54mm:PinHeader_2x04_P2.54mm_Vertical","~",""
|
||||||
|
"","","J9","Conn_01x02_Female","Connector:Conn_01x02_Female","Connector_PinSocket_2.54mm:PinSocket_1x02_P2.54mm_Vertical","~",""
|
||||||
|
"","","J10","Screw_Terminal_01x02","Connector:Screw_Terminal_01x02","TerminalBlock_Phoenix:TerminalBlock_Phoenix_MKDS-3-2-5.08_1x02_P5.08mm_Horizontal","~",""
|
||||||
|
"","","J11","Screw_Terminal_01x03","Connector:Screw_Terminal_01x03","TerminalBlock_Phoenix:TerminalBlock_Phoenix_MKDS-1,5-3_1x03_P5.00mm_Horizontal","~",""
|
||||||
|
"","","J12","Screw_Terminal_01x03","Connector:Screw_Terminal_01x03","TerminalBlock_Phoenix:TerminalBlock_Phoenix_MKDS-1,5-3_1x03_P5.00mm_Horizontal","~",""
|
||||||
|
"","","J13","USB_B","Connector:USB_B","Connectors_USB:USB_B_OST_USB-B1HSxx_Horizontal"," ~",""
|
||||||
|
"","","J14","DB9_Female","Connector:DB9_Female","Connector_Dsub:DSUB-9_Female_Horizontal_P2.77x2.84mm_EdgePinOffset7.70mm_Housed_MountingHolesOffset9.12mm"," ~",""
|
||||||
|
"","","J15","01x03","Connector:Conn_01x03_Male","Connector_PinSocket_2.54mm:PinSocket_1x03_P2.54mm_Vertical","~",""
|
||||||
|
"","","J16","Conn_01x02_Female","Connector:Conn_01x02_Female","Connector_PinSocket_2.54mm:PinSocket_1x02_P2.54mm_Vertical","~",""
|
||||||
|
"","","J17","Screw_Terminal_01x03","Connector:Screw_Terminal_01x03","TerminalBlock_Phoenix:TerminalBlock_Phoenix_MKDS-1,5-3_1x03_P5.00mm_Horizontal","~",""
|
||||||
|
"","","J18","01x05","Connector:Conn_01x05_Male","Connector_PinSocket_2.54mm:PinSocket_1x05_P2.54mm_Vertical","~",""
|
||||||
|
"","","JP1","NON-ISOL","Device:Jumper","Resistor_THT:R_Axial_DIN0207_L6.3mm_D2.5mm_P5.08mm_Vertical","~",""
|
||||||
|
"","","K1","G5LE-1","Relay:G5LE-1","Relay_THT:Relay_SPDT_Omron-G5LE-1","http://www.omron.com/ecb/products/pdf/en-g5le.pdf",""
|
||||||
|
"","","K2","G5LE-1","Relay:G5LE-1","Relay_THT:Relay_SPDT_Omron-G5LE-1","http://www.omron.com/ecb/products/pdf/en-g5le.pdf",""
|
||||||
|
"","","L1","100u","Device:L","Inductor_SMD:L_12x12mm_H4.5mm","~",""
|
||||||
|
"","","P1","Hole","stm32-rescue:CONN_01X01","my_footprints:Hole_3mm","",""
|
||||||
|
"","","P2","Hole","stm32-rescue:CONN_01X01","my_footprints:Hole_3mm","",""
|
||||||
|
"","","P3","Hole","stm32-rescue:CONN_01X01","my_footprints:Hole_3mm","",""
|
||||||
|
"","","P4","Hole","stm32-rescue:CONN_01X01","my_footprints:Hole_3mm","",""
|
||||||
|
"","","Q1","B0505S","elements:B0505S","my_footprints:B0x0xS","",""
|
||||||
|
"","","Q2","SI2300","Device:Q_NMOS_GSD","TO_SOT_Packages_SMD:SOT-23_Handsoldering","~",""
|
||||||
|
"","","Q3","SI2300","Device:Q_NMOS_GSD","TO_SOT_Packages_SMD:SOT-23_Handsoldering","~",""
|
||||||
|
"","","Q4","AO3407","Device:Q_PMOS_GSD","TO_SOT_Packages_SMD:SOT-23_Handsoldering","~",""
|
||||||
|
"","","Q5","SI2300","Device:Q_NMOS_GSD","TO_SOT_Packages_SMD:SOT-23_Handsoldering","~",""
|
||||||
|
"","","Q6","SI2300","Device:Q_NMOS_GSD","TO_SOT_Packages_SMD:SOT-23_Handsoldering","~",""
|
||||||
|
"","","Q7","SI2300","Device:Q_NMOS_GSD","TO_SOT_Packages_SMD:SOT-23_Handsoldering","~",""
|
||||||
|
"","","R1","10k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R2","4k7","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"","","R3","22","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R4","680","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R5","680","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R6","680","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R7","680","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R8","10k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R9","330","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R10","22","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"","","R11","22","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"","","R12","2k2","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R13","120","stm32-rescue:R","Resistor_SMD:R_1210_3225Metric_Pad1.42x2.65mm_HandSolder","",""
|
||||||
|
"","","R14","10k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R15","330","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R16","2k2","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R17","10k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R18","47k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R19","15k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R20","15k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R21","10k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R22","330","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R23","330","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R24","330","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R25","10k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R26","10k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","R27","10k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"","","SW1","SW_DIP_x08","Switch:SW_DIP_x08","Button_Switch_THT:SW_DIP_SPSTx08_Slide_9.78x22.5mm_W7.62mm_P2.54mm","~",""
|
||||||
|
"","","SW2","SW_DIP_x01","Switch:SW_DIP_x01","Button_Switch_THT:SW_DIP_SPSTx01_Slide_6.7x4.1mm_W7.62mm_P2.54mm_LowProfile","~",""
|
||||||
|
"","","U1","MCP2551-I/SN","stm32-rescue:MCP2551-I_SN","Package_SO:SOIC-8_3.9x4.9mm_P1.27mm","",""
|
||||||
|
"","","U2","ISO1050DUB","Interface_CAN_LIN:ISO1050DUB","Package_SO:SOP-8_6.62x9.15mm_P2.54mm","http://www.ti.com/lit/ds/symlink/iso1050.pdf",""
|
||||||
|
"","","U3","STM32F072C8Tx","MCU_ST_STM32F0:STM32F072C8Tx","Package_QFP:LQFP-48_7x7mm_P0.5mm","http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00090510.pdf",""
|
||||||
|
"","","U4","LM2576","vreg:LM2576","TO_SOT_Packages_THT:TO-220-5_P3.4x3.7mm_StaggerEven_Lead3.8mm_Vertical","","Texas Instruments"
|
||||||
|
"","","U5","LM1117-3.3","Regulator_Linear:LM1117-3.3","TO_SOT_Packages_SMD:SOT-223-3_TabPin2","http://www.ti.com/lit/ds/symlink/lm1117.pdf",""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
"Collated Components:"
|
||||||
|
|
||||||
|
"Item","Qty","Reference(s)","Value","LibPart","Footprint","Datasheet","Manufacturer"
|
||||||
|
"1","2","C1, C5","1","stm32-rescue:C","Capacitor_SMD:C_0805_2012Metric_Pad1.15x1.40mm_HandSolder","",""
|
||||||
|
"2","10","C2, C3, C4, C6, C7, C8, C9, C11, C14, C15","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"3","1","C10","47u 16V","Device:CP","Capacitor_Tantalum_SMD:CP_EIA-6032-28_Kemet-C_Pad2.25x2.35mm_HandSolder","~",""
|
||||||
|
"4","2","C12, C13","47u 10V","Device:CP","Capacitor_Tantalum_SMD:CP_EIA-1608-08_AVX-J_Pad1.25x1.05mm_HandSolder","~",""
|
||||||
|
"5","1","D1","PESD1CAN","elements:PESD1CAN","TO_SOT_Packages_SMD:SOT-23","",""
|
||||||
|
"6","5","D2, D4, D8, D9, D10","SS14","Device:D_Schottky","Diode_SMD:D_SMA-SMB_Universal_Handsoldering","~",""
|
||||||
|
"7","1","D3","USB6B1","elements:USB6B1","Package_SO:SOIC-8_3.9x4.9mm_P1.27mm","",""
|
||||||
|
"8","1","D5","MM3Z7V5","Device:D_Zener","Diode_SMD:D_0805_2012Metric_Pad1.15x1.40mm_HandSolder","~",""
|
||||||
|
"9","2","D6, D7","CESD3v3","Device:D","Diode_SMD:D_SOD-523","~",""
|
||||||
|
"10","1","D11","1N5822","Device:D","Diode_THT:D_DO-201_P12.70mm_Horizontal","~",""
|
||||||
|
"11","6","J1, J2, J3, J4, J5, J6","Conn_01x01_Female","Connector:Conn_01x01_Female","Connector_PinHeader_2.54mm:PinHeader_1x01_P2.54mm_Vertical","~",""
|
||||||
|
"12","1","J7","01x05","Connector:Conn_01x05_Male","Connector_PinHeader_2.54mm:PinHeader_1x05_P2.54mm_Vertical","~",""
|
||||||
|
"13","1","J8","Connector_Generic:Conn_02x04_Odd_Even","Connector_Generic:Conn_02x04_Odd_Even","Connector_PinHeader_2.54mm:PinHeader_2x04_P2.54mm_Vertical","~",""
|
||||||
|
"14","2","J9, J16","Conn_01x02_Female","Connector:Conn_01x02_Female","Connector_PinSocket_2.54mm:PinSocket_1x02_P2.54mm_Vertical","~",""
|
||||||
|
"15","1","J10","Screw_Terminal_01x02","Connector:Screw_Terminal_01x02","TerminalBlock_Phoenix:TerminalBlock_Phoenix_MKDS-3-2-5.08_1x02_P5.08mm_Horizontal","~",""
|
||||||
|
"16","3","J11, J12, J17","Screw_Terminal_01x03","Connector:Screw_Terminal_01x03","TerminalBlock_Phoenix:TerminalBlock_Phoenix_MKDS-1,5-3_1x03_P5.00mm_Horizontal","~",""
|
||||||
|
"17","1","J13","USB_B","Connector:USB_B","Connectors_USB:USB_B_OST_USB-B1HSxx_Horizontal"," ~",""
|
||||||
|
"18","1","J14","DB9_Female","Connector:DB9_Female","Connector_Dsub:DSUB-9_Female_Horizontal_P2.77x2.84mm_EdgePinOffset7.70mm_Housed_MountingHolesOffset9.12mm"," ~",""
|
||||||
|
"19","1","J15","01x03","Connector:Conn_01x03_Male","Connector_PinSocket_2.54mm:PinSocket_1x03_P2.54mm_Vertical","~",""
|
||||||
|
"20","1","J18","01x05","Connector:Conn_01x05_Male","Connector_PinSocket_2.54mm:PinSocket_1x05_P2.54mm_Vertical","~",""
|
||||||
|
"21","1","JP1","NON-ISOL","Device:Jumper","Resistor_THT:R_Axial_DIN0207_L6.3mm_D2.5mm_P5.08mm_Vertical","~",""
|
||||||
|
"22","2","K1, K2","G5LE-1","Relay:G5LE-1","Relay_THT:Relay_SPDT_Omron-G5LE-1","http://www.omron.com/ecb/products/pdf/en-g5le.pdf",""
|
||||||
|
"23","1","L1","100u","Device:L","Inductor_SMD:L_12x12mm_H4.5mm","~",""
|
||||||
|
"24","4","P1, P2, P3, P4","Hole","stm32-rescue:CONN_01X01","my_footprints:Hole_3mm","",""
|
||||||
|
"25","1","Q1","B0505S","elements:B0505S","my_footprints:B0x0xS","",""
|
||||||
|
"26","5","Q2, Q3, Q5, Q6, Q7","SI2300","Device:Q_NMOS_GSD","TO_SOT_Packages_SMD:SOT-23_Handsoldering","~",""
|
||||||
|
"27","1","Q4","AO3407","Device:Q_PMOS_GSD","TO_SOT_Packages_SMD:SOT-23_Handsoldering","~",""
|
||||||
|
"28","8","R1, R8, R14, R17, R21, R25, R26, R27","10k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"29","1","R2","4k7","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"30","3","R3, R10, R11","22","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"31","4","R4, R5, R6, R7","680","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"32","5","R9, R15, R22, R23, R24","330","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"33","2","R12, R16","2k2","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"34","1","R13","120","stm32-rescue:R","Resistor_SMD:R_1210_3225Metric_Pad1.42x2.65mm_HandSolder","",""
|
||||||
|
"35","1","R18","47k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"36","2","R19, R20","15k","Device:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","~",""
|
||||||
|
"37","1","SW1","SW_DIP_x08","Switch:SW_DIP_x08","Button_Switch_THT:SW_DIP_SPSTx08_Slide_9.78x22.5mm_W7.62mm_P2.54mm","~",""
|
||||||
|
"38","1","SW2","SW_DIP_x01","Switch:SW_DIP_x01","Button_Switch_THT:SW_DIP_SPSTx01_Slide_6.7x4.1mm_W7.62mm_P2.54mm_LowProfile","~",""
|
||||||
|
"39","1","U1","MCP2551-I/SN","stm32-rescue:MCP2551-I_SN","Package_SO:SOIC-8_3.9x4.9mm_P1.27mm","",""
|
||||||
|
"40","1","U2","ISO1050DUB","Interface_CAN_LIN:ISO1050DUB","Package_SO:SOP-8_6.62x9.15mm_P2.54mm","http://www.ti.com/lit/ds/symlink/iso1050.pdf",""
|
||||||
|
"41","1","U3","STM32F072C8Tx","MCU_ST_STM32F0:STM32F072C8Tx","Package_QFP:LQFP-48_7x7mm_P0.5mm","http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00090510.pdf",""
|
||||||
|
"42","1","U4","LM2576","vreg:LM2576","TO_SOT_Packages_THT:TO-220-5_P3.4x3.7mm_StaggerEven_Lead3.8mm_Vertical","","Texas Instruments"
|
||||||
|
"43","1","U5","LM1117-3.3","Regulator_Linear:LM1117-3.3","TO_SOT_Packages_SMD:SOT-223-3_TabPin2","http://www.ti.com/lit/ds/symlink/lm1117.pdf",""
|
||||||
|
Can't render this file because it has a wrong number of fields in line 7.
|
7693
F0-nolib/usbcan_relay/kicad/stm32.kicad_pcb
Normal file
7693
F0-nolib/usbcan_relay/kicad/stm32.kicad_pcb
Normal file
File diff suppressed because it is too large
Load Diff
76
F0-nolib/usbcan_relay/kicad/stm32.kicad_prl
Normal file
76
F0-nolib/usbcan_relay/kicad/stm32.kicad_prl
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
{
|
||||||
|
"board": {
|
||||||
|
"active_layer": 0,
|
||||||
|
"active_layer_preset": "All Layers",
|
||||||
|
"auto_track_width": true,
|
||||||
|
"hidden_nets": [],
|
||||||
|
"high_contrast_mode": 0,
|
||||||
|
"net_color_mode": 1,
|
||||||
|
"opacity": {
|
||||||
|
"pads": 1.0,
|
||||||
|
"tracks": 1.0,
|
||||||
|
"vias": 1.0,
|
||||||
|
"zones": 0.6
|
||||||
|
},
|
||||||
|
"ratsnest_display_mode": 0,
|
||||||
|
"selection_filter": {
|
||||||
|
"dimensions": true,
|
||||||
|
"footprints": true,
|
||||||
|
"graphics": true,
|
||||||
|
"keepouts": true,
|
||||||
|
"lockedItems": true,
|
||||||
|
"otherItems": true,
|
||||||
|
"pads": true,
|
||||||
|
"text": true,
|
||||||
|
"tracks": true,
|
||||||
|
"vias": true,
|
||||||
|
"zones": true
|
||||||
|
},
|
||||||
|
"visible_items": [
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
2,
|
||||||
|
3,
|
||||||
|
4,
|
||||||
|
5,
|
||||||
|
6,
|
||||||
|
8,
|
||||||
|
9,
|
||||||
|
10,
|
||||||
|
11,
|
||||||
|
12,
|
||||||
|
13,
|
||||||
|
14,
|
||||||
|
15,
|
||||||
|
16,
|
||||||
|
17,
|
||||||
|
18,
|
||||||
|
19,
|
||||||
|
20,
|
||||||
|
21,
|
||||||
|
22,
|
||||||
|
23,
|
||||||
|
24,
|
||||||
|
25,
|
||||||
|
26,
|
||||||
|
27,
|
||||||
|
28,
|
||||||
|
29,
|
||||||
|
30,
|
||||||
|
32,
|
||||||
|
33,
|
||||||
|
34,
|
||||||
|
35,
|
||||||
|
36
|
||||||
|
],
|
||||||
|
"visible_layers": "fffffff_ffffffff",
|
||||||
|
"zone_display_mode": 0
|
||||||
|
},
|
||||||
|
"meta": {
|
||||||
|
"filename": "stm32.kicad_prl",
|
||||||
|
"version": 3
|
||||||
|
},
|
||||||
|
"project": {
|
||||||
|
"files": []
|
||||||
|
}
|
||||||
|
}
|
||||||
462
F0-nolib/usbcan_relay/kicad/stm32.kicad_pro
Normal file
462
F0-nolib/usbcan_relay/kicad/stm32.kicad_pro
Normal file
@ -0,0 +1,462 @@
|
|||||||
|
{
|
||||||
|
"board": {
|
||||||
|
"design_settings": {
|
||||||
|
"defaults": {
|
||||||
|
"board_outline_line_width": 0.15,
|
||||||
|
"copper_line_width": 0.19999999999999998,
|
||||||
|
"copper_text_italic": false,
|
||||||
|
"copper_text_size_h": 1.5,
|
||||||
|
"copper_text_size_v": 1.5,
|
||||||
|
"copper_text_thickness": 0.3,
|
||||||
|
"copper_text_upright": false,
|
||||||
|
"courtyard_line_width": 0.049999999999999996,
|
||||||
|
"dimension_precision": 4,
|
||||||
|
"dimension_units": 3,
|
||||||
|
"dimensions": {
|
||||||
|
"arrow_length": 1270000,
|
||||||
|
"extension_offset": 500000,
|
||||||
|
"keep_text_aligned": true,
|
||||||
|
"suppress_zeroes": false,
|
||||||
|
"text_position": 0,
|
||||||
|
"units_format": 1
|
||||||
|
},
|
||||||
|
"fab_line_width": 0.09999999999999999,
|
||||||
|
"fab_text_italic": false,
|
||||||
|
"fab_text_size_h": 1.0,
|
||||||
|
"fab_text_size_v": 1.0,
|
||||||
|
"fab_text_thickness": 0.15,
|
||||||
|
"fab_text_upright": false,
|
||||||
|
"other_line_width": 0.09999999999999999,
|
||||||
|
"other_text_italic": false,
|
||||||
|
"other_text_size_h": 1.0,
|
||||||
|
"other_text_size_v": 1.0,
|
||||||
|
"other_text_thickness": 0.15,
|
||||||
|
"other_text_upright": false,
|
||||||
|
"pads": {
|
||||||
|
"drill": 0.8,
|
||||||
|
"height": 1.5,
|
||||||
|
"width": 1.5
|
||||||
|
},
|
||||||
|
"silk_line_width": 0.15,
|
||||||
|
"silk_text_italic": false,
|
||||||
|
"silk_text_size_h": 1.0,
|
||||||
|
"silk_text_size_v": 1.0,
|
||||||
|
"silk_text_thickness": 0.15,
|
||||||
|
"silk_text_upright": false,
|
||||||
|
"zones": {
|
||||||
|
"45_degree_only": true,
|
||||||
|
"min_clearance": 0.5
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"diff_pair_dimensions": [],
|
||||||
|
"drc_exclusions": [],
|
||||||
|
"meta": {
|
||||||
|
"filename": "board_design_settings.json",
|
||||||
|
"version": 2
|
||||||
|
},
|
||||||
|
"rule_severities": {
|
||||||
|
"annular_width": "error",
|
||||||
|
"clearance": "error",
|
||||||
|
"copper_edge_clearance": "error",
|
||||||
|
"courtyards_overlap": "error",
|
||||||
|
"diff_pair_gap_out_of_range": "error",
|
||||||
|
"diff_pair_uncoupled_length_too_long": "error",
|
||||||
|
"drill_out_of_range": "error",
|
||||||
|
"duplicate_footprints": "warning",
|
||||||
|
"extra_footprint": "warning",
|
||||||
|
"hole_clearance": "error",
|
||||||
|
"hole_near_hole": "error",
|
||||||
|
"invalid_outline": "error",
|
||||||
|
"item_on_disabled_layer": "error",
|
||||||
|
"items_not_allowed": "error",
|
||||||
|
"length_out_of_range": "error",
|
||||||
|
"malformed_courtyard": "error",
|
||||||
|
"microvia_drill_out_of_range": "error",
|
||||||
|
"missing_courtyard": "ignore",
|
||||||
|
"missing_footprint": "warning",
|
||||||
|
"net_conflict": "warning",
|
||||||
|
"npth_inside_courtyard": "ignore",
|
||||||
|
"padstack": "error",
|
||||||
|
"pth_inside_courtyard": "ignore",
|
||||||
|
"shorting_items": "error",
|
||||||
|
"silk_over_copper": "error",
|
||||||
|
"silk_overlap": "error",
|
||||||
|
"skew_out_of_range": "error",
|
||||||
|
"too_many_vias": "error",
|
||||||
|
"track_dangling": "warning",
|
||||||
|
"track_width": "error",
|
||||||
|
"tracks_crossing": "error",
|
||||||
|
"unconnected_items": "error",
|
||||||
|
"unresolved_variable": "error",
|
||||||
|
"via_dangling": "warning",
|
||||||
|
"zone_has_empty_net": "error",
|
||||||
|
"zones_intersect": "error"
|
||||||
|
},
|
||||||
|
"rule_severitieslegacy_courtyards_overlap": true,
|
||||||
|
"rule_severitieslegacy_no_courtyard_defined": false,
|
||||||
|
"rules": {
|
||||||
|
"allow_blind_buried_vias": false,
|
||||||
|
"allow_microvias": false,
|
||||||
|
"max_error": 0.005,
|
||||||
|
"min_clearance": 0.0,
|
||||||
|
"min_copper_edge_clearance": 0.075,
|
||||||
|
"min_hole_clearance": 0.0,
|
||||||
|
"min_hole_to_hole": 0.25,
|
||||||
|
"min_microvia_diameter": 0.19999999999999998,
|
||||||
|
"min_microvia_drill": 0.09999999999999999,
|
||||||
|
"min_silk_clearance": 0.0,
|
||||||
|
"min_through_hole_diameter": 0.6,
|
||||||
|
"min_track_width": 0.19999999999999998,
|
||||||
|
"min_via_annular_width": 0.049999999999999996,
|
||||||
|
"min_via_diameter": 0.7999999999999999
|
||||||
|
},
|
||||||
|
"track_widths": [
|
||||||
|
0.0,
|
||||||
|
0.2,
|
||||||
|
0.3,
|
||||||
|
0.5,
|
||||||
|
1.0,
|
||||||
|
2.0
|
||||||
|
],
|
||||||
|
"via_dimensions": [
|
||||||
|
{
|
||||||
|
"diameter": 0.0,
|
||||||
|
"drill": 0.0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"diameter": 1.5,
|
||||||
|
"drill": 0.8
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"zones_allow_external_fillets": false,
|
||||||
|
"zones_use_no_outline": true
|
||||||
|
},
|
||||||
|
"layer_presets": []
|
||||||
|
},
|
||||||
|
"boards": [],
|
||||||
|
"cvpcb": {
|
||||||
|
"equivalence_files": []
|
||||||
|
},
|
||||||
|
"erc": {
|
||||||
|
"erc_exclusions": [],
|
||||||
|
"meta": {
|
||||||
|
"version": 0
|
||||||
|
},
|
||||||
|
"pin_map": [
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
2,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
1,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
[
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"rule_severities": {
|
||||||
|
"bus_definition_conflict": "error",
|
||||||
|
"bus_label_syntax": "error",
|
||||||
|
"bus_to_bus_conflict": "error",
|
||||||
|
"bus_to_net_conflict": "error",
|
||||||
|
"different_unit_footprint": "error",
|
||||||
|
"different_unit_net": "error",
|
||||||
|
"duplicate_reference": "error",
|
||||||
|
"duplicate_sheet_names": "error",
|
||||||
|
"extra_units": "error",
|
||||||
|
"global_label_dangling": "warning",
|
||||||
|
"hier_label_mismatch": "error",
|
||||||
|
"label_dangling": "error",
|
||||||
|
"lib_symbol_issues": "warning",
|
||||||
|
"multiple_net_names": "warning",
|
||||||
|
"net_not_bus_member": "warning",
|
||||||
|
"no_connect_connected": "warning",
|
||||||
|
"no_connect_dangling": "warning",
|
||||||
|
"pin_not_connected": "error",
|
||||||
|
"pin_not_driven": "error",
|
||||||
|
"pin_to_pin": "warning",
|
||||||
|
"power_pin_not_driven": "error",
|
||||||
|
"similar_labels": "warning",
|
||||||
|
"unannotated": "error",
|
||||||
|
"unit_value_mismatch": "error",
|
||||||
|
"unresolved_variable": "error",
|
||||||
|
"wire_dangling": "error"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"libraries": {
|
||||||
|
"pinned_footprint_libs": [],
|
||||||
|
"pinned_symbol_libs": []
|
||||||
|
},
|
||||||
|
"meta": {
|
||||||
|
"filename": "stm32.kicad_pro",
|
||||||
|
"version": 1
|
||||||
|
},
|
||||||
|
"net_settings": {
|
||||||
|
"classes": [
|
||||||
|
{
|
||||||
|
"bus_width": 12.0,
|
||||||
|
"clearance": 0.2,
|
||||||
|
"diff_pair_gap": 0.25,
|
||||||
|
"diff_pair_via_gap": 0.25,
|
||||||
|
"diff_pair_width": 0.2,
|
||||||
|
"line_style": 0,
|
||||||
|
"microvia_diameter": 0.3,
|
||||||
|
"microvia_drill": 0.1,
|
||||||
|
"name": "Default",
|
||||||
|
"pcb_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"schematic_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"track_width": 0.2,
|
||||||
|
"via_diameter": 1.0,
|
||||||
|
"via_drill": 0.6,
|
||||||
|
"wire_width": 6.0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"bus_width": 12.0,
|
||||||
|
"clearance": 0.3,
|
||||||
|
"diff_pair_gap": 0.25,
|
||||||
|
"diff_pair_via_gap": 0.25,
|
||||||
|
"diff_pair_width": 0.2,
|
||||||
|
"line_style": 0,
|
||||||
|
"microvia_diameter": 0.3,
|
||||||
|
"microvia_drill": 0.1,
|
||||||
|
"name": "0.5",
|
||||||
|
"nets": [],
|
||||||
|
"pcb_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"schematic_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"track_width": 0.5,
|
||||||
|
"via_diameter": 1.5,
|
||||||
|
"via_drill": 0.8,
|
||||||
|
"wire_width": 6.0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"bus_width": 12.0,
|
||||||
|
"clearance": 0.5,
|
||||||
|
"diff_pair_gap": 0.25,
|
||||||
|
"diff_pair_via_gap": 0.25,
|
||||||
|
"diff_pair_width": 0.2,
|
||||||
|
"line_style": 0,
|
||||||
|
"microvia_diameter": 0.3,
|
||||||
|
"microvia_drill": 0.1,
|
||||||
|
"name": "1",
|
||||||
|
"nets": [],
|
||||||
|
"pcb_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"schematic_color": "rgba(0, 0, 0, 0.000)",
|
||||||
|
"track_width": 1.0,
|
||||||
|
"via_diameter": 1.5,
|
||||||
|
"via_drill": 0.8,
|
||||||
|
"wire_width": 6.0
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"meta": {
|
||||||
|
"version": 0
|
||||||
|
},
|
||||||
|
"net_colors": null
|
||||||
|
},
|
||||||
|
"pcbnew": {
|
||||||
|
"last_paths": {
|
||||||
|
"gencad": "",
|
||||||
|
"idf": "",
|
||||||
|
"netlist": "stm32.net",
|
||||||
|
"specctra_dsn": "",
|
||||||
|
"step": "",
|
||||||
|
"vrml": ""
|
||||||
|
},
|
||||||
|
"page_layout_descr_file": ""
|
||||||
|
},
|
||||||
|
"schematic": {
|
||||||
|
"drawing": {
|
||||||
|
"default_bus_thickness": 12.0,
|
||||||
|
"default_junction_size": 40.0,
|
||||||
|
"default_line_thickness": 6.0,
|
||||||
|
"default_text_size": 50.0,
|
||||||
|
"default_wire_thickness": 6.0,
|
||||||
|
"field_names": [],
|
||||||
|
"intersheets_ref_own_page": false,
|
||||||
|
"intersheets_ref_prefix": "",
|
||||||
|
"intersheets_ref_short": false,
|
||||||
|
"intersheets_ref_show": false,
|
||||||
|
"intersheets_ref_suffix": "",
|
||||||
|
"junction_size_choice": 3,
|
||||||
|
"pin_symbol_size": 25.0,
|
||||||
|
"text_offset_ratio": 0.3
|
||||||
|
},
|
||||||
|
"legacy_lib_dir": "",
|
||||||
|
"legacy_lib_list": [],
|
||||||
|
"meta": {
|
||||||
|
"version": 0
|
||||||
|
},
|
||||||
|
"net_format_name": "Pcbnew",
|
||||||
|
"ngspice": {
|
||||||
|
"meta": {
|
||||||
|
"version": 0
|
||||||
|
},
|
||||||
|
"model_mode": 0
|
||||||
|
},
|
||||||
|
"page_layout_descr_file": "",
|
||||||
|
"plot_directory": "",
|
||||||
|
"spice_adjust_passive_values": false,
|
||||||
|
"spice_external_command": "spice \"%I\"",
|
||||||
|
"subpart_first_id": 65,
|
||||||
|
"subpart_id_separator": 0
|
||||||
|
},
|
||||||
|
"sheets": [],
|
||||||
|
"text_variables": {}
|
||||||
|
}
|
||||||
1618
F0-nolib/usbcan_relay/kicad/stm32.net
Normal file
1618
F0-nolib/usbcan_relay/kicad/stm32.net
Normal file
File diff suppressed because it is too large
Load Diff
276
F0-nolib/usbcan_relay/kicad/stm32.pro
Normal file
276
F0-nolib/usbcan_relay/kicad/stm32.pro
Normal file
@ -0,0 +1,276 @@
|
|||||||
|
update=Ср 16 июн 2021 12:32:18
|
||||||
|
version=1
|
||||||
|
last_client=kicad
|
||||||
|
[cvpcb]
|
||||||
|
version=1
|
||||||
|
NetIExt=net
|
||||||
|
[general]
|
||||||
|
version=1
|
||||||
|
[eeschema]
|
||||||
|
version=1
|
||||||
|
LibDir=
|
||||||
|
[schematic_editor]
|
||||||
|
version=1
|
||||||
|
PageLayoutDescrFile=
|
||||||
|
PlotDirectoryName=
|
||||||
|
SubpartIdSeparator=0
|
||||||
|
SubpartFirstId=65
|
||||||
|
NetFmtName=Pcbnew
|
||||||
|
SpiceAjustPassiveValues=0
|
||||||
|
LabSize=50
|
||||||
|
ERC_TestSimilarLabels=1
|
||||||
|
[pcbnew]
|
||||||
|
version=1
|
||||||
|
PageLayoutDescrFile=
|
||||||
|
LastNetListRead=stm32.net
|
||||||
|
CopperLayerCount=2
|
||||||
|
BoardThickness=2.5
|
||||||
|
AllowMicroVias=0
|
||||||
|
AllowBlindVias=0
|
||||||
|
RequireCourtyardDefinitions=0
|
||||||
|
ProhibitOverlappingCourtyards=1
|
||||||
|
MinTrackWidth=0.2
|
||||||
|
MinViaDiameter=0.7999999999999999
|
||||||
|
MinViaDrill=0.4
|
||||||
|
MinMicroViaDiameter=0.2
|
||||||
|
MinMicroViaDrill=0.09999999999999999
|
||||||
|
MinHoleToHole=0.25
|
||||||
|
TrackWidth1=0.2
|
||||||
|
TrackWidth2=0.2
|
||||||
|
TrackWidth3=0.3
|
||||||
|
TrackWidth4=0.5
|
||||||
|
TrackWidth5=1
|
||||||
|
TrackWidth6=2
|
||||||
|
ViaDiameter1=0.8
|
||||||
|
ViaDrill1=0.4
|
||||||
|
ViaDiameter2=0.8
|
||||||
|
ViaDrill2=0.4
|
||||||
|
ViaDiameter3=1.2
|
||||||
|
ViaDrill3=0.6
|
||||||
|
dPairWidth1=0.2
|
||||||
|
dPairGap1=0.25
|
||||||
|
dPairViaGap1=0.25
|
||||||
|
SilkLineWidth=0.15
|
||||||
|
SilkTextSizeV=1
|
||||||
|
SilkTextSizeH=1
|
||||||
|
SilkTextSizeThickness=0.15
|
||||||
|
SilkTextItalic=0
|
||||||
|
SilkTextUpright=1
|
||||||
|
CopperLineWidth=0.2
|
||||||
|
CopperTextSizeV=1.5
|
||||||
|
CopperTextSizeH=1.5
|
||||||
|
CopperTextThickness=0.3
|
||||||
|
CopperTextItalic=0
|
||||||
|
CopperTextUpright=1
|
||||||
|
EdgeCutLineWidth=0.15
|
||||||
|
CourtyardLineWidth=0.05
|
||||||
|
OthersLineWidth=0.15
|
||||||
|
OthersTextSizeV=1
|
||||||
|
OthersTextSizeH=1
|
||||||
|
OthersTextSizeThickness=0.15
|
||||||
|
OthersTextItalic=0
|
||||||
|
OthersTextUpright=1
|
||||||
|
SolderMaskClearance=0.2
|
||||||
|
SolderMaskMinWidth=0
|
||||||
|
SolderPasteClearance=0
|
||||||
|
SolderPasteRatio=-0
|
||||||
|
[pcbnew/Layer.F.Cu]
|
||||||
|
Name=F.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.In1.Cu]
|
||||||
|
Name=In1.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In2.Cu]
|
||||||
|
Name=In2.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In3.Cu]
|
||||||
|
Name=In3.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In4.Cu]
|
||||||
|
Name=In4.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In5.Cu]
|
||||||
|
Name=In5.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In6.Cu]
|
||||||
|
Name=In6.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In7.Cu]
|
||||||
|
Name=In7.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In8.Cu]
|
||||||
|
Name=In8.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In9.Cu]
|
||||||
|
Name=In9.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In10.Cu]
|
||||||
|
Name=In10.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In11.Cu]
|
||||||
|
Name=In11.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In12.Cu]
|
||||||
|
Name=In12.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In13.Cu]
|
||||||
|
Name=In13.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In14.Cu]
|
||||||
|
Name=In14.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In15.Cu]
|
||||||
|
Name=In15.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In16.Cu]
|
||||||
|
Name=In16.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In17.Cu]
|
||||||
|
Name=In17.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In18.Cu]
|
||||||
|
Name=In18.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In19.Cu]
|
||||||
|
Name=In19.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In20.Cu]
|
||||||
|
Name=In20.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In21.Cu]
|
||||||
|
Name=In21.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In22.Cu]
|
||||||
|
Name=In22.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In23.Cu]
|
||||||
|
Name=In23.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In24.Cu]
|
||||||
|
Name=In24.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In25.Cu]
|
||||||
|
Name=In25.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In26.Cu]
|
||||||
|
Name=In26.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In27.Cu]
|
||||||
|
Name=In27.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In28.Cu]
|
||||||
|
Name=In28.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In29.Cu]
|
||||||
|
Name=In29.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In30.Cu]
|
||||||
|
Name=In30.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.B.Cu]
|
||||||
|
Name=B.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.Adhes]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.F.Adhes]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.Paste]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.F.Paste]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.SilkS]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.F.SilkS]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.Mask]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.F.Mask]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.Dwgs.User]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.Cmts.User]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.Eco1.User]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.Eco2.User]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.Edge.Cuts]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.Margin]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.CrtYd]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.F.CrtYd]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.Fab]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.F.Fab]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.Rescue]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Netclasses]
|
||||||
|
[pcbnew/Netclasses/Default]
|
||||||
|
Name=Default
|
||||||
|
Clearance=0.2
|
||||||
|
TrackWidth=0.2
|
||||||
|
ViaDiameter=0.8
|
||||||
|
ViaDrill=0.4
|
||||||
|
uViaDiameter=0.3
|
||||||
|
uViaDrill=0.1
|
||||||
|
dPairWidth=0.2
|
||||||
|
dPairGap=0.25
|
||||||
|
dPairViaGap=0.25
|
||||||
|
[pcbnew/Netclasses/1]
|
||||||
|
Name=0.5
|
||||||
|
Clearance=0.3
|
||||||
|
TrackWidth=0.5
|
||||||
|
ViaDiameter=1.2
|
||||||
|
ViaDrill=0.6
|
||||||
|
uViaDiameter=0.3
|
||||||
|
uViaDrill=0.1
|
||||||
|
dPairWidth=0.2
|
||||||
|
dPairGap=0.25
|
||||||
|
dPairViaGap=0.25
|
||||||
|
[pcbnew/Netclasses/2]
|
||||||
|
Name=1
|
||||||
|
Clearance=0.5
|
||||||
|
TrackWidth=1
|
||||||
|
ViaDiameter=1.2
|
||||||
|
ViaDrill=0.6
|
||||||
|
uViaDiameter=0.3
|
||||||
|
uViaDrill=0.1
|
||||||
|
dPairWidth=0.2
|
||||||
|
dPairGap=0.25
|
||||||
|
dPairViaGap=0.25
|
||||||
2308
F0-nolib/usbcan_relay/kicad/stm32.sch
Normal file
2308
F0-nolib/usbcan_relay/kicad/stm32.sch
Normal file
File diff suppressed because it is too large
Load Diff
8
F0-nolib/usbcan_relay/kicad/sym-lib-table
Normal file
8
F0-nolib/usbcan_relay/kicad/sym-lib-table
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
(sym_lib_table
|
||||||
|
(lib (name stm32-rescue)(type Legacy)(uri ${KIPRJMOD}/stm32-rescue.lib)(options "")(descr ""))
|
||||||
|
(lib (name stm32)(type Legacy)(uri /home/eddy/kicad/Kicad-Libraries/library/stm32.lib)(options "")(descr ""))
|
||||||
|
(lib (name vreg)(type Legacy)(uri /home/eddy/kicad/Kicad-Libraries/library/vreg.lib)(options "")(descr ""))
|
||||||
|
(lib (name elements)(type Legacy)(uri ${KIPRJMOD}/elements.lib)(options "")(descr ""))
|
||||||
|
(lib (name switches)(type Legacy)(uri /home/eddy/kicad/Kicad-Libraries/library/switches.lib)(options "")(descr ""))
|
||||||
|
(lib (name acs712)(type Legacy)(uri ${KIPRJMOD}/acs712.lib)(options "")(descr ""))
|
||||||
|
)
|
||||||
118
F0-nolib/usbcan_relay/main.c
Normal file
118
F0-nolib/usbcan_relay/main.c
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
/*
|
||||||
|
* main.c
|
||||||
|
*
|
||||||
|
* Copyright 2017 Edward V. Emelianoff <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "can.h"
|
||||||
|
#include "hardware.h"
|
||||||
|
#include "proto.h"
|
||||||
|
#include "usb.h"
|
||||||
|
#include "usb_lib.h"
|
||||||
|
|
||||||
|
volatile uint32_t Tms = 0;
|
||||||
|
|
||||||
|
/* Called when systick fires */
|
||||||
|
void sys_tick_handler(void){
|
||||||
|
++Tms;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define USBBUF 63
|
||||||
|
// usb getline
|
||||||
|
static char *get_USB(){
|
||||||
|
static char tmpbuf[USBBUF+1], *curptr = tmpbuf;
|
||||||
|
static int rest = USBBUF;
|
||||||
|
uint8_t x = USB_receive((uint8_t*)curptr);
|
||||||
|
if(!x) return NULL;
|
||||||
|
curptr[x] = 0;
|
||||||
|
if(x == 1 && *curptr == 0x7f){ // backspace
|
||||||
|
if(curptr > tmpbuf){
|
||||||
|
--curptr;
|
||||||
|
USND("\b \b");
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
USB_sendstr(curptr); // echo
|
||||||
|
if(curptr[x-1] == '\n'){ // || curptr[x-1] == '\r'){
|
||||||
|
curptr = tmpbuf;
|
||||||
|
rest = USBBUF;
|
||||||
|
// omit empty lines
|
||||||
|
if(tmpbuf[0] == '\n') return NULL;
|
||||||
|
// and wrong empty lines
|
||||||
|
if(tmpbuf[0] == '\r' && tmpbuf[1] == '\n') return NULL;
|
||||||
|
return tmpbuf;
|
||||||
|
}
|
||||||
|
curptr += x; rest -= x;
|
||||||
|
if(rest <= 0){ // buffer overflow
|
||||||
|
curptr = tmpbuf;
|
||||||
|
rest = USBBUF;
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void){
|
||||||
|
uint32_t lastT = 0;
|
||||||
|
uint8_t ctr, len;
|
||||||
|
CAN_message *can_mesg;
|
||||||
|
char *txt;
|
||||||
|
sysreset();
|
||||||
|
SysTick_Config(6000, 1);
|
||||||
|
gpio_setup();
|
||||||
|
USB_setup();
|
||||||
|
CAN_setup(100);
|
||||||
|
RCC->CSR |= RCC_CSR_RMVF; // remove reset flags
|
||||||
|
iwdg_setup();
|
||||||
|
|
||||||
|
while (1){
|
||||||
|
IWDG->KR = IWDG_REFRESH; // refresh watchdog
|
||||||
|
if(lastT && (Tms - lastT > 199)){
|
||||||
|
LED_off(LED0);
|
||||||
|
lastT = 0;
|
||||||
|
}
|
||||||
|
can_proc();
|
||||||
|
usb_proc();
|
||||||
|
if(CAN_get_status() == CAN_FIFO_OVERRUN){
|
||||||
|
SEND("CAN bus fifo overrun occured!\n");
|
||||||
|
sendbuf();
|
||||||
|
}
|
||||||
|
can_mesg = CAN_messagebuf_pop();
|
||||||
|
if(can_mesg && isgood(can_mesg->ID)){
|
||||||
|
LED_on(LED0);
|
||||||
|
lastT = Tms;
|
||||||
|
if(!lastT) lastT = 1;
|
||||||
|
if(ShowMsgs){ // new data in buff
|
||||||
|
IWDG->KR = IWDG_REFRESH;
|
||||||
|
len = can_mesg->length;
|
||||||
|
printu(Tms);
|
||||||
|
SEND(" #");
|
||||||
|
printuhex(can_mesg->ID);
|
||||||
|
for(ctr = 0; ctr < len; ++ctr){
|
||||||
|
SEND(" ");
|
||||||
|
printuhex(can_mesg->data[ctr]);
|
||||||
|
}
|
||||||
|
newline(); sendbuf();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if((txt = get_USB())){
|
||||||
|
IWDG->KR = IWDG_REFRESH;
|
||||||
|
cmd_parser(txt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
540
F0-nolib/usbcan_relay/proto.c
Normal file
540
F0-nolib/usbcan_relay/proto.c
Normal file
@ -0,0 +1,540 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* proto.c
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#include "can.h"
|
||||||
|
#include "hardware.h"
|
||||||
|
#include "proto.h"
|
||||||
|
#include "usb.h"
|
||||||
|
|
||||||
|
#include <string.h> // strlen
|
||||||
|
|
||||||
|
extern volatile uint8_t canerror;
|
||||||
|
|
||||||
|
uint8_t ShowMsgs = 07;
|
||||||
|
uint16_t Ignore_IDs[IGN_SIZE];
|
||||||
|
uint8_t IgnSz = 0;
|
||||||
|
static char buff[BUFSZ+1], *bptr = buff;
|
||||||
|
static uint8_t blen = 0;
|
||||||
|
|
||||||
|
void sendbuf(){
|
||||||
|
IWDG->KR = IWDG_REFRESH;
|
||||||
|
if(blen == 0) return;
|
||||||
|
*bptr = 0;
|
||||||
|
USB_sendstr(buff);
|
||||||
|
bptr = buff;
|
||||||
|
blen = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void bufputchar(char ch){
|
||||||
|
if(blen > BUFSZ-1){
|
||||||
|
sendbuf();
|
||||||
|
}
|
||||||
|
*bptr++ = ch;
|
||||||
|
++blen;
|
||||||
|
}
|
||||||
|
|
||||||
|
void addtobuf(const char *txt){
|
||||||
|
IWDG->KR = IWDG_REFRESH;
|
||||||
|
while(*txt) bufputchar(*txt++);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *omit_spaces(char *buf){
|
||||||
|
while(*buf){
|
||||||
|
if(*buf > ' ') break;
|
||||||
|
++buf;
|
||||||
|
}
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
// THERE'S NO OVERFLOW PROTECTION IN NUMBER READ PROCEDURES!
|
||||||
|
// read decimal number
|
||||||
|
static char *getdec(char *buf, uint32_t *N){
|
||||||
|
uint32_t num = 0;
|
||||||
|
while(*buf){
|
||||||
|
char c = *buf;
|
||||||
|
if(c < '0' || c > '9'){
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
num *= 10;
|
||||||
|
num += c - '0';
|
||||||
|
++buf;
|
||||||
|
}
|
||||||
|
*N = num;
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
// read hexadecimal number (without 0x prefix!)
|
||||||
|
static char *gethex(char *buf, uint32_t *N){
|
||||||
|
uint32_t num = 0;
|
||||||
|
while(*buf){
|
||||||
|
char c = *buf;
|
||||||
|
uint8_t M = 0;
|
||||||
|
if(c >= '0' && c <= '9'){
|
||||||
|
M = '0';
|
||||||
|
}else if(c >= 'A' && c <= 'F'){
|
||||||
|
M = 'A' - 10;
|
||||||
|
}else if(c >= 'a' && c <= 'f'){
|
||||||
|
M = 'a' - 10;
|
||||||
|
}
|
||||||
|
if(M){
|
||||||
|
num <<= 4;
|
||||||
|
num += c - M;
|
||||||
|
}else{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
++buf;
|
||||||
|
}
|
||||||
|
*N = num;
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
// read binary number (without 0b prefix!)
|
||||||
|
static char *getbin(char *buf, uint32_t *N){
|
||||||
|
uint32_t num = 0;
|
||||||
|
while(*buf){
|
||||||
|
char c = *buf;
|
||||||
|
if(c < '0' || c > '1'){
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
num <<= 1;
|
||||||
|
if(c == '1') num |= 1;
|
||||||
|
++buf;
|
||||||
|
}
|
||||||
|
*N = num;
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief getnum - read uint32_t from string (dec, hex or bin: 127, 0x7f, 0b1111111)
|
||||||
|
* @param buf - buffer with number and so on
|
||||||
|
* @param N - the number read
|
||||||
|
* @return pointer to first non-number symbol in buf (if it is == buf, there's no number)
|
||||||
|
*/
|
||||||
|
char *getnum(char *txt, uint32_t *N){
|
||||||
|
if(*txt == '0'){
|
||||||
|
if(txt[1] == 'x' || txt[1] == 'X') return gethex(txt+2, N);
|
||||||
|
if(txt[1] == 'b' || txt[1] == 'B') return getbin(txt+2, N);
|
||||||
|
}
|
||||||
|
return getdec(txt, N);
|
||||||
|
}
|
||||||
|
|
||||||
|
// parse `txt` to CAN_message
|
||||||
|
static CAN_message *parseCANmsg(char *txt){
|
||||||
|
static CAN_message canmsg;
|
||||||
|
//SEND("CAN command with arguments:\n");
|
||||||
|
uint32_t N;
|
||||||
|
char *n;
|
||||||
|
int ctr = -1;
|
||||||
|
canmsg.ID = 0xffff;
|
||||||
|
do{
|
||||||
|
txt = omit_spaces(txt);
|
||||||
|
n = getnum(txt, &N);
|
||||||
|
if(txt == n) break;
|
||||||
|
txt = n;
|
||||||
|
if(ctr == -1){
|
||||||
|
if(N > 0x7ff){
|
||||||
|
SEND("ID should be 11-bit number!\n");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
canmsg.ID = (uint16_t)(N&0x7ff);
|
||||||
|
//SEND("ID="); printuhex(canmsg.ID); newline();
|
||||||
|
ctr = 0;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(ctr > 7){
|
||||||
|
SEND("ONLY 8 data bytes allowed!\n");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
if(N > 0xff){
|
||||||
|
SEND("Every data portion is a byte!\n");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
canmsg.data[ctr++] = (uint8_t)(N&0xff);
|
||||||
|
//printu(N); SEND(", hex: ");
|
||||||
|
//printuhex(N); newline();
|
||||||
|
}while(1);
|
||||||
|
/*if(*n){
|
||||||
|
SEND("\nUnusefull data: ");
|
||||||
|
SEND(n);
|
||||||
|
}*/
|
||||||
|
if(canmsg.ID == 0xffff){
|
||||||
|
SEND("NO ID given, send nothing!\n");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
SEND("Message parsed OK\n");
|
||||||
|
sendbuf();
|
||||||
|
canmsg.length = (uint8_t) ctr;
|
||||||
|
return &canmsg;
|
||||||
|
}
|
||||||
|
|
||||||
|
// send command, format: ID (hex/bin/dec) data bytes (up to 8 bytes, space-delimeted)
|
||||||
|
TRUE_INLINE void sendCANcommand(char *txt){
|
||||||
|
CAN_message *msg = parseCANmsg(txt);
|
||||||
|
if(!msg) return;
|
||||||
|
uint32_t N = 1000000;
|
||||||
|
while(CAN_BUSY == can_send(msg->data, msg->length, msg->ID)){
|
||||||
|
if(--N == 0) break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TRUE_INLINE void CANini(char *txt){
|
||||||
|
txt = omit_spaces(txt);
|
||||||
|
uint32_t N;
|
||||||
|
char *n = getnum(txt, &N);
|
||||||
|
if(txt == n){
|
||||||
|
SEND("No speed given");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(N < 50){
|
||||||
|
SEND("Lowest speed is 50kbps");
|
||||||
|
return;
|
||||||
|
}else if(N > 3000){
|
||||||
|
SEND("Highest speed is 3000kbps");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
CAN_reinit((uint16_t)N);
|
||||||
|
SEND("Reinit CAN bus with speed ");
|
||||||
|
printu(N); SEND("kbps");
|
||||||
|
}
|
||||||
|
|
||||||
|
TRUE_INLINE void addIGN(char *txt){
|
||||||
|
if(IgnSz == IGN_SIZE){
|
||||||
|
MSG("Ignore buffer is full");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
txt = omit_spaces(txt);
|
||||||
|
uint32_t N;
|
||||||
|
char *n = getnum(txt, &N);
|
||||||
|
if(txt == n){
|
||||||
|
SEND("No ID given");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(N > 0x7ff){
|
||||||
|
SEND("ID should be 11-bit number!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Ignore_IDs[IgnSz++] = (uint16_t)(N & 0x7ff);
|
||||||
|
SEND("Added ID "); printu(N);
|
||||||
|
SEND("\nIgn buffer size: "); printu(IgnSz);
|
||||||
|
}
|
||||||
|
|
||||||
|
TRUE_INLINE void print_ign_buf(){
|
||||||
|
if(IgnSz == 0){
|
||||||
|
SEND("Ignore buffer is empty");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SEND("Ignored IDs:\n");
|
||||||
|
for(int i = 0; i < IgnSz; ++i){
|
||||||
|
printu(i);
|
||||||
|
SEND(": ");
|
||||||
|
printuhex(Ignore_IDs[i]);
|
||||||
|
newline();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// print ID/mask of CAN->sFilterRegister[x] half
|
||||||
|
static void printID(uint16_t FRn){
|
||||||
|
if(FRn & 0x1f) return; // trash
|
||||||
|
printuhex(FRn >> 5);
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
Can filtering: FSCx=0 (CAN->FS1R) -> 16-bit identifiers
|
||||||
|
CAN->FMR = (sb)<<8 | FINIT - init filter in starting bank sb
|
||||||
|
CAN->FFA1R FFAx = 1 -> FIFO1, 0 -> FIFO0
|
||||||
|
CAN->FA1R FACTx=1 - filter active
|
||||||
|
MASK: FBMx=0 (CAN->FM1R), two filters (n in FR1 and n+1 in FR2)
|
||||||
|
ID: CAN->sFilterRegister[x].FRn[0..15]
|
||||||
|
MASK: CAN->sFilterRegister[x].FRn[16..31]
|
||||||
|
FR bits: STID[10:0] RTR IDE EXID[17:15]
|
||||||
|
LIST: FBMx=1, four filters (n&n+1 in FR1, n+2&n+3 in FR2)
|
||||||
|
IDn: CAN->sFilterRegister[x].FRn[0..15]
|
||||||
|
IDn+1: CAN->sFilterRegister[x].FRn[16..31]
|
||||||
|
*/
|
||||||
|
TRUE_INLINE void list_filters(){
|
||||||
|
uint32_t fa = CAN->FA1R, ctr = 0, mask = 1;
|
||||||
|
while(fa){
|
||||||
|
if(fa & 1){
|
||||||
|
SEND("Filter "); printu(ctr); SEND(", FIFO");
|
||||||
|
if(CAN->FFA1R & mask) SEND("1");
|
||||||
|
else SEND("0");
|
||||||
|
SEND(" in ");
|
||||||
|
if(CAN->FM1R & mask){ // up to 4 filters in LIST mode
|
||||||
|
SEND("LIST mode, IDs: ");
|
||||||
|
printID(CAN->sFilterRegister[ctr].FR1 & 0xffff);
|
||||||
|
SEND(" ");
|
||||||
|
printID(CAN->sFilterRegister[ctr].FR1 >> 16);
|
||||||
|
SEND(" ");
|
||||||
|
printID(CAN->sFilterRegister[ctr].FR2 & 0xffff);
|
||||||
|
SEND(" ");
|
||||||
|
printID(CAN->sFilterRegister[ctr].FR2 >> 16);
|
||||||
|
}else{ // up to 2 filters in MASK mode
|
||||||
|
SEND("MASK mode: ");
|
||||||
|
if(!(CAN->sFilterRegister[ctr].FR1&0x1f)){
|
||||||
|
SEND("ID="); printID(CAN->sFilterRegister[ctr].FR1 & 0xffff);
|
||||||
|
SEND(", MASK="); printID(CAN->sFilterRegister[ctr].FR1 >> 16);
|
||||||
|
SEND(" ");
|
||||||
|
}
|
||||||
|
if(!(CAN->sFilterRegister[ctr].FR2&0x1f)){
|
||||||
|
SEND("ID="); printID(CAN->sFilterRegister[ctr].FR2 & 0xffff);
|
||||||
|
SEND(", MASK="); printID(CAN->sFilterRegister[ctr].FR2 >> 16);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
newline();
|
||||||
|
}
|
||||||
|
fa >>= 1;
|
||||||
|
++ctr;
|
||||||
|
mask <<= 1;
|
||||||
|
}
|
||||||
|
sendbuf();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief add_filter - add/modify filter
|
||||||
|
* @param str - string in format "bank# FIFO# mode num0 .. num3"
|
||||||
|
* where bank# - 0..27
|
||||||
|
* if there's nothing after bank# - delete filter
|
||||||
|
* FIFO# - 0,1
|
||||||
|
* mode - 'I' for ID, 'M' for mask
|
||||||
|
* num0..num3 - IDs in ID mode, ID/MASK for mask mode
|
||||||
|
*/
|
||||||
|
static void add_filter(char *str){
|
||||||
|
uint32_t N;
|
||||||
|
str = omit_spaces(str);
|
||||||
|
char *n = getnum(str, &N);
|
||||||
|
if(n == str){
|
||||||
|
SEND("No bank# given");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(N > STM32F0FBANKNO-1){
|
||||||
|
SEND("bank# > 27");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
uint8_t bankno = (uint8_t)N;
|
||||||
|
str = omit_spaces(n);
|
||||||
|
if(!*str){ // deactivate filter
|
||||||
|
SEND("Deactivate filters in bank ");
|
||||||
|
printu(bankno);
|
||||||
|
CAN->FMR = CAN_FMR_FINIT;
|
||||||
|
CAN->FA1R &= ~(1<<bankno);
|
||||||
|
CAN->FMR &=~ CAN_FMR_FINIT;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
uint8_t fifono = 0;
|
||||||
|
if(*str == '1') fifono = 1;
|
||||||
|
else if(*str != '0'){
|
||||||
|
SEND("FIFO# is 0 or 1");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
str = omit_spaces(str + 1);
|
||||||
|
char c = *str;
|
||||||
|
uint8_t mode = 0; // ID
|
||||||
|
if(c == 'M' || c == 'm') mode = 1;
|
||||||
|
else if(c != 'I' && c != 'i'){
|
||||||
|
SEND("mode is 'M/m' for MASK and 'I/i' for IDLIST");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
str = omit_spaces(str + 1);
|
||||||
|
uint32_t filters[4];
|
||||||
|
uint32_t nfilt;
|
||||||
|
for(nfilt = 0; nfilt < 4; ++nfilt){
|
||||||
|
n = getnum(str, &N);
|
||||||
|
if(n == str) break;
|
||||||
|
filters[nfilt] = N;
|
||||||
|
str = omit_spaces(n);
|
||||||
|
}
|
||||||
|
if(nfilt == 0){
|
||||||
|
SEND("You should add at least one filter!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(mode && (nfilt&1)){
|
||||||
|
SEND("In MASK mode you should point pairs of ID/MASK");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
CAN->FMR = CAN_FMR_FINIT;
|
||||||
|
uint32_t mask = 1<<bankno;
|
||||||
|
CAN->FA1R |= mask; // activate given filter
|
||||||
|
if(fifono) CAN->FFA1R |= mask; // set FIFO number
|
||||||
|
else CAN->FFA1R &= ~mask;
|
||||||
|
if(mode) CAN->FM1R &= ~mask; // MASK
|
||||||
|
else CAN->FM1R |= mask; // LIST
|
||||||
|
uint32_t F1 = (0x8f<<16);
|
||||||
|
uint32_t F2 = (0x8f<<16);
|
||||||
|
// reset filter registers to wrong value
|
||||||
|
CAN->sFilterRegister[bankno].FR1 = (0x8f<<16) | 0x8f;
|
||||||
|
CAN->sFilterRegister[bankno].FR2 = (0x8f<<16) | 0x8f;
|
||||||
|
switch(nfilt){
|
||||||
|
case 4:
|
||||||
|
F2 = filters[3] << 21;
|
||||||
|
// fallthrough
|
||||||
|
case 3:
|
||||||
|
CAN->sFilterRegister[bankno].FR2 = (F2 & 0xffff0000) | (filters[2] << 5);
|
||||||
|
// fallthrough
|
||||||
|
case 2:
|
||||||
|
F1 = filters[1] << 21;
|
||||||
|
// fallthrough
|
||||||
|
case 1:
|
||||||
|
CAN->sFilterRegister[bankno].FR1 = (F1 & 0xffff0000) | (filters[0] << 5);
|
||||||
|
}
|
||||||
|
CAN->FMR &=~ CAN_FMR_FINIT;
|
||||||
|
SEND("Added filter with ");
|
||||||
|
printu(nfilt); SEND(" parameters");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief cmd_parser - command parsing
|
||||||
|
* @param txt - buffer with commands & data
|
||||||
|
* @param isUSB - == 1 if data got from USB
|
||||||
|
*/
|
||||||
|
void cmd_parser(char *txt){
|
||||||
|
char _1st = txt[0];
|
||||||
|
/*
|
||||||
|
* parse long commands here
|
||||||
|
*/
|
||||||
|
switch(_1st){
|
||||||
|
case 'a':
|
||||||
|
addIGN(txt + 1);
|
||||||
|
goto eof;
|
||||||
|
break;
|
||||||
|
case 'b':
|
||||||
|
CANini(txt + 1);
|
||||||
|
goto eof;
|
||||||
|
break;
|
||||||
|
case 'f':
|
||||||
|
add_filter(txt + 1);
|
||||||
|
goto eof;
|
||||||
|
break;
|
||||||
|
case 'F':
|
||||||
|
set_flood(parseCANmsg(txt + 1));
|
||||||
|
goto eof;
|
||||||
|
break;
|
||||||
|
case 's':
|
||||||
|
case 'S':
|
||||||
|
sendCANcommand(txt + 1);
|
||||||
|
goto eof;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(txt[1] != '\n') *txt = '?'; // help for wrong message length
|
||||||
|
switch(_1st){
|
||||||
|
case 'd':
|
||||||
|
IgnSz = 0;
|
||||||
|
break;
|
||||||
|
case 'D':
|
||||||
|
SEND("Go into DFU mode\n");
|
||||||
|
sendbuf();
|
||||||
|
Jump2Boot();
|
||||||
|
break;
|
||||||
|
case 'I':
|
||||||
|
CAN_reinit(0);
|
||||||
|
break;
|
||||||
|
case 'l':
|
||||||
|
list_filters();
|
||||||
|
break;
|
||||||
|
case 'o':
|
||||||
|
ledsON = 0;
|
||||||
|
LED_off(LED0);
|
||||||
|
LED_off(LED1);
|
||||||
|
break;
|
||||||
|
case 'O':
|
||||||
|
ledsON = 1;
|
||||||
|
break;
|
||||||
|
case 'p':
|
||||||
|
print_ign_buf();
|
||||||
|
break;
|
||||||
|
case 'P':
|
||||||
|
ShowMsgs = !ShowMsgs;
|
||||||
|
if(ShowMsgs) SEND("Resume\n");
|
||||||
|
else SEND("Pause\n");
|
||||||
|
break;
|
||||||
|
case 'R':
|
||||||
|
SEND("Soft reset\n");
|
||||||
|
sendbuf();
|
||||||
|
pause_ms(5); // a little pause to transmit data
|
||||||
|
NVIC_SystemReset();
|
||||||
|
break;
|
||||||
|
case 'T':
|
||||||
|
SEND("Time (ms): ");
|
||||||
|
printu(Tms);
|
||||||
|
newline();
|
||||||
|
break;
|
||||||
|
default: // help
|
||||||
|
SEND(
|
||||||
|
"'a' - add ID to ignore list (max 10 IDs)\n"
|
||||||
|
"'b' - reinit CAN with given baudrate\n"
|
||||||
|
"'d' - delete ignore list\n"
|
||||||
|
"'D' - activate DFU mode\n"
|
||||||
|
"'f' - add/delete filter, format: bank# FIFO# mode(M/I) num0 [num1 [num2 [num3]]]\n"
|
||||||
|
"'F' - send/clear flood message: F ID byte0 ... byteN\n"
|
||||||
|
"'I' - reinit CAN\n"
|
||||||
|
"'l' - list all active filters\n"
|
||||||
|
"'o' - turn LEDs OFF\n"
|
||||||
|
"'O' - turn LEDs ON\n"
|
||||||
|
"'p' - print ignore buffer\n"
|
||||||
|
"'P' - pause/resume in packets displaying\n"
|
||||||
|
"'R' - software reset\n"
|
||||||
|
"'s/S' - send data over CAN: s ID byte0 .. byteN\n"
|
||||||
|
"'T' - get time from start (ms)\n"
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
eof:
|
||||||
|
newline();
|
||||||
|
sendbuf();
|
||||||
|
}
|
||||||
|
|
||||||
|
// print 32bit unsigned int
|
||||||
|
void printu(uint32_t val){
|
||||||
|
char buf[11], *bufptr = &buf[10];
|
||||||
|
*bufptr = 0;
|
||||||
|
if(!val){
|
||||||
|
*(--bufptr) = '0';
|
||||||
|
}else{
|
||||||
|
while(val){
|
||||||
|
*(--bufptr) = val % 10 + '0';
|
||||||
|
val /= 10;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
addtobuf(bufptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
// print 32bit unsigned int as hex
|
||||||
|
void printuhex(uint32_t val){
|
||||||
|
addtobuf("0x");
|
||||||
|
uint8_t *ptr = (uint8_t*)&val + 3;
|
||||||
|
int8_t i, j, z=1;
|
||||||
|
for(i = 0; i < 4; ++i, --ptr){
|
||||||
|
if(*ptr == 0){ // omit leading zeros
|
||||||
|
if(i == 3) z = 0;
|
||||||
|
if(z) continue;
|
||||||
|
}
|
||||||
|
else z = 0;
|
||||||
|
for(j = 1; j > -1; --j){
|
||||||
|
uint8_t half = (*ptr >> (4*j)) & 0x0f;
|
||||||
|
if(half < 10) bufputchar(half + '0');
|
||||||
|
else bufputchar(half - 10 + 'a');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// check Ignore_IDs & return 1 if ID isn't in list
|
||||||
|
uint8_t isgood(uint16_t ID){
|
||||||
|
for(int i = 0; i < IgnSz; ++i)
|
||||||
|
if(Ignore_IDs[i] == ID) return 0;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
62
F0-nolib/usbcan_relay/proto.h
Normal file
62
F0-nolib/usbcan_relay/proto.h
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* proto.h
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#pragma once
|
||||||
|
#ifndef __PROTO_H__
|
||||||
|
#define __PROTO_H__
|
||||||
|
|
||||||
|
#include "stm32f0.h"
|
||||||
|
#include "hardware.h"
|
||||||
|
|
||||||
|
#define BUFSZ (64)
|
||||||
|
|
||||||
|
// macro for static strings
|
||||||
|
#define SEND(str) do{addtobuf(str);}while(0)
|
||||||
|
|
||||||
|
#ifdef EBUG
|
||||||
|
#define MSG(str) do{addtobuf(__FILE__ " (L" STR(__LINE__) "): " str);}while(0)
|
||||||
|
#else
|
||||||
|
#define MSG(str)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define newline() do{bufputchar('\n');}while(0)
|
||||||
|
// newline with buffer sending over USART
|
||||||
|
#define NL() do{bufputchar('\n'); sendbuf();}while(0)
|
||||||
|
|
||||||
|
#define IGN_SIZE 10
|
||||||
|
extern uint16_t Ignore_IDs[IGN_SIZE];
|
||||||
|
extern uint8_t IgnSz;
|
||||||
|
extern uint8_t ShowMsgs;
|
||||||
|
|
||||||
|
void cmd_parser(char *buf);
|
||||||
|
void addtobuf(const char *txt);
|
||||||
|
void bufputchar(char ch);
|
||||||
|
void printu(uint32_t val);
|
||||||
|
void printuhex(uint32_t val);
|
||||||
|
void sendbuf();
|
||||||
|
|
||||||
|
char *omit_spaces(char *buf);
|
||||||
|
char *getnum(char *buf, uint32_t *N);
|
||||||
|
|
||||||
|
uint8_t isgood(uint16_t ID);
|
||||||
|
|
||||||
|
#endif // __PROTO_H__
|
||||||
180
F0-nolib/usbcan_relay/usb.c
Normal file
180
F0-nolib/usbcan_relay/usb.c
Normal file
@ -0,0 +1,180 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* usb.c - base functions for different USB types
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "usb.h"
|
||||||
|
#include "usb_lib.h"
|
||||||
|
|
||||||
|
static volatile uint8_t tx_succesfull = 1;
|
||||||
|
static volatile uint8_t rxNE = 0;
|
||||||
|
|
||||||
|
// interrupt IN handler (never used?)
|
||||||
|
static void EP1_Handler(){
|
||||||
|
uint16_t epstatus = KEEP_DTOG(USB->EPnR[1]);
|
||||||
|
if(RX_FLAG(epstatus)) epstatus = (epstatus & ~USB_EPnR_STAT_TX) ^ USB_EPnR_STAT_RX; // set valid RX
|
||||||
|
else epstatus = epstatus & ~(USB_EPnR_STAT_TX|USB_EPnR_STAT_RX);
|
||||||
|
// clear CTR
|
||||||
|
epstatus = (epstatus & ~(USB_EPnR_CTR_RX|USB_EPnR_CTR_TX));
|
||||||
|
USB->EPnR[1] = epstatus;
|
||||||
|
}
|
||||||
|
|
||||||
|
// data IN/OUT handlers
|
||||||
|
static void transmit_Handler(){ // EP3IN
|
||||||
|
tx_succesfull = 1;
|
||||||
|
uint16_t epstatus = KEEP_DTOG_STAT(USB->EPnR[3]);
|
||||||
|
// clear CTR keep DTOGs & STATs
|
||||||
|
USB->EPnR[3] = (epstatus & ~(USB_EPnR_CTR_TX)); // clear TX ctr
|
||||||
|
}
|
||||||
|
|
||||||
|
static void receive_Handler(){ // EP2OUT
|
||||||
|
rxNE = 1;
|
||||||
|
uint16_t epstatus = KEEP_DTOG_STAT(USB->EPnR[2]);
|
||||||
|
USB->EPnR[2] = (epstatus & ~(USB_EPnR_CTR_RX)); // clear RX ctr
|
||||||
|
}
|
||||||
|
|
||||||
|
void USB_setup(){
|
||||||
|
RCC->APB1ENR |= RCC_APB1ENR_CRSEN | RCC_APB1ENR_USBEN; // enable CRS (hsi48 sync) & USB
|
||||||
|
RCC->CFGR3 &= ~RCC_CFGR3_USBSW; // reset USB
|
||||||
|
RCC->CR2 |= RCC_CR2_HSI48ON; // turn ON HSI48
|
||||||
|
uint32_t tmout = 16000000;
|
||||||
|
while(!(RCC->CR2 & RCC_CR2_HSI48RDY)){if(--tmout == 0) break;}
|
||||||
|
FLASH->ACR = FLASH_ACR_PRFTBE | FLASH_ACR_LATENCY;
|
||||||
|
CRS->CFGR &= ~CRS_CFGR_SYNCSRC;
|
||||||
|
CRS->CFGR |= CRS_CFGR_SYNCSRC_1; // USB SOF selected as sync source
|
||||||
|
CRS->CR |= CRS_CR_AUTOTRIMEN; // enable auto trim
|
||||||
|
CRS->CR |= CRS_CR_CEN; // enable freq counter & block CRS->CFGR as read-only
|
||||||
|
RCC->CFGR |= RCC_CFGR_SW;
|
||||||
|
// allow RESET and CTRM interrupts
|
||||||
|
USB->CNTR = USB_CNTR_RESETM | USB_CNTR_WKUPM;
|
||||||
|
// clear flags
|
||||||
|
USB->ISTR = 0;
|
||||||
|
// and activate pullup
|
||||||
|
USB->BCDR |= USB_BCDR_DPPU;
|
||||||
|
NVIC_EnableIRQ(USB_IRQn);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int usbwr(const uint8_t *buf, uint16_t l){
|
||||||
|
uint32_t ctra = 1000000;
|
||||||
|
while(--ctra && tx_succesfull == 0){
|
||||||
|
IWDG->KR = IWDG_REFRESH;
|
||||||
|
}
|
||||||
|
tx_succesfull = 0;
|
||||||
|
EP_Write(3, buf, l);
|
||||||
|
ctra = 1000000;
|
||||||
|
while(--ctra && tx_succesfull == 0){
|
||||||
|
IWDG->KR = IWDG_REFRESH;
|
||||||
|
}
|
||||||
|
if(tx_succesfull == 0){usbON = 0; return 1;} // usb is OFF?
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t usbbuff[USB_TXBUFSZ-1]; // temporary buffer (63 - to prevent need of ZLP)
|
||||||
|
static uint8_t buflen = 0; // amount of symbols in usbbuff
|
||||||
|
|
||||||
|
// send next up to 63 bytes of data in usbbuff
|
||||||
|
static void send_next(){
|
||||||
|
if(!buflen || !tx_succesfull) return;
|
||||||
|
tx_succesfull = 0;
|
||||||
|
EP_Write(3, usbbuff, buflen);
|
||||||
|
buflen = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// unblocking sending - just fill a buffer
|
||||||
|
void USB_send(const uint8_t *buf, uint16_t len){
|
||||||
|
if(!usbON || !len) return;
|
||||||
|
if(len > USB_TXBUFSZ-1 - buflen){
|
||||||
|
usbwr(usbbuff, buflen);
|
||||||
|
buflen = 0;
|
||||||
|
}
|
||||||
|
if(len > USB_TXBUFSZ-1){
|
||||||
|
USB_send_blk(buf, len);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
while(len--) usbbuff[buflen++] = *buf++;
|
||||||
|
}
|
||||||
|
|
||||||
|
// send zero-terminated string
|
||||||
|
void USB_sendstr(const char *str){
|
||||||
|
uint16_t l = 0;
|
||||||
|
const char *ptr = str;
|
||||||
|
while(*ptr++) ++l;
|
||||||
|
USB_send((uint8_t*)str, l);
|
||||||
|
}
|
||||||
|
|
||||||
|
// blocking sending
|
||||||
|
void USB_send_blk(const uint8_t *buf, uint16_t len){
|
||||||
|
if(!usbON || !len) return; // USB disconnected
|
||||||
|
if(buflen){
|
||||||
|
usbwr(usbbuff, buflen);
|
||||||
|
buflen = 0;
|
||||||
|
}
|
||||||
|
int needzlp = 0;
|
||||||
|
while(len){
|
||||||
|
if(len == USB_TXBUFSZ) needzlp = 1;
|
||||||
|
uint16_t s = (len > USB_TXBUFSZ) ? USB_TXBUFSZ : len;
|
||||||
|
if(usbwr(buf, s)) return;
|
||||||
|
len -= s;
|
||||||
|
buf += s;
|
||||||
|
}
|
||||||
|
if(needzlp){
|
||||||
|
usbwr(NULL, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void usb_proc(){
|
||||||
|
switch(USB_Dev.USB_Status){
|
||||||
|
case USB_STATE_CONFIGURED:
|
||||||
|
// make new BULK endpoint
|
||||||
|
// Buffer have 1024 bytes, but last 256 we use for CAN bus (30.2 of RM: USB main features)
|
||||||
|
EP_Init(1, EP_TYPE_INTERRUPT, USB_EP1BUFSZ, 0, EP1_Handler); // IN1 - transmit
|
||||||
|
EP_Init(2, EP_TYPE_BULK, 0, USB_RXBUFSZ, receive_Handler); // OUT2 - receive data
|
||||||
|
EP_Init(3, EP_TYPE_BULK, USB_TXBUFSZ, 0, transmit_Handler); // IN3 - transmit data
|
||||||
|
USB_Dev.USB_Status = USB_STATE_CONNECTED;
|
||||||
|
break;
|
||||||
|
case USB_STATE_DEFAULT:
|
||||||
|
case USB_STATE_ADDRESSED:
|
||||||
|
if(usbON){
|
||||||
|
usbON = 0;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default: // USB_STATE_CONNECTED - send next data portion
|
||||||
|
if(!usbON) return;
|
||||||
|
send_next();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_receive
|
||||||
|
* @param buf (i) - buffer[64] for received data
|
||||||
|
* @return amount of received bytes
|
||||||
|
*/
|
||||||
|
uint8_t USB_receive(uint8_t *buf){
|
||||||
|
if(!usbON || !rxNE) return 0;
|
||||||
|
uint8_t sz = EP_Read(2, buf);
|
||||||
|
uint16_t epstatus = KEEP_DTOG(USB->EPnR[2]);
|
||||||
|
// keep stat_tx & set ACK rx
|
||||||
|
USB->EPnR[2] = (epstatus & ~(USB_EPnR_STAT_TX)) ^ USB_EPnR_STAT_RX;
|
||||||
|
rxNE = 0;
|
||||||
|
return sz;
|
||||||
|
}
|
||||||
|
|
||||||
41
F0-nolib/usbcan_relay/usb.h
Normal file
41
F0-nolib/usbcan_relay/usb.h
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* usb.h
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#pragma once
|
||||||
|
#ifndef __USB_H__
|
||||||
|
#define __USB_H__
|
||||||
|
|
||||||
|
#include "hardware.h"
|
||||||
|
|
||||||
|
#define BUFFSIZE (64)
|
||||||
|
|
||||||
|
// send string with constant length
|
||||||
|
#define USND(str) do{USB_send((uint8_t*)str, sizeof(str)-1);}while(0)
|
||||||
|
|
||||||
|
void USB_setup();
|
||||||
|
void usb_proc();
|
||||||
|
void USB_send(const uint8_t *buf, uint16_t len);
|
||||||
|
void USB_sendstr(const char *str);
|
||||||
|
void USB_send_blk(const uint8_t *buf, uint16_t len);
|
||||||
|
uint8_t USB_receive(uint8_t *buf);
|
||||||
|
|
||||||
|
#endif // __USB_H__
|
||||||
104
F0-nolib/usbcan_relay/usb_defs.h
Normal file
104
F0-nolib/usbcan_relay/usb_defs.h
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* usb_defs.h
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#ifndef __USB_DEFS_H__
|
||||||
|
#define __USB_DEFS_H__
|
||||||
|
|
||||||
|
#include <stm32f0.h>
|
||||||
|
|
||||||
|
// max endpoints number
|
||||||
|
#define STM32ENDPOINTS 8
|
||||||
|
/**
|
||||||
|
* Buffers size definition
|
||||||
|
**/
|
||||||
|
// !!! when working with CAN bus change USB_BTABLE_SIZE to 768 !!!
|
||||||
|
#define USB_BTABLE_SIZE 768
|
||||||
|
// for USB FS EP0 buffers are from 8 to 64 bytes long (64 for PL2303)
|
||||||
|
#define USB_EP0_BUFSZ 64
|
||||||
|
// USB transmit buffer size (64 for PL2303)
|
||||||
|
#define USB_TXBUFSZ 64
|
||||||
|
// USB receive buffer size (64 for PL2303)
|
||||||
|
#define USB_RXBUFSZ 64
|
||||||
|
// EP1 - interrupt - buffer size
|
||||||
|
#define USB_EP1BUFSZ 8
|
||||||
|
|
||||||
|
#define USB_BTABLE_BASE 0x40006000
|
||||||
|
|
||||||
|
#ifdef USB_BTABLE
|
||||||
|
#undef USB_BTABLE
|
||||||
|
#endif
|
||||||
|
#define USB_BTABLE ((USB_BtableDef *)(USB_BTABLE_BASE))
|
||||||
|
#define USB_ISTR_EPID 0x0000000F
|
||||||
|
#define USB_FNR_LSOF_0 0x00000800
|
||||||
|
#define USB_FNR_lSOF_1 0x00001000
|
||||||
|
#define USB_LPMCSR_BESL_0 0x00000010
|
||||||
|
#define USB_LPMCSR_BESL_1 0x00000020
|
||||||
|
#define USB_LPMCSR_BESL_2 0x00000040
|
||||||
|
#define USB_LPMCSR_BESL_3 0x00000080
|
||||||
|
#define USB_EPnR_CTR_RX 0x00008000
|
||||||
|
#define USB_EPnR_DTOG_RX 0x00004000
|
||||||
|
#define USB_EPnR_STAT_RX 0x00003000
|
||||||
|
#define USB_EPnR_STAT_RX_0 0x00001000
|
||||||
|
#define USB_EPnR_STAT_RX_1 0x00002000
|
||||||
|
#define USB_EPnR_SETUP 0x00000800
|
||||||
|
#define USB_EPnR_EP_TYPE 0x00000600
|
||||||
|
#define USB_EPnR_EP_TYPE_0 0x00000200
|
||||||
|
#define USB_EPnR_EP_TYPE_1 0x00000400
|
||||||
|
#define USB_EPnR_EP_KIND 0x00000100
|
||||||
|
#define USB_EPnR_CTR_TX 0x00000080
|
||||||
|
#define USB_EPnR_DTOG_TX 0x00000040
|
||||||
|
#define USB_EPnR_STAT_TX 0x00000030
|
||||||
|
#define USB_EPnR_STAT_TX_0 0x00000010
|
||||||
|
#define USB_EPnR_STAT_TX_1 0x00000020
|
||||||
|
#define USB_EPnR_EA 0x0000000F
|
||||||
|
#define USB_COUNTn_RX_BLSIZE 0x00008000
|
||||||
|
#define USB_COUNTn_NUM_BLOCK 0x00007C00
|
||||||
|
#define USB_COUNTn_RX 0x0000003F
|
||||||
|
|
||||||
|
#define USB_TypeDef USB_TypeDef_custom
|
||||||
|
|
||||||
|
typedef struct{
|
||||||
|
__IO uint32_t EPnR[STM32ENDPOINTS];
|
||||||
|
__IO uint32_t RESERVED[STM32ENDPOINTS];
|
||||||
|
__IO uint32_t CNTR;
|
||||||
|
__IO uint32_t ISTR;
|
||||||
|
__IO uint32_t FNR;
|
||||||
|
__IO uint32_t DADDR;
|
||||||
|
__IO uint32_t BTABLE;
|
||||||
|
__IO uint32_t LPMCSR;
|
||||||
|
__IO uint32_t BCDR;
|
||||||
|
} USB_TypeDef;
|
||||||
|
|
||||||
|
typedef struct{
|
||||||
|
__IO uint16_t USB_ADDR_TX;
|
||||||
|
__IO uint16_t USB_COUNT_TX;
|
||||||
|
__IO uint16_t USB_ADDR_RX;
|
||||||
|
__IO uint16_t USB_COUNT_RX;
|
||||||
|
} USB_EPDATA_TypeDef;
|
||||||
|
|
||||||
|
typedef struct{
|
||||||
|
__IO USB_EPDATA_TypeDef EP[STM32ENDPOINTS];
|
||||||
|
} USB_BtableDef;
|
||||||
|
|
||||||
|
#endif // __USB_DEFS_H__
|
||||||
473
F0-nolib/usbcan_relay/usb_lib.c
Normal file
473
F0-nolib/usbcan_relay/usb_lib.c
Normal file
@ -0,0 +1,473 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* usb_lib.c
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include "usb_lib.h"
|
||||||
|
|
||||||
|
ep_t endpoints[STM32ENDPOINTS];
|
||||||
|
|
||||||
|
usb_dev_t USB_Dev;
|
||||||
|
uint8_t usbON = 0;
|
||||||
|
static usb_LineCoding lineCoding = {115200, 0, 0, 8};
|
||||||
|
static config_pack_t setup_packet;
|
||||||
|
static uint8_t ep0databuf[EP0DATABUF_SIZE];
|
||||||
|
static uint8_t ep0dbuflen = 0;
|
||||||
|
|
||||||
|
usb_LineCoding getLineCoding(){return lineCoding;}
|
||||||
|
|
||||||
|
// definition of parts common for USB_DeviceDescriptor & USB_DeviceQualifierDescriptor
|
||||||
|
#define bcdUSB_L 0x10
|
||||||
|
#define bcdUSB_H 0x01
|
||||||
|
#define bDeviceClass 0
|
||||||
|
#define bDeviceSubClass 0
|
||||||
|
#define bDeviceProtocol 0
|
||||||
|
#define bNumConfigurations 1
|
||||||
|
|
||||||
|
static const uint8_t USB_DeviceDescriptor[] = {
|
||||||
|
18, // bLength
|
||||||
|
0x01, // bDescriptorType - Device descriptor
|
||||||
|
bcdUSB_L, // bcdUSB_L - 1.10
|
||||||
|
bcdUSB_H, // bcdUSB_H
|
||||||
|
bDeviceClass, // bDeviceClass - USB_COMM
|
||||||
|
bDeviceSubClass, // bDeviceSubClass
|
||||||
|
bDeviceProtocol, // bDeviceProtocol
|
||||||
|
USB_EP0_BUFSZ, // bMaxPacketSize
|
||||||
|
0x7b, // idVendor_L PL2303: VID=0x067b, PID=0x2303
|
||||||
|
0x06, // idVendor_H
|
||||||
|
0x03, // idProduct_L
|
||||||
|
0x23, // idProduct_H
|
||||||
|
0x00, // bcdDevice_Ver_L
|
||||||
|
0x03, // bcdDevice_Ver_H
|
||||||
|
0x01, // iManufacturer
|
||||||
|
0x02, // iProduct
|
||||||
|
0x00, // iSerialNumber
|
||||||
|
bNumConfigurations // bNumConfigurations
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t USB_DeviceQualifierDescriptor[] = {
|
||||||
|
10, //bLength
|
||||||
|
0x06, // bDescriptorType - Device qualifier
|
||||||
|
bcdUSB_L, // bcdUSB_L
|
||||||
|
bcdUSB_H, // bcdUSB_H
|
||||||
|
bDeviceClass, // bDeviceClass
|
||||||
|
bDeviceSubClass, // bDeviceSubClass
|
||||||
|
bDeviceProtocol, // bDeviceProtocol
|
||||||
|
USB_EP0_BUFSZ, // bMaxPacketSize0
|
||||||
|
bNumConfigurations, // bNumConfigurations
|
||||||
|
0x00 // Reserved
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t USB_ConfigDescriptor[] = {
|
||||||
|
/*Configuration Descriptor*/
|
||||||
|
0x09, /* bLength: Configuration Descriptor size */
|
||||||
|
0x02, /* bDescriptorType: Configuration */
|
||||||
|
39, /* wTotalLength:no of returned bytes */
|
||||||
|
0x00,
|
||||||
|
0x01, /* bNumInterfaces: 1 interface */
|
||||||
|
0x01, /* bConfigurationValue: Configuration value */
|
||||||
|
0x00, /* iConfiguration: Index of string descriptor describing the configuration */
|
||||||
|
0xa0, /* bmAttributes - Bus powered, Remote wakeup */
|
||||||
|
0x32, /* MaxPower 100 mA */
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
/*Interface Descriptor */
|
||||||
|
0x09, /* bLength: Interface Descriptor size */
|
||||||
|
0x04, /* bDescriptorType: Interface */
|
||||||
|
0x00, /* bInterfaceNumber: Number of Interface */
|
||||||
|
0x00, /* bAlternateSetting: Alternate setting */
|
||||||
|
0x03, /* bNumEndpoints: 3 endpoints used */
|
||||||
|
0xff, /* bInterfaceClass */
|
||||||
|
0x00, /* bInterfaceSubClass */
|
||||||
|
0x00, /* bInterfaceProtocol */
|
||||||
|
0x00, /* iInterface: */
|
||||||
|
///////////////////////////////////////////////////
|
||||||
|
/*Endpoint 1 Descriptor*/
|
||||||
|
0x07, /* bLength: Endpoint Descriptor size */
|
||||||
|
0x05, /* bDescriptorType: Endpoint */
|
||||||
|
0x81, /* bEndpointAddress IN1 */
|
||||||
|
0x03, /* bmAttributes: Interrupt */
|
||||||
|
0x0a, /* wMaxPacketSize LO: */
|
||||||
|
0x00, /* wMaxPacketSize HI: */
|
||||||
|
0x01, /* bInterval: */
|
||||||
|
|
||||||
|
/*Endpoint OUT2 Descriptor*/
|
||||||
|
0x07, /* bLength: Endpoint Descriptor size */
|
||||||
|
0x05, /* bDescriptorType: Endpoint */
|
||||||
|
0x02, /* bEndpointAddress: OUT2 */
|
||||||
|
0x02, /* bmAttributes: Bulk */
|
||||||
|
(USB_RXBUFSZ & 0xff), /* wMaxPacketSize: 64 */
|
||||||
|
(USB_RXBUFSZ >> 8),
|
||||||
|
0x00, /* bInterval: ignore for Bulk transfer */
|
||||||
|
|
||||||
|
/*Endpoint IN3 Descriptor*/
|
||||||
|
0x07, /* bLength: Endpoint Descriptor size */
|
||||||
|
0x05, /* bDescriptorType: Endpoint */
|
||||||
|
0x83, /* bEndpointAddress IN3 */
|
||||||
|
0x02, /* bmAttributes: Bulk */
|
||||||
|
(USB_TXBUFSZ & 0xff), /* wMaxPacketSize: 64 */
|
||||||
|
(USB_TXBUFSZ >> 8),
|
||||||
|
0x00, /* bInterval: ignore for Bulk transfer */
|
||||||
|
};
|
||||||
|
|
||||||
|
_USB_LANG_ID_(USB_StringLangDescriptor, LANG_US);
|
||||||
|
// these descriptors are not used in PL2303 emulator!
|
||||||
|
_USB_STRING_(USB_StringSerialDescriptor, u"0");
|
||||||
|
_USB_STRING_(USB_StringManufacturingDescriptor, u"Prolific Technology Inc.");
|
||||||
|
_USB_STRING_(USB_StringProdDescriptor, u"USB-Serial Controller");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* default handlers
|
||||||
|
*/
|
||||||
|
// SET_LINE_CODING
|
||||||
|
void WEAK linecoding_handler(usb_LineCoding __attribute__((unused)) *lc){
|
||||||
|
}
|
||||||
|
|
||||||
|
// SET_CONTROL_LINE_STATE
|
||||||
|
void WEAK clstate_handler(uint16_t __attribute__((unused)) val){
|
||||||
|
}
|
||||||
|
|
||||||
|
// SEND_BREAK
|
||||||
|
void WEAK break_handler(){
|
||||||
|
}
|
||||||
|
|
||||||
|
// handler of vendor requests
|
||||||
|
void WEAK vendor_handler(config_pack_t *packet){
|
||||||
|
if(packet->bmRequestType & 0x80){ // read
|
||||||
|
uint8_t c;
|
||||||
|
switch(packet->wValue){
|
||||||
|
case 0x8484:
|
||||||
|
c = 2;
|
||||||
|
break;
|
||||||
|
case 0x0080:
|
||||||
|
c = 1;
|
||||||
|
break;
|
||||||
|
case 0x8686:
|
||||||
|
c = 0xaa;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
c = 0;
|
||||||
|
}
|
||||||
|
EP_WriteIRQ(0, &c, 1);
|
||||||
|
}else{ // write ZLP
|
||||||
|
EP_WriteIRQ(0, (uint8_t *)0, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void wr0(const uint8_t *buf, uint16_t size){
|
||||||
|
if(setup_packet.wLength < size) size = setup_packet.wLength; // shortened request
|
||||||
|
if(size < endpoints[0].txbufsz){
|
||||||
|
EP_WriteIRQ(0, buf, size);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
while(size){
|
||||||
|
uint16_t l = size;
|
||||||
|
if(l > endpoints[0].txbufsz) l = endpoints[0].txbufsz;
|
||||||
|
EP_WriteIRQ(0, buf, l);
|
||||||
|
buf += l;
|
||||||
|
size -= l;
|
||||||
|
uint8_t needzlp = (l == endpoints[0].txbufsz) ? 1 : 0;
|
||||||
|
if(size || needzlp){ // send last data buffer
|
||||||
|
uint16_t status = KEEP_DTOG(USB->EPnR[0]);
|
||||||
|
// keep DTOGs, clear CTR_RX,TX, set TX VALID, leave stat_Rx
|
||||||
|
USB->EPnR[0] = (status & ~(USB_EPnR_CTR_RX|USB_EPnR_CTR_TX|USB_EPnR_STAT_RX))
|
||||||
|
^ USB_EPnR_STAT_TX;
|
||||||
|
uint32_t ctr = 1000000;
|
||||||
|
while(--ctr && (USB->ISTR & USB_ISTR_CTR) == 0){IWDG->KR = IWDG_REFRESH;};
|
||||||
|
if((USB->ISTR & USB_ISTR_CTR) == 0){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(needzlp) EP_WriteIRQ(0, (uint8_t*)0, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void get_descriptor(){
|
||||||
|
switch(setup_packet.wValue){
|
||||||
|
case DEVICE_DESCRIPTOR:
|
||||||
|
wr0(USB_DeviceDescriptor, sizeof(USB_DeviceDescriptor));
|
||||||
|
break;
|
||||||
|
case CONFIGURATION_DESCRIPTOR:
|
||||||
|
wr0(USB_ConfigDescriptor, sizeof(USB_ConfigDescriptor));
|
||||||
|
break;
|
||||||
|
case STRING_LANG_DESCRIPTOR:
|
||||||
|
wr0((const uint8_t *)&USB_StringLangDescriptor, STRING_LANG_DESCRIPTOR_SIZE_BYTE);
|
||||||
|
break;
|
||||||
|
case STRING_MAN_DESCRIPTOR:
|
||||||
|
wr0((const uint8_t *)&USB_StringManufacturingDescriptor, USB_StringManufacturingDescriptor.bLength);
|
||||||
|
break;
|
||||||
|
case STRING_PROD_DESCRIPTOR:
|
||||||
|
wr0((const uint8_t *)&USB_StringProdDescriptor, USB_StringProdDescriptor.bLength);
|
||||||
|
break;
|
||||||
|
case STRING_SN_DESCRIPTOR:
|
||||||
|
wr0((const uint8_t *)&USB_StringSerialDescriptor, USB_StringSerialDescriptor.bLength);
|
||||||
|
break;
|
||||||
|
case DEVICE_QUALIFIER_DESCRIPTOR:
|
||||||
|
wr0(USB_DeviceQualifierDescriptor, USB_DeviceQualifierDescriptor[0]);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t configuration = 0; // reply for GET_CONFIGURATION (==1 if configured)
|
||||||
|
static inline void std_d2h_req(){
|
||||||
|
uint16_t status = 0; // bus powered
|
||||||
|
switch(setup_packet.bRequest){
|
||||||
|
case GET_DESCRIPTOR:
|
||||||
|
get_descriptor();
|
||||||
|
break;
|
||||||
|
case GET_STATUS:
|
||||||
|
EP_WriteIRQ(0, (uint8_t *)&status, 2); // send status: Bus Powered
|
||||||
|
break;
|
||||||
|
case GET_CONFIGURATION:
|
||||||
|
EP_WriteIRQ(0, &configuration, 1);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void std_h2d_req(){
|
||||||
|
switch(setup_packet.bRequest){
|
||||||
|
case SET_ADDRESS:
|
||||||
|
// new address will be assigned later - after acknowlegement or request to host
|
||||||
|
USB_Dev.USB_Addr = setup_packet.wValue;
|
||||||
|
break;
|
||||||
|
case SET_CONFIGURATION:
|
||||||
|
// Now device configured
|
||||||
|
USB_Dev.USB_Status = USB_STATE_CONFIGURED;
|
||||||
|
configuration = setup_packet.wValue;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
bmRequestType: 76543210
|
||||||
|
7 direction: 0 - host->device, 1 - device->host
|
||||||
|
65 type: 0 - standard, 1 - class, 2 - vendor
|
||||||
|
4..0 getter: 0 - device, 1 - interface, 2 - endpoint, 3 - other
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* Endpoint0 (control) handler
|
||||||
|
*/
|
||||||
|
static void EP0_Handler(){
|
||||||
|
uint16_t epstatus = USB->EPnR[0]; // EP0R on input -> return this value after modifications
|
||||||
|
uint8_t reqtype = setup_packet.bmRequestType & 0x7f;
|
||||||
|
uint8_t dev2host = (setup_packet.bmRequestType & 0x80) ? 1 : 0;
|
||||||
|
int rxflag = RX_FLAG(epstatus);
|
||||||
|
if(rxflag && SETUP_FLAG(epstatus)){
|
||||||
|
switch(reqtype){
|
||||||
|
case STANDARD_DEVICE_REQUEST_TYPE: // standard device request
|
||||||
|
if(dev2host){
|
||||||
|
std_d2h_req();
|
||||||
|
}else{
|
||||||
|
std_h2d_req();
|
||||||
|
EP_WriteIRQ(0, (uint8_t *)0, 0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case STANDARD_ENDPOINT_REQUEST_TYPE: // standard endpoint request
|
||||||
|
if(setup_packet.bRequest == CLEAR_FEATURE){
|
||||||
|
EP_WriteIRQ(0, (uint8_t *)0, 0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case VENDOR_REQUEST_TYPE:
|
||||||
|
vendor_handler(&setup_packet);
|
||||||
|
break;
|
||||||
|
case CONTROL_REQUEST_TYPE:
|
||||||
|
switch(setup_packet.bRequest){
|
||||||
|
case GET_LINE_CODING:
|
||||||
|
EP_WriteIRQ(0, (uint8_t*)&lineCoding, sizeof(lineCoding));
|
||||||
|
break;
|
||||||
|
case SET_LINE_CODING: // omit this for next stage, when data will come
|
||||||
|
break;
|
||||||
|
case SET_CONTROL_LINE_STATE:
|
||||||
|
usbON = 1;
|
||||||
|
clstate_handler(setup_packet.wValue);
|
||||||
|
break;
|
||||||
|
case SEND_BREAK:
|
||||||
|
usbON = 0;
|
||||||
|
break_handler();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(setup_packet.bRequest != GET_LINE_CODING) EP_WriteIRQ(0, (uint8_t *)0, 0); // write acknowledgement
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
EP_WriteIRQ(0, (uint8_t *)0, 0);
|
||||||
|
}
|
||||||
|
}else if(rxflag){ // got data over EP0 or host acknowlegement
|
||||||
|
if(endpoints[0].rx_cnt){
|
||||||
|
if(setup_packet.bRequest == SET_LINE_CODING){
|
||||||
|
linecoding_handler((usb_LineCoding*)ep0databuf);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if(TX_FLAG(epstatus)){ // package transmitted
|
||||||
|
// now we can change address after enumeration
|
||||||
|
if ((USB->DADDR & USB_DADDR_ADD) != USB_Dev.USB_Addr){
|
||||||
|
USB->DADDR = USB_DADDR_EF | USB_Dev.USB_Addr;
|
||||||
|
// change state to ADRESSED
|
||||||
|
USB_Dev.USB_Status = USB_STATE_ADDRESSED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
epstatus = KEEP_DTOG(USB->EPnR[0]);
|
||||||
|
if(rxflag) epstatus ^= USB_EPnR_STAT_TX; // start ZLP/data transmission
|
||||||
|
else epstatus &= ~USB_EPnR_STAT_TX; // or leave unchanged
|
||||||
|
// keep DTOGs, clear CTR_RX,TX, set RX VALID
|
||||||
|
USB->EPnR[0] = (epstatus & ~(USB_EPnR_CTR_RX|USB_EPnR_CTR_TX)) ^ USB_EPnR_STAT_RX;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint16_t lastaddr = LASTADDR_DEFAULT;
|
||||||
|
/**
|
||||||
|
* Endpoint initialisation
|
||||||
|
* !!! when working with CAN bus change USB_BTABLE_SIZE to 768 !!!
|
||||||
|
* @param number - EP num (0...7)
|
||||||
|
* @param type - EP type (EP_TYPE_BULK, EP_TYPE_CONTROL, EP_TYPE_ISO, EP_TYPE_INTERRUPT)
|
||||||
|
* @param txsz - transmission buffer size @ USB/CAN buffer
|
||||||
|
* @param rxsz - reception buffer size @ USB/CAN buffer
|
||||||
|
* @param uint16_t (*func)(ep_t *ep) - EP handler function
|
||||||
|
* @return 0 if all OK
|
||||||
|
*/
|
||||||
|
int EP_Init(uint8_t number, uint8_t type, uint16_t txsz, uint16_t rxsz, void (*func)()){
|
||||||
|
if(number >= STM32ENDPOINTS) return 4; // out of configured amount
|
||||||
|
if(txsz > USB_BTABLE_SIZE || rxsz > USB_BTABLE_SIZE) return 1; // buffer too large
|
||||||
|
if(lastaddr + txsz + rxsz >= USB_BTABLE_SIZE) return 2; // out of btable
|
||||||
|
USB->EPnR[number] = (type << 9) | (number & USB_EPnR_EA);
|
||||||
|
USB->EPnR[number] ^= USB_EPnR_STAT_RX | USB_EPnR_STAT_TX_1;
|
||||||
|
if(rxsz & 1 || rxsz > 512) return 3; // wrong rx buffer size
|
||||||
|
uint16_t countrx = 0;
|
||||||
|
if(rxsz < 64) countrx = rxsz / 2;
|
||||||
|
else{
|
||||||
|
if(rxsz & 0x1f) return 3; // should be multiple of 32
|
||||||
|
countrx = 31 + rxsz / 32;
|
||||||
|
}
|
||||||
|
USB_BTABLE->EP[number].USB_ADDR_TX = lastaddr;
|
||||||
|
endpoints[number].tx_buf = (uint16_t *)(USB_BTABLE_BASE + lastaddr);
|
||||||
|
endpoints[number].txbufsz = txsz;
|
||||||
|
lastaddr += txsz;
|
||||||
|
USB_BTABLE->EP[number].USB_COUNT_TX = 0;
|
||||||
|
USB_BTABLE->EP[number].USB_ADDR_RX = lastaddr;
|
||||||
|
endpoints[number].rx_buf = (uint8_t *)(USB_BTABLE_BASE + lastaddr);
|
||||||
|
lastaddr += rxsz;
|
||||||
|
// buffer size: Table127 of RM
|
||||||
|
USB_BTABLE->EP[number].USB_COUNT_RX = countrx << 10;
|
||||||
|
endpoints[number].func = func;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// standard IRQ handler
|
||||||
|
void usb_isr(){
|
||||||
|
if (USB->ISTR & USB_ISTR_RESET){
|
||||||
|
// Reinit registers
|
||||||
|
USB->CNTR = USB_CNTR_RESETM | USB_CNTR_CTRM | USB_CNTR_SUSPM | USB_CNTR_WKUPM;
|
||||||
|
USB->ISTR = 0;
|
||||||
|
// Endpoint 0 - CONTROL
|
||||||
|
// ON USB LS size of EP0 may be 8 bytes, but on FS it should be 64 bytes!
|
||||||
|
lastaddr = LASTADDR_DEFAULT; // roll back to beginning of buffer
|
||||||
|
EP_Init(0, EP_TYPE_CONTROL, USB_EP0_BUFSZ, USB_EP0_BUFSZ, EP0_Handler);
|
||||||
|
// clear address, leave only enable bit
|
||||||
|
USB->DADDR = USB_DADDR_EF;
|
||||||
|
// state is default - wait for enumeration
|
||||||
|
USB_Dev.USB_Status = USB_STATE_DEFAULT;
|
||||||
|
}
|
||||||
|
if(USB->ISTR & USB_ISTR_CTR){
|
||||||
|
// EP number
|
||||||
|
uint8_t n = USB->ISTR & USB_ISTR_EPID;
|
||||||
|
// copy status register
|
||||||
|
uint16_t epstatus = USB->EPnR[n];
|
||||||
|
// copy received bytes amount
|
||||||
|
endpoints[n].rx_cnt = USB_BTABLE->EP[n].USB_COUNT_RX & 0x3FF; // low 10 bits is counter
|
||||||
|
// check direction
|
||||||
|
if(USB->ISTR & USB_ISTR_DIR){ // OUT interrupt - receive data, CTR_RX==1 (if CTR_TX == 1 - two pending transactions: receive following by transmit)
|
||||||
|
if(n == 0){ // control endpoint
|
||||||
|
if(epstatus & USB_EPnR_SETUP){ // setup packet -> copy data to conf_pack
|
||||||
|
EP_Read(0, (uint8_t*)&setup_packet);
|
||||||
|
ep0dbuflen = 0;
|
||||||
|
// interrupt handler will be called later
|
||||||
|
}else if(epstatus & USB_EPnR_CTR_RX){ // data packet -> push received data to ep0databuf
|
||||||
|
ep0dbuflen = endpoints[0].rx_cnt;
|
||||||
|
EP_Read(0, (uint8_t*)&ep0databuf);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// call EP handler
|
||||||
|
if(endpoints[n].func) endpoints[n].func(endpoints[n]);
|
||||||
|
}
|
||||||
|
if(USB->ISTR & USB_ISTR_SUSP){ // suspend -> still no connection, may sleep
|
||||||
|
usbON = 0;
|
||||||
|
USB->CNTR |= USB_CNTR_FSUSP | USB_CNTR_LPMODE;
|
||||||
|
USB->ISTR = ~USB_ISTR_SUSP;
|
||||||
|
}
|
||||||
|
if(USB->ISTR & USB_ISTR_WKUP){ // wakeup
|
||||||
|
USB->CNTR &= ~(USB_CNTR_FSUSP | USB_CNTR_LPMODE); // clear suspend flags
|
||||||
|
USB->ISTR = ~USB_ISTR_WKUP;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write data to EP buffer (called from IRQ handler)
|
||||||
|
* @param number - EP number
|
||||||
|
* @param *buf - array with data
|
||||||
|
* @param size - its size
|
||||||
|
*/
|
||||||
|
void EP_WriteIRQ(uint8_t number, const uint8_t *buf, uint16_t size){
|
||||||
|
uint8_t i;
|
||||||
|
if(size > USB_TXBUFSZ) size = USB_TXBUFSZ;
|
||||||
|
uint16_t N2 = (size + 1) >> 1;
|
||||||
|
// the buffer is 16-bit, so we should copy data as it would be uint16_t
|
||||||
|
uint16_t *buf16 = (uint16_t *)buf;
|
||||||
|
for (i = 0; i < N2; i++){
|
||||||
|
endpoints[number].tx_buf[i] = buf16[i];
|
||||||
|
}
|
||||||
|
USB_BTABLE->EP[number].USB_COUNT_TX = size;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write data to EP buffer (called outside IRQ handler)
|
||||||
|
* @param number - EP number
|
||||||
|
* @param *buf - array with data
|
||||||
|
* @param size - its size
|
||||||
|
*/
|
||||||
|
void EP_Write(uint8_t number, const uint8_t *buf, uint16_t size){
|
||||||
|
EP_WriteIRQ(number, buf, size);
|
||||||
|
uint16_t status = KEEP_DTOG(USB->EPnR[number]);
|
||||||
|
// keep DTOGs, clear CTR_TX & set TX VALID to start transmission
|
||||||
|
USB->EPnR[number] = (status & ~(USB_EPnR_CTR_TX)) ^ USB_EPnR_STAT_TX;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copy data from EP buffer into user buffer area
|
||||||
|
* @param *buf - user array for data
|
||||||
|
* @return amount of data read
|
||||||
|
*/
|
||||||
|
int EP_Read(uint8_t number, uint8_t *buf){
|
||||||
|
int n = endpoints[number].rx_cnt;
|
||||||
|
if(n){
|
||||||
|
for(int i = 0; i < n; ++i)
|
||||||
|
buf[i] = endpoints[number].rx_buf[i];
|
||||||
|
}
|
||||||
|
return n;
|
||||||
|
}
|
||||||
189
F0-nolib/usbcan_relay/usb_lib.h
Normal file
189
F0-nolib/usbcan_relay/usb_lib.h
Normal file
@ -0,0 +1,189 @@
|
|||||||
|
/*
|
||||||
|
* geany_encoding=koi8-r
|
||||||
|
* usb_lib.h
|
||||||
|
*
|
||||||
|
* Copyright 2018 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#ifndef __USB_LIB_H__
|
||||||
|
#define __USB_LIB_H__
|
||||||
|
|
||||||
|
#include <wchar.h>
|
||||||
|
#include "usb_defs.h"
|
||||||
|
|
||||||
|
#define EP0DATABUF_SIZE (64)
|
||||||
|
#define LASTADDR_DEFAULT (STM32ENDPOINTS * 8)
|
||||||
|
|
||||||
|
// bmRequestType & 0x7f
|
||||||
|
#define STANDARD_DEVICE_REQUEST_TYPE 0
|
||||||
|
#define STANDARD_ENDPOINT_REQUEST_TYPE 2
|
||||||
|
#define VENDOR_REQUEST_TYPE 0x40
|
||||||
|
#define CONTROL_REQUEST_TYPE 0x21
|
||||||
|
// bRequest, standard; for bmRequestType == 0x80
|
||||||
|
#define GET_STATUS 0x00
|
||||||
|
#define GET_DESCRIPTOR 0x06
|
||||||
|
#define GET_CONFIGURATION 0x08
|
||||||
|
// for bmRequestType == 0
|
||||||
|
#define CLEAR_FEATURE 0x01
|
||||||
|
#define SET_FEATURE 0x03 // unused
|
||||||
|
#define SET_ADDRESS 0x05
|
||||||
|
#define SET_DESCRIPTOR 0x07 // unused
|
||||||
|
#define SET_CONFIGURATION 0x09
|
||||||
|
// for bmRequestType == 0x81, 1 or 0xB2
|
||||||
|
#define GET_INTERFACE 0x0A // unused
|
||||||
|
#define SET_INTERFACE 0x0B // unused
|
||||||
|
#define SYNC_FRAME 0x0C // unused
|
||||||
|
#define VENDOR_REQUEST 0x01 // unused
|
||||||
|
|
||||||
|
// Class-Specific Control Requests
|
||||||
|
#define SEND_ENCAPSULATED_COMMAND 0x00 // unused
|
||||||
|
#define GET_ENCAPSULATED_RESPONSE 0x01 // unused
|
||||||
|
#define SET_COMM_FEATURE 0x02 // unused
|
||||||
|
#define GET_COMM_FEATURE 0x03 // unused
|
||||||
|
#define CLEAR_COMM_FEATURE 0x04 // unused
|
||||||
|
#define SET_LINE_CODING 0x20
|
||||||
|
#define GET_LINE_CODING 0x21
|
||||||
|
#define SET_CONTROL_LINE_STATE 0x22
|
||||||
|
#define SEND_BREAK 0x23
|
||||||
|
|
||||||
|
// control line states
|
||||||
|
#define CONTROL_DTR 0x01
|
||||||
|
#define CONTROL_RTS 0x02
|
||||||
|
|
||||||
|
// wValue
|
||||||
|
#define DEVICE_DESCRIPTOR 0x100
|
||||||
|
#define CONFIGURATION_DESCRIPTOR 0x200
|
||||||
|
#define STRING_LANG_DESCRIPTOR 0x300
|
||||||
|
#define STRING_MAN_DESCRIPTOR 0x301
|
||||||
|
#define STRING_PROD_DESCRIPTOR 0x302
|
||||||
|
#define STRING_SN_DESCRIPTOR 0x303
|
||||||
|
#define DEVICE_QUALIFIER_DESCRIPTOR 0x600
|
||||||
|
|
||||||
|
#define RX_FLAG(epstat) (epstat & USB_EPnR_CTR_RX)
|
||||||
|
#define TX_FLAG(epstat) (epstat & USB_EPnR_CTR_TX)
|
||||||
|
#define SETUP_FLAG(epstat) (epstat & USB_EPnR_SETUP)
|
||||||
|
|
||||||
|
// EPnR bits manipulation
|
||||||
|
#define KEEP_DTOG_STAT(EPnR) (EPnR & ~(USB_EPnR_STAT_RX|USB_EPnR_STAT_TX|USB_EPnR_DTOG_RX|USB_EPnR_DTOG_TX))
|
||||||
|
#define KEEP_DTOG(EPnR) (EPnR & ~(USB_EPnR_DTOG_RX|USB_EPnR_DTOG_TX))
|
||||||
|
|
||||||
|
// USB state: uninitialized, addressed, ready for use, client connected
|
||||||
|
typedef enum{
|
||||||
|
USB_STATE_DEFAULT,
|
||||||
|
USB_STATE_ADDRESSED,
|
||||||
|
USB_STATE_CONFIGURED,
|
||||||
|
USB_STATE_CONNECTED
|
||||||
|
} USB_state;
|
||||||
|
|
||||||
|
// EP types
|
||||||
|
#define EP_TYPE_BULK 0x00
|
||||||
|
#define EP_TYPE_CONTROL 0x01
|
||||||
|
#define EP_TYPE_ISO 0x02
|
||||||
|
#define EP_TYPE_INTERRUPT 0x03
|
||||||
|
|
||||||
|
#define LANG_US (uint16_t)0x0409
|
||||||
|
|
||||||
|
#define _USB_STRING_(name, str) \
|
||||||
|
static const struct name \
|
||||||
|
{ \
|
||||||
|
uint8_t bLength; \
|
||||||
|
uint8_t bDescriptorType; \
|
||||||
|
uint16_t bString[(sizeof(str) - 2) / 2]; \
|
||||||
|
\
|
||||||
|
} \
|
||||||
|
name = {sizeof(name), 0x03, str}
|
||||||
|
|
||||||
|
#define _USB_LANG_ID_(name, lng_id) \
|
||||||
|
\
|
||||||
|
static const struct name \
|
||||||
|
{ \
|
||||||
|
uint8_t bLength; \
|
||||||
|
uint8_t bDescriptorType; \
|
||||||
|
uint16_t bString; \
|
||||||
|
\
|
||||||
|
} \
|
||||||
|
name = {0x04, 0x03, lng_id}
|
||||||
|
#define STRING_LANG_DESCRIPTOR_SIZE_BYTE (4)
|
||||||
|
|
||||||
|
// EP0 configuration packet
|
||||||
|
typedef struct {
|
||||||
|
uint8_t bmRequestType;
|
||||||
|
uint8_t bRequest;
|
||||||
|
uint16_t wValue;
|
||||||
|
uint16_t wIndex;
|
||||||
|
uint16_t wLength;
|
||||||
|
} config_pack_t;
|
||||||
|
|
||||||
|
// endpoints state
|
||||||
|
typedef struct __ep_t{
|
||||||
|
uint16_t *tx_buf; // transmission buffer address
|
||||||
|
uint16_t txbufsz; // transmission buffer size
|
||||||
|
uint8_t *rx_buf; // reception buffer address
|
||||||
|
void (*func)(); // endpoint action function
|
||||||
|
uint16_t rx_cnt; // received data counter
|
||||||
|
} ep_t;
|
||||||
|
|
||||||
|
// USB status & its address
|
||||||
|
typedef struct {
|
||||||
|
uint8_t USB_Status;
|
||||||
|
uint16_t USB_Addr;
|
||||||
|
}usb_dev_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint32_t dwDTERate;
|
||||||
|
uint8_t bCharFormat;
|
||||||
|
#define USB_CDC_1_STOP_BITS 0
|
||||||
|
#define USB_CDC_1_5_STOP_BITS 1
|
||||||
|
#define USB_CDC_2_STOP_BITS 2
|
||||||
|
uint8_t bParityType;
|
||||||
|
#define USB_CDC_NO_PARITY 0
|
||||||
|
#define USB_CDC_ODD_PARITY 1
|
||||||
|
#define USB_CDC_EVEN_PARITY 2
|
||||||
|
#define USB_CDC_MARK_PARITY 3
|
||||||
|
#define USB_CDC_SPACE_PARITY 4
|
||||||
|
uint8_t bDataBits;
|
||||||
|
} __attribute__ ((packed)) usb_LineCoding;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint8_t bmRequestType;
|
||||||
|
uint8_t bNotificationType;
|
||||||
|
uint16_t wValue;
|
||||||
|
uint16_t wIndex;
|
||||||
|
uint16_t wLength;
|
||||||
|
} __attribute__ ((packed)) usb_cdc_notification;
|
||||||
|
|
||||||
|
extern ep_t endpoints[];
|
||||||
|
extern usb_dev_t USB_Dev;
|
||||||
|
extern uint8_t usbON;
|
||||||
|
|
||||||
|
void USB_Init();
|
||||||
|
uint8_t USB_GetState();
|
||||||
|
int EP_Init(uint8_t number, uint8_t type, uint16_t txsz, uint16_t rxsz, void (*func)());
|
||||||
|
void EP_WriteIRQ(uint8_t number, const uint8_t *buf, uint16_t size);
|
||||||
|
void EP_Write(uint8_t number, const uint8_t *buf, uint16_t size);
|
||||||
|
int EP_Read(uint8_t number, uint8_t *buf);
|
||||||
|
usb_LineCoding getLineCoding();
|
||||||
|
|
||||||
|
void linecoding_handler(usb_LineCoding *lc);
|
||||||
|
void clstate_handler(uint16_t val);
|
||||||
|
void break_handler();
|
||||||
|
void vendor_handler(config_pack_t *packet);
|
||||||
|
|
||||||
|
#endif // __USB_LIB_H__
|
||||||
BIN
F0-nolib/usbcan_relay/usbcan.bin
Normal file
BIN
F0-nolib/usbcan_relay/usbcan.bin
Normal file
Binary file not shown.
190
F0_F1_F3-LQFP48_testboard/elements.lib
Normal file
190
F0_F1_F3-LQFP48_testboard/elements.lib
Normal file
@ -0,0 +1,190 @@
|
|||||||
|
EESchema-LIBRARY Version 2.3
|
||||||
|
#encoding utf-8
|
||||||
|
#
|
||||||
|
# 74HC4051
|
||||||
|
#
|
||||||
|
DEF 74HC4051 U 0 10 Y Y 1 F N
|
||||||
|
F0 "U" 0 0 50 H V C CNN
|
||||||
|
F1 "74HC4051" 0 -150 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
$FPLIST
|
||||||
|
SO16
|
||||||
|
TSSOP16
|
||||||
|
SSOP16
|
||||||
|
DHVQFN16
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -400 450 400 -450 0 1 0 N
|
||||||
|
X Y4 1 700 -50 300 L 50 50 1 1 B
|
||||||
|
X Y6 2 700 -250 300 L 50 50 1 1 B
|
||||||
|
X Z 3 0 -750 300 U 50 50 1 1 B
|
||||||
|
X Y7 4 700 -350 300 L 50 50 1 1 B
|
||||||
|
X Y5 5 700 -150 300 L 50 50 1 1 B
|
||||||
|
X ~E 6 -700 -350 300 R 50 50 1 1 I I
|
||||||
|
X VEE 7 -700 0 300 R 50 50 1 1 W
|
||||||
|
X GND 8 -700 -200 300 R 50 50 1 1 W
|
||||||
|
X S2 9 -700 150 300 R 50 50 1 1 I
|
||||||
|
X S1 10 -700 250 300 R 50 50 1 1 I
|
||||||
|
X S0 11 -700 350 300 R 50 50 1 1 I
|
||||||
|
X Y3 12 700 50 300 L 50 50 1 1 B
|
||||||
|
X Y0 13 700 350 300 L 50 50 1 1 B
|
||||||
|
X Y1 14 700 250 300 L 50 50 1 1 B
|
||||||
|
X Y2 15 700 150 300 L 50 50 1 1 B
|
||||||
|
X VCC 16 -700 -100 300 R 50 50 1 1 W
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# D_Schottky_x2_ACom_AKK
|
||||||
|
#
|
||||||
|
DEF D_Schottky_x2_ACom_AKK D 0 30 Y N 1 F N
|
||||||
|
F0 "D" 50 -100 50 H V C CNN
|
||||||
|
F1 "D_Schottky_x2_ACom_AKK" 0 100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 -140 0 150 0 N
|
||||||
|
P 2 0 1 0 0 0 0 -100 N
|
||||||
|
P 3 0 1 8 -150 50 -150 -50 -150 -50 N
|
||||||
|
P 3 0 1 8 150 50 150 -50 150 -50 N
|
||||||
|
P 4 0 1 8 -150 50 -170 50 -170 40 -170 40 N
|
||||||
|
P 4 0 1 8 150 -50 170 -50 170 -40 170 -40 N
|
||||||
|
P 4 0 1 8 150 50 130 50 130 40 130 40 N
|
||||||
|
P 5 0 1 8 -130 -40 -130 -50 -150 -50 -150 -50 -150 -50 N
|
||||||
|
P 6 0 1 8 -50 -50 -150 0 -50 50 -50 -50 -50 -50 -50 -50 N
|
||||||
|
P 6 0 1 8 50 50 150 0 50 -50 50 50 50 50 50 50 N
|
||||||
|
X A 1 0 -200 100 U 50 50 0 1 P
|
||||||
|
X K 2 -300 0 150 R 50 50 0 1 P
|
||||||
|
X K 3 300 0 150 L 50 50 0 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# LM1117-ADJ
|
||||||
|
#
|
||||||
|
DEF LM1117-ADJ U 0 30 Y Y 1 F N
|
||||||
|
F0 "U" 100 -250 50 H V C CNN
|
||||||
|
F1 "LM1117-ADJ" 0 250 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
ALIAS LM1117-1.8 LM1117-2.5 LM1117-3.3 LM1117-5.0
|
||||||
|
$FPLIST
|
||||||
|
SOT-223*
|
||||||
|
TO-263*
|
||||||
|
TO-252*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -200 -200 200 200 0 1 10 f
|
||||||
|
X GND/ADJ 1 0 -300 100 U 50 50 1 1 W
|
||||||
|
X VO 2 300 0 100 L 50 50 1 1 w
|
||||||
|
X VI 3 -300 0 100 R 50 50 1 1 W
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# PESD1CAN
|
||||||
|
#
|
||||||
|
DEF PESD1CAN D 0 30 Y N 1 F N
|
||||||
|
F0 "D" 0 -350 50 H V C CNN
|
||||||
|
F1 "PESD1CAN" 50 150 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
$FPLIST
|
||||||
|
SOT23
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -200 100 300 -300 0 1 0 N
|
||||||
|
P 2 0 1 0 -140 -200 150 -200 N
|
||||||
|
P 2 0 1 0 -140 0 150 0 N
|
||||||
|
P 3 0 1 8 -150 -150 -150 -250 -150 -250 N
|
||||||
|
P 3 0 1 8 -150 50 -150 -50 -150 -50 N
|
||||||
|
P 3 0 1 8 150 -150 150 -250 150 -250 N
|
||||||
|
P 3 0 1 8 150 50 150 -50 150 -50 N
|
||||||
|
P 4 0 1 8 -150 -150 -170 -150 -170 -160 -170 -160 N
|
||||||
|
P 4 0 1 8 -150 50 -170 50 -170 40 -170 40 N
|
||||||
|
P 4 0 1 8 150 -250 170 -250 170 -240 170 -240 N
|
||||||
|
P 4 0 1 8 150 -150 130 -150 130 -160 130 -160 N
|
||||||
|
P 4 0 1 8 150 -50 170 -50 170 -40 170 -40 N
|
||||||
|
P 4 0 1 0 150 0 250 0 250 -200 150 -200 N
|
||||||
|
P 4 0 1 8 150 50 130 50 130 40 130 40 N
|
||||||
|
P 5 0 1 8 -130 -240 -130 -250 -150 -250 -150 -250 -150 -250 N
|
||||||
|
P 5 0 1 8 -130 -40 -130 -50 -150 -50 -150 -50 -150 -50 N
|
||||||
|
P 6 0 1 8 -50 -250 -150 -200 -50 -150 -50 -250 -50 -250 -50 -250 N
|
||||||
|
P 6 0 1 8 -50 -50 -150 0 -50 50 -50 -50 -50 -50 -50 -50 N
|
||||||
|
P 6 0 1 8 50 -150 150 -200 50 -250 50 -150 50 -150 50 -150 N
|
||||||
|
P 6 0 1 8 50 50 150 0 50 -50 50 50 50 50 50 50 N
|
||||||
|
X K 1 -300 0 150 R 50 50 0 1 P
|
||||||
|
X K 2 -300 -200 150 R 50 50 0 1 P
|
||||||
|
X O 3 400 -100 150 L 50 50 0 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# TPS2051
|
||||||
|
#
|
||||||
|
DEF TPS2051 U 0 40 Y Y 1 F N
|
||||||
|
F0 "U" 0 -300 60 H V C CNN
|
||||||
|
F1 "TPS2051" 0 300 60 H V C CNN
|
||||||
|
F2 "" 0 0 60 H I C CNN
|
||||||
|
F3 "" 0 0 60 H I C CNN
|
||||||
|
DRAW
|
||||||
|
S -250 250 250 -250 0 1 0 N
|
||||||
|
X GND 1 -450 150 200 R 50 50 1 1 W
|
||||||
|
X IN 2 -450 50 200 R 50 50 1 1 W
|
||||||
|
X IN 3 -450 -50 200 R 50 50 1 1 P
|
||||||
|
X EN 4 -450 -150 200 R 50 50 1 1 I
|
||||||
|
X ~OC 5 450 -150 200 L 50 50 1 1 O
|
||||||
|
X OUT 6 450 -50 200 L 50 50 1 1 P
|
||||||
|
X OUT 7 450 50 200 L 50 50 1 1 P
|
||||||
|
X OUT 8 450 150 200 L 50 50 1 1 w
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# USB6B1
|
||||||
|
#
|
||||||
|
DEF USB6B1 D 0 30 Y N 1 F N
|
||||||
|
F0 "D" 0 -450 50 H V C CNN
|
||||||
|
F1 "USB6B1" 0 400 50 H V C CNN
|
||||||
|
F2 "" 200 -100 50 V V C CNN
|
||||||
|
F3 "" 200 -100 50 V V C CNN
|
||||||
|
$FPLIST
|
||||||
|
SO8
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
C -150 -300 7 0 1 0 N
|
||||||
|
C -150 100 7 0 1 0 N
|
||||||
|
C -150 300 7 0 1 0 N
|
||||||
|
C 0 -300 7 0 1 0 N
|
||||||
|
C 0 -100 7 0 1 0 N
|
||||||
|
C 0 300 7 0 1 0 N
|
||||||
|
C 200 -300 7 0 1 0 N
|
||||||
|
C 200 300 7 0 1 0 N
|
||||||
|
S -300 -100 300 -100 0 1 0 N
|
||||||
|
S -300 300 300 300 0 1 0 N
|
||||||
|
S -200 -150 -100 -150 0 1 0 N
|
||||||
|
S -200 250 -100 250 0 1 0 N
|
||||||
|
S -150 300 -150 -300 0 1 0 N
|
||||||
|
S -50 -150 50 -150 0 1 0 N
|
||||||
|
S -50 250 50 250 0 1 0 N
|
||||||
|
S 0 300 0 -300 0 1 0 N
|
||||||
|
S 200 300 200 -300 0 1 0 N
|
||||||
|
S 300 -300 -300 -300 0 1 0 N
|
||||||
|
S 300 100 -300 100 0 1 0 N
|
||||||
|
P 3 0 1 8 150 50 250 50 250 50 N
|
||||||
|
P 4 0 1 8 150 50 150 30 160 30 160 30 N
|
||||||
|
P 4 0 1 8 250 50 250 70 240 70 240 70 N
|
||||||
|
P 5 0 1 0 -250 350 300 350 300 -350 -250 -350 -250 350 N
|
||||||
|
P 6 0 1 8 -200 -250 -150 -150 -100 -250 -200 -250 -200 -250 -200 -250 N
|
||||||
|
P 6 0 1 8 -200 150 -150 250 -100 150 -200 150 -200 150 -200 150 N
|
||||||
|
P 6 0 1 8 -50 -250 0 -150 50 -250 -50 -250 -50 -250 -50 -250 N
|
||||||
|
P 6 0 1 8 -50 150 0 250 50 150 -50 150 -50 150 -50 150 N
|
||||||
|
P 6 0 1 8 150 -50 200 50 250 -50 150 -50 150 -50 150 -50 N
|
||||||
|
X VCC 1 -500 300 200 R 50 50 1 1 P
|
||||||
|
X I/O1 2 -500 100 200 R 50 50 1 1 P
|
||||||
|
X I/O2 3 -500 -100 200 R 50 50 1 1 P
|
||||||
|
X GND 4 -500 -300 200 R 50 50 1 1 P
|
||||||
|
X GND 5 500 -300 200 L 50 50 1 1 P
|
||||||
|
X I/O2 6 500 -100 200 L 50 50 1 1 P
|
||||||
|
X I/O1 7 500 100 200 L 50 50 1 1 P
|
||||||
|
X VCC 8 500 300 200 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
#End Library
|
||||||
1947
F0_F1_F3-LQFP48_testboard/fp-info-cache
Normal file
1947
F0_F1_F3-LQFP48_testboard/fp-info-cache
Normal file
File diff suppressed because it is too large
Load Diff
6
F0_F1_F3-LQFP48_testboard/fp-lib-table
Normal file
6
F0_F1_F3-LQFP48_testboard/fp-lib-table
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
(fp_lib_table
|
||||||
|
(lib (name my_footprints)(type KiCad)(uri "$(KIPRJMOD)/my_footprints.pretty")(options "")(descr ""))
|
||||||
|
(lib (name LED_THT)(type KiCad)(uri ${KISYSMOD}/LED_THT.pretty)(options "")(descr ""))
|
||||||
|
(lib (name Crystal)(type KiCad)(uri ${KISYSMOD}/Crystal.pretty)(options "")(descr ""))
|
||||||
|
(lib (name Potentiometer_THT)(type KiCad)(uri ${KISYSMOD}/Potentiometer_THT.pretty)(options "")(descr ""))
|
||||||
|
)
|
||||||
@ -0,0 +1,9 @@
|
|||||||
|
(module Hole_3mm (layer F.Cu) (tedit 5913F6E4)
|
||||||
|
(fp_text reference REF** (at 0 3.81) (layer F.SilkS) hide
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(fp_text value Hole_3mm (at 0 -7.62) (layer F.Fab) hide
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(pad 1 thru_hole circle (at 0 0) (size 5 5) (drill 3) (layers *.Cu *.Mask))
|
||||||
|
)
|
||||||
@ -0,0 +1,51 @@
|
|||||||
|
(module Potentiometer (layer F.Cu) (tedit 5CDABBAE)
|
||||||
|
(descr http://www.ttelectronics.com/sites/default/files/download-files/Datasheet_PanelPot_P09xSeries.pdf)
|
||||||
|
(tags "potentiometer vertical TT P0915N single")
|
||||||
|
(fp_text reference REF** (at 2.5 -13.5) (layer F.SilkS)
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(fp_text value Potentiometer (at 2.5 2) (layer F.Fab)
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(fp_line (start -3.1 -9.75) (end -3.1 -12.6) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start 8.1 -0.75) (end 6.15 -0.75) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start -3.1 -12.6) (end 8.1 -12.6) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start 7.97 -0.88) (end 6.15 -0.88) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_line (start -2.97 -12.47) (end -2.97 -9.75) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_line (start 7.97 -12.47) (end -2.97 -12.47) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_circle (center 2.5 -7.5) (end 5.5 -7.5) (layer F.Fab) (width 0.12))
|
||||||
|
(fp_line (start -2.85 -12.35) (end 7.85 -12.35) (layer F.Fab) (width 0.1))
|
||||||
|
(fp_line (start -2.85 -1) (end -2.85 -12.35) (layer F.Fab) (width 0.1))
|
||||||
|
(fp_line (start 7.85 -1) (end -2.85 -1) (layer F.Fab) (width 0.1))
|
||||||
|
(fp_line (start 7.85 -12.35) (end 7.85 -1) (layer F.Fab) (width 0.1))
|
||||||
|
(fp_text user %R (at 2.5 -7.5) (layer F.Fab)
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(fp_line (start -1.15 -0.88) (end -2.97 -0.88) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_line (start 6.15 1.15) (end 6.15 -0.75) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start -1.15 -0.75) (end -3.1 -0.75) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start -1.15 1.15) (end -1.15 -0.75) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start 6.15 1.15) (end -1.15 1.15) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start -3.1 -9.75) (end -4.5 -9.75) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start -4.5 -5.25) (end -4.5 -9.75) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start -3.1 -0.75) (end -3.1 -5.25) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start -3.1 -5.25) (end -4.5 -5.25) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start 8.1 -0.75) (end 8.1 -5.25) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start 8.1 -9.75) (end 8.1 -12.6) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start 9.5 -9.75) (end 8.1 -9.75) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start 9.5 -5.25) (end 8.1 -5.25) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start 9.5 -5.25) (end 9.5 -9.75) (layer F.CrtYd) (width 0.05))
|
||||||
|
(fp_line (start -2.97 -5.25) (end -2.97 -0.88) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_line (start 7.97 -5.25) (end 7.97 -0.88) (layer F.SilkS) (width 0.12))
|
||||||
|
(fp_line (start 7.97 -12.47) (end 7.97 -9.75) (layer F.SilkS) (width 0.12))
|
||||||
|
(pad "" thru_hole oval (at -2.66 -7) (size 4.5 4.5) (drill 2.2) (layers *.Cu *.Mask))
|
||||||
|
(pad 3 thru_hole circle (at 5 0) (size 2 2) (drill 0.9) (layers *.Cu *.Mask))
|
||||||
|
(pad 2 thru_hole circle (at 2.54 0) (size 2 2) (drill 0.9) (layers *.Cu *.Mask))
|
||||||
|
(pad 1 thru_hole rect (at 0 0) (size 2 3) (drill 0.9) (layers *.Cu *.Mask))
|
||||||
|
(pad "" thru_hole oval (at 7.74 -7) (size 4.5 4.5) (drill 2.2) (layers *.Cu *.Mask))
|
||||||
|
(model ${KISYS3DMOD}/Potentiometer_THT.3dshapes/Potentiometer_TT_P0915N.wrl
|
||||||
|
(at (xyz 0 0 0))
|
||||||
|
(scale (xyz 1 1 1))
|
||||||
|
(rotate (xyz 0 0 0))
|
||||||
|
)
|
||||||
|
)
|
||||||
@ -0,0 +1,12 @@
|
|||||||
|
(module SMD_conn_4x2.5mm (layer F.Cu) (tedit 58B86145)
|
||||||
|
(fp_text reference REF** (at 0 3.81) (layer F.SilkS)
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(fp_text value SMD_conn_4x2.5mm (at 0 -3.81) (layer F.Fab)
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(pad 1 smd rect (at -3.81 0) (size 1.5 5) (layers F.Cu F.Paste F.Mask))
|
||||||
|
(pad 2 smd rect (at -1.27 0) (size 1.5 5) (layers F.Cu F.Paste F.Mask))
|
||||||
|
(pad 3 smd rect (at 1.27 0) (size 1.5 5) (layers F.Cu F.Paste F.Mask))
|
||||||
|
(pad 4 smd rect (at 3.81 0) (size 1.5 5) (layers F.Cu F.Paste F.Mask))
|
||||||
|
)
|
||||||
@ -0,0 +1,10 @@
|
|||||||
|
(module TH_via (layer F.Cu) (tedit 5A5E619A)
|
||||||
|
(fp_text reference REF** (at 0 0.5) (layer F.SilkS) hide
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(fp_text value TH_via (at 0 -0.5) (layer F.Fab) hide
|
||||||
|
(effects (font (size 1 1) (thickness 0.15)))
|
||||||
|
)
|
||||||
|
(pad 1 thru_hole circle (at 0 0) (size 1.5 1.5) (drill 0.8) (layers *.Cu *.Mask)
|
||||||
|
(zone_connect 1))
|
||||||
|
)
|
||||||
30
F0_F1_F3-LQFP48_testboard/stm32
Normal file
30
F0_F1_F3-LQFP48_testboard/stm32
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
"Source:","/Big/Data/00__Electronics/STM32/F0_F1_F3-LQFP48_testboard/stm32.sch"
|
||||||
|
"Date:","óÒ 23 ÉÀÎ 2021 22:52:44"
|
||||||
|
"Tool:","Eeschema 5.1.10"
|
||||||
|
"Generator:","/usr/share/kicad/plugins/bom_csv_grouped_by_value_with_fp.py"
|
||||||
|
"Component Count:","54"
|
||||||
|
"Ref","Qnty","Value","Cmp name","Footprint","Description","Vendor"
|
||||||
|
"C1, C2, C3, C7, C8, C9, C10, ","7","0.1","C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"C4, ","1","47u","CP","Capacitor_Tantalum_SMD:CP_EIA-6032-28_Kemet-C_Pad2.25x2.35mm_HandSolder","",""
|
||||||
|
"C5, C6, ","2","12","C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"D1, D2, D3, D4, D5, D6, ","6","LED","LED-RESCUE-stm32","LED_THT:LED_D3.0mm","",""
|
||||||
|
"J1, J5, J6, J7, J8, J9, J11, ","7","Conn_01x04_Female","Conn_01x04_Female","Connector_PinSocket_2.54mm:PinSocket_1x04_P2.54mm_Vertical","Generic connector, single row, 01x04, script generated (kicad-library-utils/schlib/autogen/connector/)",""
|
||||||
|
"J2, J4, J10, J12, ","4","Conn_01x01_Female","Conn_01x01_Female","Connector_PinSocket_2.54mm:PinSocket_1x01_P2.54mm_Vertical","Generic connector, single row, 01x01, script generated (kicad-library-utils/schlib/autogen/connector/)",""
|
||||||
|
"J3, ","1","Conn_01x02_Female","Conn_01x02_Female","Connector_PinSocket_2.54mm:PinSocket_1x02_P2.54mm_Vertical","Generic connector, single row, 01x02, script generated (kicad-library-utils/schlib/autogen/connector/)",""
|
||||||
|
"P1, ","1","USART1","Conn_01x03_Female","Connector_PinSocket_2.54mm:PinSocket_1x03_P2.54mm_Vertical","Generic connector, single row, 01x03, script generated (kicad-library-utils/schlib/autogen/connector/)",""
|
||||||
|
"P2, ","1","USART2/3","Conn_01x03_Female","Connector_PinSocket_2.54mm:PinSocket_1x03_P2.54mm_Vertical","Generic connector, single row, 01x03, script generated (kicad-library-utils/schlib/autogen/connector/)",""
|
||||||
|
"P3, ","1","USB_B","USB_A-RESCUE-stm32","Connector_USB:USB_B_OST_USB-B1HSxx_Horizontal","",""
|
||||||
|
"Q1, ","1","DTA114Y","DTA114Y","Package_TO_SOT_SMD:SOT-323_SC-70_Handsoldering","Digital PNP Transistor, 10k/47k, SOT-23",""
|
||||||
|
"R1, R2, R14, R15, ","4","4k7","R","Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder","",""
|
||||||
|
"R3, ","1","10k","R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"R5, ","1","100k","R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"R6, R7, R8, R9, R10, R11, ","6","220","R","Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder","",""
|
||||||
|
"R12, R13, ","2","22","R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"R16, ","1","1k5","R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder","",""
|
||||||
|
"RV1, ","1","20k","R_POT","my_footprints:Potentiometer","Potentiometer",""
|
||||||
|
"SW1, ","1","Reset","SW_Push","Button_Switch_THT:SW_PUSH_6mm","",""
|
||||||
|
"SW2, ","1","Boot","SW_Push","Button_Switch_THT:SW_PUSH_6mm","",""
|
||||||
|
"U1, ","1","LM1117-3.3","LM1117-3.3-RESCUE-stm32","Package_TO_SOT_SMD:SOT-223","",""
|
||||||
|
"U2, ","1","STM32LQFP48","STM32F042C6Tx","Package_DIP:DIP-48_W15.24mm_Socket_LongPads","",""
|
||||||
|
"U3, ","1","USBLC6-2SC6","USBLC6-2SC6","Package_TO_SOT_SMD:SOT-23-6_Handsoldering","Bidirectional ESD Protection Diode, SOT-23-6",""
|
||||||
|
"Y1, ","1","8MHz","Crystal","Crystal:Crystal_HC49-U_Vertical","Two pin crystal",""
|
||||||
695
F0_F1_F3-LQFP48_testboard/stm32-rescue.lib
Normal file
695
F0_F1_F3-LQFP48_testboard/stm32-rescue.lib
Normal file
@ -0,0 +1,695 @@
|
|||||||
|
EESchema-LIBRARY Version 2.4
|
||||||
|
#encoding utf-8
|
||||||
|
#
|
||||||
|
# +3.3V
|
||||||
|
#
|
||||||
|
DEF +3.3V #PWR 0 0 Y Y 1 F P
|
||||||
|
F0 "#PWR" 0 -150 50 H I C CNN
|
||||||
|
F1 "+3.3V" 0 140 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 -30 50 0 100 N
|
||||||
|
P 2 0 1 0 0 0 0 100 N
|
||||||
|
P 2 0 1 0 0 100 30 50 N
|
||||||
|
X +3V3 1 0 0 0 U 50 50 1 1 W N
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# +5V
|
||||||
|
#
|
||||||
|
DEF +5V #PWR 0 0 Y Y 1 F P
|
||||||
|
F0 "#PWR" 0 -150 50 H I C CNN
|
||||||
|
F1 "+5V" 0 140 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 -30 50 0 100 N
|
||||||
|
P 2 0 1 0 0 0 0 100 N
|
||||||
|
P 2 0 1 0 0 100 30 50 N
|
||||||
|
X +5V 1 0 0 0 U 50 50 1 1 W N
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# C
|
||||||
|
#
|
||||||
|
DEF C C 0 10 N Y 1 F N
|
||||||
|
F0 "C" 25 100 50 H V L CNN
|
||||||
|
F1 "C" 25 -100 50 H V L CNN
|
||||||
|
F2 "" 38 -150 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
C_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 20 -80 -30 80 -30 N
|
||||||
|
P 2 0 1 20 -80 30 80 30 N
|
||||||
|
X ~ 1 0 150 110 D 50 50 1 1 P
|
||||||
|
X ~ 2 0 -150 110 U 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# CONN_01X01
|
||||||
|
#
|
||||||
|
DEF CONN_01X01 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 100 50 H V C CNN
|
||||||
|
F1 "CONN_01X01" 100 0 50 V V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Pin_Header_Straight_1X*
|
||||||
|
Pin_Header_Angled_1X*
|
||||||
|
Socket_Strip_Straight_1X*
|
||||||
|
Socket_Strip_Angled_1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 5 10 -5 0 1 0 N
|
||||||
|
S -50 50 50 -50 0 1 0 N
|
||||||
|
X P1 1 -200 0 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# CONN_01X03
|
||||||
|
#
|
||||||
|
DEF CONN_01X03 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 200 50 H V C CNN
|
||||||
|
F1 "CONN_01X03" 100 0 50 V V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Pin_Header_Straight_1X*
|
||||||
|
Pin_Header_Angled_1X*
|
||||||
|
Socket_Strip_Straight_1X*
|
||||||
|
Socket_Strip_Angled_1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 -95 10 -105 0 1 0 N
|
||||||
|
S -50 5 10 -5 0 1 0 N
|
||||||
|
S -50 105 10 95 0 1 0 N
|
||||||
|
S -50 150 50 -150 0 1 0 N
|
||||||
|
X P1 1 -200 100 150 R 50 50 1 1 P
|
||||||
|
X P2 2 -200 0 150 R 50 50 1 1 P
|
||||||
|
X P3 3 -200 -100 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# CONN_02X03
|
||||||
|
#
|
||||||
|
DEF CONN_02X03 J 0 1 Y N 1 F N
|
||||||
|
F0 "J" 0 200 50 H V C CNN
|
||||||
|
F1 "CONN_02X03" 0 -200 50 H V C CNN
|
||||||
|
F2 "" 0 -1200 50 H I C CNN
|
||||||
|
F3 "" 0 -1200 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Pin_Header_Straight_2X*
|
||||||
|
Pin_Header_Angled_2X*
|
||||||
|
Socket_Strip_Straight_2X*
|
||||||
|
Socket_Strip_Angled_2X*
|
||||||
|
IDC_Header_Straight_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -100 -95 -50 -105 0 1 0 N
|
||||||
|
S -100 5 -50 -5 0 1 0 N
|
||||||
|
S -100 105 -50 95 0 1 0 N
|
||||||
|
S -100 150 100 -150 0 1 0 N
|
||||||
|
S 50 -95 100 -105 0 1 0 N
|
||||||
|
S 50 5 100 -5 0 1 0 N
|
||||||
|
S 50 105 100 95 0 1 0 N
|
||||||
|
X P1 1 -250 100 150 R 50 50 1 1 P
|
||||||
|
X P2 2 250 100 150 L 50 50 1 1 P
|
||||||
|
X P3 3 -250 0 150 R 50 50 1 1 P
|
||||||
|
X P4 4 250 0 150 L 50 50 1 1 P
|
||||||
|
X P5 5 -250 -100 150 R 50 50 1 1 P
|
||||||
|
X P6 6 250 -100 150 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# CP
|
||||||
|
#
|
||||||
|
DEF CP C 0 10 N Y 1 F N
|
||||||
|
F0 "C" 25 100 50 H V L CNN
|
||||||
|
F1 "CP" 25 -100 50 H V L CNN
|
||||||
|
F2 "" 38 -150 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
CP_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -90 20 -90 40 0 1 0 N
|
||||||
|
S -90 20 90 20 0 1 0 N
|
||||||
|
S 90 -20 -90 -40 0 1 0 F
|
||||||
|
S 90 40 -90 40 0 1 0 N
|
||||||
|
S 90 40 90 20 0 1 0 N
|
||||||
|
P 2 0 1 0 -70 90 -30 90 N
|
||||||
|
P 2 0 1 0 -50 110 -50 70 N
|
||||||
|
X ~ 1 0 150 110 D 50 50 1 1 P
|
||||||
|
X ~ 2 0 -150 110 U 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Conn_01x01
|
||||||
|
#
|
||||||
|
DEF Conn_01x01 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 100 50 H V C CNN
|
||||||
|
F1 "Conn_01x01" 0 -100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Connector*:*_??x*mm*
|
||||||
|
Connector*:*1x??x*mm*
|
||||||
|
Pin?Header?Straight?1X*
|
||||||
|
Pin?Header?Angled?1X*
|
||||||
|
Socket?Strip?Straight?1X*
|
||||||
|
Socket?Strip?Angled?1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 5 0 -5 1 1 6 N
|
||||||
|
S -50 50 50 -50 1 1 10 f
|
||||||
|
X Pin_1 1 -200 0 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Conn_01x02
|
||||||
|
#
|
||||||
|
DEF Conn_01x02 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 100 50 H V C CNN
|
||||||
|
F1 "Conn_01x02" 0 -200 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Connector*:*_??x*mm*
|
||||||
|
Connector*:*1x??x*mm*
|
||||||
|
Pin?Header?Straight?1X*
|
||||||
|
Pin?Header?Angled?1X*
|
||||||
|
Socket?Strip?Straight?1X*
|
||||||
|
Socket?Strip?Angled?1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 -95 0 -105 1 1 6 N
|
||||||
|
S -50 5 0 -5 1 1 6 N
|
||||||
|
S -50 50 50 -150 1 1 10 f
|
||||||
|
X Pin_1 1 -200 0 150 R 50 50 1 1 P
|
||||||
|
X Pin_2 2 -200 -100 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Conn_01x07
|
||||||
|
#
|
||||||
|
DEF Conn_01x07 J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 400 50 H V C CNN
|
||||||
|
F1 "Conn_01x07" 0 -400 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
Connector*:*_??x*mm*
|
||||||
|
Connector*:*1x??x*mm*
|
||||||
|
Pin?Header?Straight?1X*
|
||||||
|
Pin?Header?Angled?1X*
|
||||||
|
Socket?Strip?Straight?1X*
|
||||||
|
Socket?Strip?Angled?1X*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -50 -295 0 -305 1 1 6 N
|
||||||
|
S -50 -195 0 -205 1 1 6 N
|
||||||
|
S -50 -95 0 -105 1 1 6 N
|
||||||
|
S -50 5 0 -5 1 1 6 N
|
||||||
|
S -50 105 0 95 1 1 6 N
|
||||||
|
S -50 205 0 195 1 1 6 N
|
||||||
|
S -50 305 0 295 1 1 6 N
|
||||||
|
S -50 350 50 -350 1 1 10 f
|
||||||
|
X Pin_1 1 -200 300 150 R 50 50 1 1 P
|
||||||
|
X Pin_2 2 -200 200 150 R 50 50 1 1 P
|
||||||
|
X Pin_3 3 -200 100 150 R 50 50 1 1 P
|
||||||
|
X Pin_4 4 -200 0 150 R 50 50 1 1 P
|
||||||
|
X Pin_5 5 -200 -100 150 R 50 50 1 1 P
|
||||||
|
X Pin_6 6 -200 -200 150 R 50 50 1 1 P
|
||||||
|
X Pin_7 7 -200 -300 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# DB9_Female
|
||||||
|
#
|
||||||
|
DEF DB9_Female J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 550 50 H V C CNN
|
||||||
|
F1 "DB9_Female" 0 -575 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
DB*F*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
C -70 -400 30 0 1 0 N
|
||||||
|
C -70 -200 30 0 1 0 N
|
||||||
|
C -70 0 30 0 1 0 N
|
||||||
|
C -70 200 30 0 1 0 N
|
||||||
|
C -70 400 30 0 1 0 N
|
||||||
|
C 50 -300 30 0 1 0 N
|
||||||
|
C 50 -100 30 0 1 0 N
|
||||||
|
C 50 100 30 0 1 0 N
|
||||||
|
C 50 300 30 0 1 0 N
|
||||||
|
P 2 0 1 0 -150 -400 -100 -400 N
|
||||||
|
P 2 0 1 0 -150 -300 20 -300 N
|
||||||
|
P 2 0 1 0 -150 -200 -100 -200 N
|
||||||
|
P 2 0 1 0 -150 -100 20 -100 N
|
||||||
|
P 2 0 1 0 -150 0 -100 0 N
|
||||||
|
P 2 0 1 0 -150 100 20 100 N
|
||||||
|
P 2 0 1 0 -150 200 -100 200 N
|
||||||
|
P 2 0 1 0 -150 300 20 300 N
|
||||||
|
P 2 0 1 0 -150 400 -100 400 N
|
||||||
|
P 5 0 1 10 -150 525 -150 -525 150 -375 150 375 -150 525 f
|
||||||
|
X 1 1 -300 400 150 R 50 50 1 1 P
|
||||||
|
X 2 2 -300 200 150 R 50 50 1 1 P
|
||||||
|
X 3 3 -300 0 150 R 50 50 1 1 P
|
||||||
|
X 4 4 -300 -200 150 R 50 50 1 1 P
|
||||||
|
X 5 5 -300 -400 150 R 50 50 1 1 P
|
||||||
|
X 6 6 -300 300 150 R 50 50 1 1 P
|
||||||
|
X 7 7 -300 100 150 R 50 50 1 1 P
|
||||||
|
X 8 8 -300 -100 150 R 50 50 1 1 P
|
||||||
|
X 9 9 -300 -300 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# DB9_Male
|
||||||
|
#
|
||||||
|
DEF DB9_Male J 0 40 Y N 1 F N
|
||||||
|
F0 "J" 0 550 50 H V C CNN
|
||||||
|
F1 "DB9_Male" 0 -575 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
DB*M*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
C -70 -400 30 0 1 0 F
|
||||||
|
C -70 -200 30 0 1 0 F
|
||||||
|
C -70 0 30 0 1 0 F
|
||||||
|
C -70 200 30 0 1 0 F
|
||||||
|
C -70 400 30 0 1 0 F
|
||||||
|
C 50 -300 30 0 1 0 F
|
||||||
|
C 50 -100 30 0 1 0 F
|
||||||
|
C 50 100 30 0 1 0 F
|
||||||
|
C 50 300 30 0 1 0 F
|
||||||
|
P 2 0 1 0 -150 -400 -100 -400 N
|
||||||
|
P 2 0 1 0 -150 -300 20 -300 N
|
||||||
|
P 2 0 1 0 -150 -200 -100 -200 N
|
||||||
|
P 2 0 1 0 -150 -100 20 -100 N
|
||||||
|
P 2 0 1 0 -150 0 -100 0 N
|
||||||
|
P 2 0 1 0 -150 100 20 100 N
|
||||||
|
P 2 0 1 0 -150 200 -100 200 N
|
||||||
|
P 2 0 1 0 -150 300 20 300 N
|
||||||
|
P 2 0 1 0 -150 400 -100 400 N
|
||||||
|
P 5 0 1 10 -150 -525 -150 525 150 375 150 -375 -150 -525 f
|
||||||
|
X 1 1 -300 -400 150 R 50 50 1 1 P
|
||||||
|
X 2 2 -300 -200 150 R 50 50 1 1 P
|
||||||
|
X 3 3 -300 0 150 R 50 50 1 1 P
|
||||||
|
X 4 4 -300 200 150 R 50 50 1 1 P
|
||||||
|
X 5 5 -300 400 150 R 50 50 1 1 P
|
||||||
|
X 6 6 -300 -300 150 R 50 50 1 1 P
|
||||||
|
X 7 7 -300 -100 150 R 50 50 1 1 P
|
||||||
|
X 8 8 -300 100 150 R 50 50 1 1 P
|
||||||
|
X 9 9 -300 300 150 R 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# D_Schottky
|
||||||
|
#
|
||||||
|
DEF D_Schottky D 0 40 N N 1 F N
|
||||||
|
F0 "D" 0 100 50 H V C CNN
|
||||||
|
F1 "D_Schottky" 0 -100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
TO-???*
|
||||||
|
*SingleDiode
|
||||||
|
*_Diode_*
|
||||||
|
*SingleDiode*
|
||||||
|
D_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 50 0 -50 0 N
|
||||||
|
P 4 0 1 8 50 50 50 -50 -50 0 50 50 N
|
||||||
|
P 6 0 1 8 -75 25 -75 50 -50 50 -50 -50 -25 -50 -25 -25 N
|
||||||
|
X K 1 -150 0 100 R 50 50 1 1 P
|
||||||
|
X A 2 150 0 100 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# D_Zener
|
||||||
|
#
|
||||||
|
DEF D_Zener D 0 40 N N 1 F N
|
||||||
|
F0 "D" 0 100 50 H V C CNN
|
||||||
|
F1 "D_Zener" 0 -100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
TO-???*
|
||||||
|
*SingleDiode
|
||||||
|
*_Diode_*
|
||||||
|
*SingleDiode*
|
||||||
|
D_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 0 50 0 -50 0 N
|
||||||
|
P 3 0 1 8 -50 -50 -50 50 -30 50 N
|
||||||
|
P 4 0 1 8 50 -50 50 50 -50 0 50 -50 N
|
||||||
|
X K 1 -150 0 100 R 50 50 1 1 P
|
||||||
|
X A 2 150 0 100 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# GND
|
||||||
|
#
|
||||||
|
DEF GND #PWR 0 0 Y Y 1 F P
|
||||||
|
F0 "#PWR" 0 -250 50 H I C CNN
|
||||||
|
F1 "GND" 0 -150 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
P 6 0 1 0 0 0 0 -50 50 -50 0 -100 -50 -50 0 -50 N
|
||||||
|
X GND 1 0 0 0 D 50 50 1 1 W N
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Jumper_NO_Small
|
||||||
|
#
|
||||||
|
DEF Jumper_NO_Small JP 0 30 N N 1 F N
|
||||||
|
F0 "JP" 0 80 50 H V C CNN
|
||||||
|
F1 "Jumper_NO_Small" 10 -60 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
C -40 0 20 0 1 0 N
|
||||||
|
C 40 0 20 0 1 0 N
|
||||||
|
X 1 1 -100 0 40 R 50 50 0 1 P
|
||||||
|
X 2 2 100 0 40 L 50 50 0 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# LED-RESCUE-stm32
|
||||||
|
#
|
||||||
|
DEF LED-RESCUE-stm32 D 0 40 Y N 1 F N
|
||||||
|
F0 "D" 0 100 50 H V C CNN
|
||||||
|
F1 "LED-RESCUE-stm32" 0 -100 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H V C CNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
$FPLIST
|
||||||
|
LED*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
P 2 0 1 8 -50 -50 -50 50 N
|
||||||
|
P 2 0 1 0 -50 0 50 0 N
|
||||||
|
P 4 0 1 8 50 -50 50 50 -50 0 50 -50 N
|
||||||
|
P 5 0 1 0 -120 -30 -180 -90 -150 -90 -180 -90 -180 -60 N
|
||||||
|
P 5 0 1 0 -70 -30 -130 -90 -100 -90 -130 -90 -130 -60 N
|
||||||
|
X K 1 -150 0 100 R 50 50 1 1 P
|
||||||
|
X A 2 150 0 100 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# LM1117-3.3-RESCUE-stm32
|
||||||
|
#
|
||||||
|
DEF LM1117-3.3-RESCUE-stm32 U 0 30 Y Y 1 F N
|
||||||
|
F0 "U" 100 -250 50 H V C CNN
|
||||||
|
F1 "LM1117-3.3-RESCUE-stm32" 0 250 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
SOT-223*
|
||||||
|
TO-263*
|
||||||
|
TO-252*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -200 -200 200 200 0 1 10 f
|
||||||
|
X GND/ADJ 1 0 -300 100 U 50 50 1 1 W
|
||||||
|
X VO 2 300 50 100 L 50 50 1 1 P
|
||||||
|
X VI 3 -300 0 100 R 50 50 1 1 W
|
||||||
|
X VO 4 300 -50 100 L 50 50 1 1 w
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# MAX471-RESCUE-stm32
|
||||||
|
#
|
||||||
|
DEF MAX471-RESCUE-stm32 U 0 40 Y Y 1 F N
|
||||||
|
F0 "U" -300 350 50 H V L CNN
|
||||||
|
F1 "MAX471-RESCUE-stm32" -300 -350 50 H V L CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
S -300 300 300 -300 0 1 10 f
|
||||||
|
X SHDN 1 -400 -100 100 R 50 50 1 1 I
|
||||||
|
X RS+ 2 -400 200 100 R 50 50 1 1 W
|
||||||
|
X RS+ 3 -400 100 100 R 50 50 1 1 P
|
||||||
|
X GND 4 -400 -200 100 R 50 50 1 1 W
|
||||||
|
X SIGN 5 400 -100 100 L 50 50 1 1 C
|
||||||
|
X RS- 6 400 200 100 L 50 50 1 1 w
|
||||||
|
X RS- 7 400 100 100 L 50 50 1 1 P
|
||||||
|
X OUT 8 400 -200 100 L 50 50 1 1 O
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# MCP2551-I_SN
|
||||||
|
#
|
||||||
|
DEF MCP2551-I_SN U 0 40 Y Y 1 F N
|
||||||
|
F0 "U" -400 350 50 H V L CNN
|
||||||
|
F1 "MCP2551-I_SN" 100 350 50 H V L CNN
|
||||||
|
F2 "Housings_SOIC:SOIC-8_3.9x4.9mm_Pitch1.27mm" 0 -500 50 H I C CIN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
SOIC*Pitch1.27mm*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -400 300 400 -300 0 1 10 f
|
||||||
|
X TXD 1 -500 200 100 R 50 50 1 1 I
|
||||||
|
X VSS 2 0 -400 100 U 50 50 1 1 W
|
||||||
|
X VDD 3 0 400 100 D 50 50 1 1 W
|
||||||
|
X RXD 4 -500 100 100 R 50 50 1 1 O
|
||||||
|
X Vref 5 -500 -100 100 R 50 50 1 1 w
|
||||||
|
X CANL 6 500 -100 100 L 50 50 1 1 B
|
||||||
|
X CANH 7 500 100 100 L 50 50 1 1 B
|
||||||
|
X Rs 8 -500 -200 100 R 50 50 1 1 I
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# PWR_FLAG
|
||||||
|
#
|
||||||
|
DEF PWR_FLAG #FLG 0 0 N N 1 F P
|
||||||
|
F0 "#FLG" 0 75 50 H I C CNN
|
||||||
|
F1 "PWR_FLAG" 0 150 50 H V C CNN
|
||||||
|
F2 "" 0 0 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
P 6 0 1 0 0 0 0 50 -40 75 0 100 40 75 0 50 N
|
||||||
|
X pwr 1 0 0 0 U 50 50 0 0 w
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Q_NMOS_GSD
|
||||||
|
#
|
||||||
|
DEF Q_NMOS_GSD Q 0 0 Y N 1 F N
|
||||||
|
F0 "Q" 200 50 50 H V L CNN
|
||||||
|
F1 "Q_NMOS_GSD" 200 -50 50 H V L CNN
|
||||||
|
F2 "" 200 100 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
C 65 0 111 0 1 10 N
|
||||||
|
C 100 -70 11 0 1 0 F
|
||||||
|
C 100 70 11 0 1 0 F
|
||||||
|
P 2 0 1 0 2 0 10 0 N
|
||||||
|
P 2 0 1 0 30 -70 100 -70 N
|
||||||
|
P 2 0 1 10 30 -50 30 -90 N
|
||||||
|
P 2 0 1 0 30 0 100 0 N
|
||||||
|
P 2 0 1 10 30 20 30 -20 N
|
||||||
|
P 2 0 1 0 30 70 100 70 N
|
||||||
|
P 2 0 1 10 30 90 30 50 N
|
||||||
|
P 2 0 1 0 100 -70 100 -100 N
|
||||||
|
P 2 0 1 0 100 -70 100 0 N
|
||||||
|
P 2 0 1 0 100 100 100 70 N
|
||||||
|
P 3 0 1 10 10 75 10 -75 10 -75 N
|
||||||
|
P 4 0 1 0 40 0 80 15 80 -15 40 0 F
|
||||||
|
P 4 0 1 0 100 -70 130 -70 130 70 100 70 N
|
||||||
|
P 4 0 1 0 110 20 115 15 145 15 150 10 N
|
||||||
|
P 4 0 1 0 130 15 115 -10 145 -10 130 15 N
|
||||||
|
X G 1 -200 0 200 R 50 50 1 1 I
|
||||||
|
X S 2 100 -200 100 U 50 50 1 1 P
|
||||||
|
X D 3 100 200 100 D 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# Q_PMOS_GSD
|
||||||
|
#
|
||||||
|
DEF Q_PMOS_GSD Q 0 0 Y N 1 F N
|
||||||
|
F0 "Q" 200 50 50 H V L CNN
|
||||||
|
F1 "Q_PMOS_GSD" 200 -50 50 H V L CNN
|
||||||
|
F2 "" 200 100 50 H I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
C 65 0 111 0 1 10 N
|
||||||
|
C 100 -70 11 0 1 0 F
|
||||||
|
C 100 70 11 0 1 0 F
|
||||||
|
P 2 0 1 0 2 0 10 0 N
|
||||||
|
P 2 0 1 0 30 -70 100 -70 N
|
||||||
|
P 2 0 1 10 30 -50 30 -90 N
|
||||||
|
P 2 0 1 0 30 0 100 0 N
|
||||||
|
P 2 0 1 10 30 20 30 -20 N
|
||||||
|
P 2 0 1 0 30 70 100 70 N
|
||||||
|
P 2 0 1 10 30 90 30 50 N
|
||||||
|
P 2 0 1 0 100 -70 100 -100 N
|
||||||
|
P 2 0 1 0 100 -70 100 0 N
|
||||||
|
P 2 0 1 0 100 100 100 70 N
|
||||||
|
P 3 0 1 10 10 75 10 -75 10 -75 N
|
||||||
|
P 4 0 1 0 90 0 50 -15 50 15 90 0 F
|
||||||
|
P 4 0 1 0 100 -70 130 -70 130 70 100 70 N
|
||||||
|
P 4 0 1 0 110 -20 115 -15 145 -15 150 -10 N
|
||||||
|
P 4 0 1 0 130 -15 115 10 145 10 130 -15 N
|
||||||
|
X G 1 -200 0 200 R 50 50 1 1 I
|
||||||
|
X S 2 100 -200 100 U 50 50 1 1 P
|
||||||
|
X D 3 100 200 100 D 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# R
|
||||||
|
#
|
||||||
|
DEF R R 0 0 N Y 1 F N
|
||||||
|
F0 "R" 80 0 50 V V C CNN
|
||||||
|
F1 "R" 0 0 50 V V C CNN
|
||||||
|
F2 "" -70 0 50 V I C CNN
|
||||||
|
F3 "" 0 0 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
R_*
|
||||||
|
R_*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -40 -100 40 100 0 1 10 N
|
||||||
|
X ~ 1 0 150 50 D 50 50 1 1 P
|
||||||
|
X ~ 2 0 -150 50 U 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# SP0502BAHT
|
||||||
|
#
|
||||||
|
DEF SP0502BAHT D 0 40 Y N 1 F N
|
||||||
|
F0 "D" 225 100 50 H V L CNN
|
||||||
|
F1 "SP0502BAHT" 225 25 50 H V L CNN
|
||||||
|
F2 "TO_SOT_Packages_SMD:SOT-23" 225 -50 50 H I L CNN
|
||||||
|
F3 "" 125 125 50 H I C CNN
|
||||||
|
$FPLIST
|
||||||
|
SOT?23*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -175 100 175 -100 0 1 10 f
|
||||||
|
P 2 0 1 0 -100 100 -100 50 N
|
||||||
|
P 2 0 1 0 0 -50 0 -100 N
|
||||||
|
P 2 0 1 0 100 100 100 50 N
|
||||||
|
P 4 0 1 0 -150 75 -125 50 -75 50 -50 25 N
|
||||||
|
P 4 0 1 0 -100 0 -100 -50 100 -50 100 0 N
|
||||||
|
P 4 0 1 0 -100 50 -75 0 -125 0 -100 50 F
|
||||||
|
P 4 0 1 0 50 75 75 50 125 50 150 25 N
|
||||||
|
P 4 0 1 0 100 50 75 0 125 0 100 50 F
|
||||||
|
X A 3 0 -200 100 U 50 50 0 0 I
|
||||||
|
X K 1 -100 200 100 D 50 50 1 1 I
|
||||||
|
X K 2 100 200 100 D 50 50 1 1 I
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# STM32F042C6Tx
|
||||||
|
#
|
||||||
|
DEF STM32F042C6Tx U 0 40 Y Y 1 L N
|
||||||
|
F0 "U" -3000 1725 50 H V L BNN
|
||||||
|
F1 "STM32F042C6Tx" 3000 1725 50 H V R BNN
|
||||||
|
F2 "LQFP48" 3000 1675 50 H V R TNN
|
||||||
|
F3 "" 0 0 50 H V C CNN
|
||||||
|
DRAW
|
||||||
|
S -3000 -1700 3000 1700 0 1 10 f
|
||||||
|
X VBAT 1 -3100 1100 100 R 50 50 1 1 W
|
||||||
|
X ADC_IN0/RTC_TAMP2/SYS_WKUP1/TIM2_CH1/TIM2_ETR/TSC_G1_IO1/USART2_CTS/PA0 10 3100 100 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN1/TIM2_CH2/TSC_G1_IO2/USART2_DE/USART2_RTS/PA1 11 3100 0 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN2/SYS_WKUP4/TIM2_CH3/TSC_G1_IO3/USART2_TX/PA2 12 3100 -100 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN3/TIM2_CH4/TSC_G1_IO4/USART2_RX/PA3 13 3100 -200 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN4/I2S1_WS/SPI1_NSS/TIM14_CH1/TSC_G2_IO1/USART2_CK/USB_OE/PA4 14 3100 -300 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN5/CEC/I2S1_CK/SPI1_SCK/TIM2_CH1/TIM2_ETR/TSC_G2_IO2/PA5 15 3100 -400 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN6/I2S1_MCK/SPI1_MISO/TIM16_CH1/TIM1_BKIN/TIM3_CH1/TSC_G2_IO3/PA6 16 3100 -500 100 L 50 50 1 1 B
|
||||||
|
X ADC_IN7/I2S1_SD/SPI1_MOSI/TIM14_CH1/TIM17_CH1/TIM1_CH1N/TIM3_CH2/TSC_G2_IO4/PA7 17 3100 -600 100 L 50 50 1 1 B
|
||||||
|
X PB0/ADC_IN8/TIM1_CH2N/TIM3_CH3/TSC_G3_IO2 18 -3100 100 100 R 50 50 1 1 B
|
||||||
|
X PB1/ADC_IN9/TIM14_CH1/TIM1_CH3N/TIM3_CH4/TSC_G3_IO3 19 -3100 0 100 R 50 50 1 1 B
|
||||||
|
X PC13/RTC_OUT_ALARM/RTC_OUT_CALIB/RTC_TAMP1/RTC_TS/SYS_WKUP2 2 -3100 500 100 R 50 50 1 1 B
|
||||||
|
X PB2/TSC_G3_IO4 20 -3100 -100 100 R 50 50 1 1 B
|
||||||
|
X PB10/CEC/I2C1_SCL/SPI2_SCK/TIM2_CH3/TSC_SYNC 21 -3100 -900 100 R 50 50 1 1 B
|
||||||
|
X PB11/I2C1_SDA/TIM2_CH4 22 -3100 -1000 100 R 50 50 1 1 B
|
||||||
|
X VSS 23 -200 -1800 100 U 50 50 1 1 W
|
||||||
|
X VDD 24 -200 1800 100 D 50 50 1 1 W
|
||||||
|
X PB12/SPI2_NSS/TIM1_BKIN 25 -3100 -1100 100 R 50 50 1 1 B
|
||||||
|
X PB13/I2C1_SCL/SPI2_SCK/TIM1_CH1N 26 -3100 -1200 100 R 50 50 1 1 B
|
||||||
|
X PB14/I2C1_SDA/SPI2_MISO/TIM1_CH2N 27 -3100 -1300 100 R 50 50 1 1 B
|
||||||
|
X PB15/RTC_REFIN/SPI2_MOSI/SYS_WKUP7/TIM1_CH3N 28 -3100 -1400 100 R 50 50 1 1 B
|
||||||
|
X CRS_SYNC/RCC_MCO/TIM1_CH1/USART1_CK/PA8 29 3100 -700 100 L 50 50 1 1 B
|
||||||
|
X PC14/RCC_OSC32_IN 3 -3100 400 100 R 50 50 1 1 B
|
||||||
|
X I2C1_SCL/TIM1_CH2/TSC_G4_IO1/USART1_TX/PA9 30 3100 -800 100 L 50 50 1 1 B
|
||||||
|
X I2C1_SDA/TIM17_BKIN/TIM1_CH3/TSC_G4_IO2/USART1_RX/PA10 31 3100 -900 100 L 50 50 1 1 B
|
||||||
|
X CAN_RX/I2C1_SCL/TIM1_CH4/TSC_G4_IO3/USART1_CTS/USB_DM/PA11 32 3100 -1000 100 L 50 50 1 1 B
|
||||||
|
X CAN_TX/I2C1_SDA/TIM1_ETR/TSC_G4_IO4/USART1_DE/USART1_RTS/USB_DP/PA12 33 3100 -1100 100 L 50 50 1 1 B
|
||||||
|
X IR_OUT/SYS_SWDIO/USB_OE/PA13 34 3100 -1200 100 L 50 50 1 1 B
|
||||||
|
X VSS 35 -100 -1800 100 U 50 50 1 1 W
|
||||||
|
X VDDIO2 36 100 1800 100 D 50 50 1 1 W
|
||||||
|
X SYS_SWCLK/USART2_TX/PA14 37 3100 -1300 100 L 50 50 1 1 B
|
||||||
|
X I2S1_WS/SPI1_NSS/TIM2_CH1/TIM2_ETR/USART2_RX/USB_OE/PA15 38 3100 -1400 100 L 50 50 1 1 B
|
||||||
|
X PB3/I2S1_CK/SPI1_SCK/TIM2_CH2/TSC_G5_IO1 39 -3100 -200 100 R 50 50 1 1 B
|
||||||
|
X PC15/RCC_OSC32_OUT 4 -3100 300 100 R 50 50 1 1 B
|
||||||
|
X PB4/I2S1_MCK/SPI1_MISO/TIM17_BKIN/TIM3_CH1/TSC_G5_IO2 40 -3100 -300 100 R 50 50 1 1 B
|
||||||
|
X PB5/I2C1_SMBA/I2S1_SD/SPI1_MOSI/SYS_WKUP6/TIM16_BKIN/TIM3_CH2 41 -3100 -400 100 R 50 50 1 1 B
|
||||||
|
X PB6/I2C1_SCL/TIM16_CH1N/TSC_G5_IO3/USART1_TX 42 -3100 -500 100 R 50 50 1 1 B
|
||||||
|
X PB7/I2C1_SDA/TIM17_CH1N/TSC_G5_IO4/USART1_RX 43 -3100 -600 100 R 50 50 1 1 B
|
||||||
|
X PF11 44 -3100 700 100 R 50 50 1 1 B
|
||||||
|
X PB8/CAN_RX/CEC/I2C1_SCL/TIM16_CH1/TSC_SYNC 45 -3100 -700 100 R 50 50 1 1 B
|
||||||
|
X PB9/CAN_TX/I2C1_SDA/IR_OUT/SPI2_NSS/TIM17_CH1 46 -3100 -800 100 R 50 50 1 1 B
|
||||||
|
X VSS 47 0 -1800 100 U 50 50 1 1 W
|
||||||
|
X VDD 48 -100 1800 100 D 50 50 1 1 W
|
||||||
|
X PF0/CRS_SYNC/I2C1_SDA/RCC_OSC_IN 5 -3100 900 100 R 50 50 1 1 I
|
||||||
|
X PF1/I2C1_SCL/RCC_OSC_OUT 6 -3100 800 100 R 50 50 1 1 I
|
||||||
|
X NRST 7 -3100 1300 100 R 50 50 1 1 I
|
||||||
|
X VSSA 8 100 -1800 100 U 50 50 1 1 W
|
||||||
|
X VDDA 9 0 1800 100 D 50 50 1 1 W
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# SW_Push
|
||||||
|
#
|
||||||
|
DEF SW_Push SW 0 40 N N 1 F N
|
||||||
|
F0 "SW" 50 100 50 H V L CNN
|
||||||
|
F1 "SW_Push" 0 -60 50 H V C CNN
|
||||||
|
F2 "" 0 200 50 H I C CNN
|
||||||
|
F3 "" 0 200 50 H I C CNN
|
||||||
|
DRAW
|
||||||
|
C -80 0 20 0 1 0 N
|
||||||
|
C 80 0 20 0 1 0 N
|
||||||
|
P 2 0 1 0 0 50 0 120 N
|
||||||
|
P 2 0 1 0 100 50 -100 50 N
|
||||||
|
X 1 1 -200 0 100 R 50 50 0 1 P
|
||||||
|
X 2 2 200 0 100 L 50 50 0 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
# USB_A-RESCUE-stm32
|
||||||
|
#
|
||||||
|
DEF USB_A-RESCUE-stm32 P 0 40 Y Y 1 F N
|
||||||
|
F0 "P" 200 -200 50 H V C CNN
|
||||||
|
F1 "USB_A-RESCUE-stm32" -50 200 50 H V C CNN
|
||||||
|
F2 "" -50 -100 50 V V C CNN
|
||||||
|
F3 "" -50 -100 50 V V C CNN
|
||||||
|
$FPLIST
|
||||||
|
USB*
|
||||||
|
$ENDFPLIST
|
||||||
|
DRAW
|
||||||
|
S -250 -150 150 150 0 1 0 N
|
||||||
|
S -205 -150 -195 -120 0 1 0 N
|
||||||
|
S -105 -150 -95 -120 0 1 0 N
|
||||||
|
S -5 -150 5 -120 0 1 0 N
|
||||||
|
S 95 -150 105 -120 0 1 0 N
|
||||||
|
X VBUS 1 -200 -300 150 U 50 50 1 1 W
|
||||||
|
X D- 2 -100 -300 150 U 50 50 1 1 P
|
||||||
|
X D+ 3 0 -300 150 U 50 50 1 1 P
|
||||||
|
X GND 4 100 -300 150 U 50 50 1 1 W
|
||||||
|
X shield 5 300 100 150 L 50 50 1 1 P
|
||||||
|
ENDDRAW
|
||||||
|
ENDDEF
|
||||||
|
#
|
||||||
|
#End Library
|
||||||
73
F0_F1_F3-LQFP48_testboard/stm32.bom
Normal file
73
F0_F1_F3-LQFP48_testboard/stm32.bom
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
"Source:","/home/eddy/Docs/SAO/ELECTRONICS/STM32/F0-srcs/F0_F1_testboard/kicad/stm32.sch"
|
||||||
|
"Date:","þÔ 16 ÍÁÑ 2019 13:55:26"
|
||||||
|
"Tool:","Eeschema (6.0.0-rc1-dev-1613-ga55d9819b)"
|
||||||
|
"Generator:","/usr/local/share/kicad/plugins/bom_csv_grouped_by_value.py"
|
||||||
|
"Component Count:","35"
|
||||||
|
|
||||||
|
"Individual Components:"
|
||||||
|
|
||||||
|
"Item","Qty","Reference(s)","Value","LibPart","Footprint","Datasheet"
|
||||||
|
"","","C1","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","C2","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","C3","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","C4","47u","stm32-rescue:CP","Capacitor_Tantalum_SMD:CP_EIA-3216-18_Kemet-A_Pad1.58x1.35mm_HandSolder",""
|
||||||
|
"","","C5","12","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","C6","12","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","C7","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","C8","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","C9","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","C10","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","D1","LED","stm32-rescue:LED-RESCUE-stm32","LED_THT:LED_D3.0mm",""
|
||||||
|
"","","D2","IP4220CZ6","Power_Protection:SP0505BAHT","TO_SOT_Packages_SMD:SOT-23-6_Handsoldering","http://www.littelfuse.com/~/media/files/littelfuse/technical%20resources/documents/data%20sheets/sp05xxba.pdf"
|
||||||
|
"","","D3","LED","stm32-rescue:LED-RESCUE-stm32","LED_THT:LED_D5.0mm",""
|
||||||
|
"","","D4","LED","stm32-rescue:LED-RESCUE-stm32","LED_THT:LED_D5.0mm",""
|
||||||
|
"","","P1","USART1","stm32-rescue:CONN_01X03","Connector_PinHeader_2.54mm:PinHeader_1x03_P2.54mm_Vertical",""
|
||||||
|
"","","P2","USB_B","stm32-rescue:USB_A-RESCUE-stm32","Connectors_USB:USB_Micro-B_Wuerth_629105150521",""
|
||||||
|
"","","Q1","DTA114Y","Transistor_BJT:DTA114Y","TO_SOT_Packages_SMD:SOT-323_SC-70_Handsoldering",""
|
||||||
|
"","","R1","10k","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","R2","10k","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","R3","100k","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","R4","220","stm32-rescue:R","Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder",""
|
||||||
|
"","","R5","220","stm32-rescue:R","Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder",""
|
||||||
|
"","","R6","220","stm32-rescue:R","Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder",""
|
||||||
|
"","","R7","22","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","R8","22","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","R9","1k5","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"","","RV1","10k","Device:R_POT","my_footprints:Potentiometer","~"
|
||||||
|
"","","SW1","Reset","stm32-rescue:SW_Push","Button_Switch_THT:SW_PUSH_6mm",""
|
||||||
|
"","","SW2","Boot","stm32-rescue:SW_Push","Button_Switch_THT:SW_PUSH_6mm",""
|
||||||
|
"","","SW3","Button0","stm32-rescue:SW_Push","Button_Switch_THT:SW_PUSH_6mm",""
|
||||||
|
"","","SW4","Button1","stm32-rescue:SW_Push","Button_Switch_THT:SW_PUSH_6mm",""
|
||||||
|
"","","U1","LM1117-3.3","stm32-rescue:LM1117-3.3-RESCUE-stm32","TO_SOT_Packages_SMD:SOT-223",""
|
||||||
|
"","","U2","STM32F042C6Tx","stm32-rescue:STM32F042C6Tx","Package_DIP:DIP-48_W15.24mm_Socket_LongPads",""
|
||||||
|
"","","U3","USBLC6-2SC6","Power_Protection:USBLC6-2SC6","TO_SOT_Packages_SMD:SOT-23-6_Handsoldering","http://www2.st.com/resource/en/datasheet/CD00050750.pdf"
|
||||||
|
"","","Y1","8MHz","Device:Crystal","Crystal:Crystal_HC49-U_Vertical","~"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
"Collated Components:"
|
||||||
|
|
||||||
|
"Item","Qty","Reference(s)","Value","LibPart","Footprint","Datasheet"
|
||||||
|
"1","7","C1, C2, C3, C7, C8, C9, C10","0.1","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"2","1","C4","47u","stm32-rescue:CP","Capacitor_Tantalum_SMD:CP_EIA-3216-18_Kemet-A_Pad1.58x1.35mm_HandSolder",""
|
||||||
|
"3","2","C5, C6","12","stm32-rescue:C","Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"4","1","D1","LED","stm32-rescue:LED-RESCUE-stm32","LED_THT:LED_D3.0mm",""
|
||||||
|
"5","1","D2","IP4220CZ6","Power_Protection:SP0505BAHT","TO_SOT_Packages_SMD:SOT-23-6_Handsoldering","http://www.littelfuse.com/~/media/files/littelfuse/technical%20resources/documents/data%20sheets/sp05xxba.pdf"
|
||||||
|
"6","2","D3, D4","LED","stm32-rescue:LED-RESCUE-stm32","LED_THT:LED_D5.0mm",""
|
||||||
|
"7","1","P1","USART1","stm32-rescue:CONN_01X03","Connector_PinHeader_2.54mm:PinHeader_1x03_P2.54mm_Vertical",""
|
||||||
|
"8","1","P2","USB_B","stm32-rescue:USB_A-RESCUE-stm32","Connectors_USB:USB_Micro-B_Wuerth_629105150521",""
|
||||||
|
"9","1","Q1","DTA114Y","Transistor_BJT:DTA114Y","TO_SOT_Packages_SMD:SOT-323_SC-70_Handsoldering",""
|
||||||
|
"10","2","R1, R2","10k","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"11","1","R3","100k","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"12","3","R4, R5, R6","220","stm32-rescue:R","Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder",""
|
||||||
|
"13","2","R7, R8","22","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"14","1","R9","1k5","stm32-rescue:R","Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder",""
|
||||||
|
"15","1","RV1","10k","Device:R_POT","my_footprints:Potentiometer","~"
|
||||||
|
"16","1","SW1","Reset","stm32-rescue:SW_Push","Button_Switch_THT:SW_PUSH_6mm",""
|
||||||
|
"17","1","SW2","Boot","stm32-rescue:SW_Push","Button_Switch_THT:SW_PUSH_6mm",""
|
||||||
|
"18","1","SW3","Button0","stm32-rescue:SW_Push","Button_Switch_THT:SW_PUSH_6mm",""
|
||||||
|
"19","1","SW4","Button1","stm32-rescue:SW_Push","Button_Switch_THT:SW_PUSH_6mm",""
|
||||||
|
"20","1","U1","LM1117-3.3","stm32-rescue:LM1117-3.3-RESCUE-stm32","TO_SOT_Packages_SMD:SOT-223",""
|
||||||
|
"21","1","U2","STM32F042C6Tx","stm32-rescue:STM32F042C6Tx","Package_DIP:DIP-48_W15.24mm_Socket_LongPads",""
|
||||||
|
"22","1","U3","USBLC6-2SC6","Power_Protection:USBLC6-2SC6","TO_SOT_Packages_SMD:SOT-23-6_Handsoldering","http://www2.st.com/resource/en/datasheet/CD00050750.pdf"
|
||||||
|
"23","1","Y1","8MHz","Device:Crystal","Crystal:Crystal_HC49-U_Vertical","~"
|
||||||
4756
F0_F1_F3-LQFP48_testboard/stm32.kicad_pcb
Normal file
4756
F0_F1_F3-LQFP48_testboard/stm32.kicad_pcb
Normal file
File diff suppressed because it is too large
Load Diff
816
F0_F1_F3-LQFP48_testboard/stm32.net
Normal file
816
F0_F1_F3-LQFP48_testboard/stm32.net
Normal file
@ -0,0 +1,816 @@
|
|||||||
|
(export (version D)
|
||||||
|
(design
|
||||||
|
(source /Big/Data/00__Electronics/STM32/F0_F1_F3-LQFP48_testboard/stm32.sch)
|
||||||
|
(date "Вт 22 июн 2021 23:00:03")
|
||||||
|
(tool "Eeschema 5.1.10")
|
||||||
|
(sheet (number 1) (name /) (tstamps /)
|
||||||
|
(title_block
|
||||||
|
(title)
|
||||||
|
(company)
|
||||||
|
(rev)
|
||||||
|
(date)
|
||||||
|
(source stm32.sch)
|
||||||
|
(comment (number 1) (value ""))
|
||||||
|
(comment (number 2) (value ""))
|
||||||
|
(comment (number 3) (value ""))
|
||||||
|
(comment (number 4) (value "")))))
|
||||||
|
(components
|
||||||
|
(comp (ref U1)
|
||||||
|
(value LM1117-3.3)
|
||||||
|
(footprint Package_TO_SOT_SMD:SOT-223)
|
||||||
|
(libsource (lib stm32-rescue) (part LM1117-3.3-RESCUE-stm32) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 58C431FC))
|
||||||
|
(comp (ref C4)
|
||||||
|
(value 47u)
|
||||||
|
(footprint Capacitor_Tantalum_SMD:CP_EIA-6032-28_Kemet-C_Pad2.25x2.35mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part CP) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 58C454F6))
|
||||||
|
(comp (ref D1)
|
||||||
|
(value LED)
|
||||||
|
(footprint LED_THT:LED_D3.0mm)
|
||||||
|
(libsource (lib stm32-rescue) (part LED-RESCUE-stm32) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5909BFFC))
|
||||||
|
(comp (ref R6)
|
||||||
|
(value 220)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5909C002))
|
||||||
|
(comp (ref R3)
|
||||||
|
(value 10k)
|
||||||
|
(footprint Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 590D30C8))
|
||||||
|
(comp (ref C2)
|
||||||
|
(value 0.1)
|
||||||
|
(footprint Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part C) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 590D4150))
|
||||||
|
(comp (ref C1)
|
||||||
|
(value 0.1)
|
||||||
|
(footprint Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part C) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 590D4832))
|
||||||
|
(comp (ref SW2)
|
||||||
|
(value Boot)
|
||||||
|
(footprint Button_Switch_THT:SW_PUSH_6mm)
|
||||||
|
(libsource (lib stm32-rescue) (part SW_Push) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5909F6B6))
|
||||||
|
(comp (ref SW1)
|
||||||
|
(value Reset)
|
||||||
|
(footprint Button_Switch_THT:SW_PUSH_6mm)
|
||||||
|
(libsource (lib stm32-rescue) (part SW_Push) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 590A0134))
|
||||||
|
(comp (ref C7)
|
||||||
|
(value 0.1)
|
||||||
|
(footprint Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part C) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CE67302))
|
||||||
|
(comp (ref C8)
|
||||||
|
(value 0.1)
|
||||||
|
(footprint Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part C) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CE67308))
|
||||||
|
(comp (ref C9)
|
||||||
|
(value 0.1)
|
||||||
|
(footprint Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part C) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CE6730E))
|
||||||
|
(comp (ref C10)
|
||||||
|
(value 0.1)
|
||||||
|
(footprint Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part C) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CE67321))
|
||||||
|
(comp (ref P3)
|
||||||
|
(value USB_B)
|
||||||
|
(footprint Connector_USB:USB_B_OST_USB-B1HSxx_Horizontal)
|
||||||
|
(libsource (lib stm32-rescue) (part USB_A-RESCUE-stm32) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CEABE76))
|
||||||
|
(comp (ref P1)
|
||||||
|
(value USART1)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x03_P2.54mm_Vertical)
|
||||||
|
(libsource (lib Connector) (part Conn_01x03_Female) (description "Generic connector, single row, 01x03, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CEABE88))
|
||||||
|
(comp (ref R12)
|
||||||
|
(value 22)
|
||||||
|
(footprint Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CEABEA6))
|
||||||
|
(comp (ref R13)
|
||||||
|
(value 22)
|
||||||
|
(footprint Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CEABEAC))
|
||||||
|
(comp (ref U3)
|
||||||
|
(value USBLC6-2SC6)
|
||||||
|
(footprint Package_TO_SOT_SMD:SOT-23-6_Handsoldering)
|
||||||
|
(datasheet http://www2.st.com/resource/en/datasheet/CD00050750.pdf)
|
||||||
|
(libsource (lib Power_Protection) (part USBLC6-2SC6) (description "Bidirectional ESD Protection Diode, SOT-23-6"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CED0250))
|
||||||
|
(comp (ref C3)
|
||||||
|
(value 0.1)
|
||||||
|
(footprint Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part C) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D05A623))
|
||||||
|
(comp (ref R5)
|
||||||
|
(value 100k)
|
||||||
|
(footprint Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D1076F1))
|
||||||
|
(comp (ref D3)
|
||||||
|
(value LED)
|
||||||
|
(footprint LED_THT:LED_D3.0mm)
|
||||||
|
(libsource (lib stm32-rescue) (part LED-RESCUE-stm32) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D1AC2F3))
|
||||||
|
(comp (ref D2)
|
||||||
|
(value LED)
|
||||||
|
(footprint LED_THT:LED_D3.0mm)
|
||||||
|
(libsource (lib stm32-rescue) (part LED-RESCUE-stm32) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D1AD231))
|
||||||
|
(comp (ref Y1)
|
||||||
|
(value 8MHz)
|
||||||
|
(footprint Crystal:Crystal_HC49-U_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Device) (part Crystal) (description "Two pin crystal"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D1F4994))
|
||||||
|
(comp (ref C6)
|
||||||
|
(value 12)
|
||||||
|
(footprint Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part C) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D1F64B1))
|
||||||
|
(comp (ref C5)
|
||||||
|
(value 12)
|
||||||
|
(footprint Capacitor_SMD:C_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part C) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D1F7471))
|
||||||
|
(comp (ref R7)
|
||||||
|
(value 220)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D3F2F98))
|
||||||
|
(comp (ref R8)
|
||||||
|
(value 220)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D3F3639))
|
||||||
|
(comp (ref R16)
|
||||||
|
(value 1k5)
|
||||||
|
(footprint Resistor_SMD:R_0603_1608Metric_Pad1.05x0.95mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D5EA0B2))
|
||||||
|
(comp (ref Q1)
|
||||||
|
(value DTA114Y)
|
||||||
|
(footprint Package_TO_SOT_SMD:SOT-323_SC-70_Handsoldering)
|
||||||
|
(libsource (lib Transistor_BJT) (part DTA114Y) (description "Digital PNP Transistor, 10k/47k, SOT-23"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D5EB488))
|
||||||
|
(comp (ref RV1)
|
||||||
|
(value 20k)
|
||||||
|
(footprint my_footprints:Potentiometer)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Device) (part R_POT) (description Potentiometer))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5D64D13D))
|
||||||
|
(comp (ref R14)
|
||||||
|
(value 4k7)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D2E1DE))
|
||||||
|
(comp (ref R15)
|
||||||
|
(value 4k7)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D2EBC4))
|
||||||
|
(comp (ref P2)
|
||||||
|
(value USART2/3)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x03_P2.54mm_Vertical)
|
||||||
|
(libsource (lib Connector) (part Conn_01x03_Female) (description "Generic connector, single row, 01x03, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D365C8))
|
||||||
|
(comp (ref U2)
|
||||||
|
(value STM32LQFP48)
|
||||||
|
(footprint Package_DIP:DIP-48_W15.24mm_Socket_LongPads)
|
||||||
|
(libsource (lib stm32-rescue) (part STM32F042C6Tx) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 5CDF834A))
|
||||||
|
(comp (ref J12)
|
||||||
|
(value Conn_01x01_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x01_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x01_Female) (description "Generic connector, single row, 01x01, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D3E39B))
|
||||||
|
(comp (ref D4)
|
||||||
|
(value LED)
|
||||||
|
(footprint LED_THT:LED_D3.0mm)
|
||||||
|
(libsource (lib stm32-rescue) (part LED-RESCUE-stm32) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D3FAEC))
|
||||||
|
(comp (ref R9)
|
||||||
|
(value 220)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D40000))
|
||||||
|
(comp (ref D5)
|
||||||
|
(value LED)
|
||||||
|
(footprint LED_THT:LED_D3.0mm)
|
||||||
|
(libsource (lib stm32-rescue) (part LED-RESCUE-stm32) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D42259))
|
||||||
|
(comp (ref R10)
|
||||||
|
(value 220)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D42795))
|
||||||
|
(comp (ref J2)
|
||||||
|
(value Conn_01x01_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x01_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x01_Female) (description "Generic connector, single row, 01x01, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D5B482))
|
||||||
|
(comp (ref J4)
|
||||||
|
(value Conn_01x01_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x01_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x01_Female) (description "Generic connector, single row, 01x01, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D5EFE7))
|
||||||
|
(comp (ref J8)
|
||||||
|
(value Conn_01x04_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x04_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x04_Female) (description "Generic connector, single row, 01x04, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D62BA1))
|
||||||
|
(comp (ref J6)
|
||||||
|
(value Conn_01x04_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x04_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x04_Female) (description "Generic connector, single row, 01x04, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D63CA9))
|
||||||
|
(comp (ref J5)
|
||||||
|
(value Conn_01x04_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x04_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x04_Female) (description "Generic connector, single row, 01x04, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D6404E))
|
||||||
|
(comp (ref J11)
|
||||||
|
(value Conn_01x04_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x04_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x04_Female) (description "Generic connector, single row, 01x04, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D71C3A))
|
||||||
|
(comp (ref D6)
|
||||||
|
(value LED)
|
||||||
|
(footprint LED_THT:LED_D3.0mm)
|
||||||
|
(libsource (lib stm32-rescue) (part LED-RESCUE-stm32) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D7D866))
|
||||||
|
(comp (ref R11)
|
||||||
|
(value 220)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D7DE9A))
|
||||||
|
(comp (ref J10)
|
||||||
|
(value Conn_01x01_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x01_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x01_Female) (description "Generic connector, single row, 01x01, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D84738))
|
||||||
|
(comp (ref J7)
|
||||||
|
(value Conn_01x04_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x04_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x04_Female) (description "Generic connector, single row, 01x04, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D8D483))
|
||||||
|
(comp (ref J9)
|
||||||
|
(value Conn_01x04_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x04_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x04_Female) (description "Generic connector, single row, 01x04, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D9540E))
|
||||||
|
(comp (ref R2)
|
||||||
|
(value 4k7)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D9CAFF))
|
||||||
|
(comp (ref R1)
|
||||||
|
(value 4k7)
|
||||||
|
(footprint Resistor_SMD:R_0805_2012Metric_Pad1.15x1.40mm_HandSolder)
|
||||||
|
(libsource (lib stm32-rescue) (part R) (description ""))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60D9FC64))
|
||||||
|
(comp (ref J1)
|
||||||
|
(value Conn_01x04_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x04_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x04_Female) (description "Generic connector, single row, 01x04, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60DA399B))
|
||||||
|
(comp (ref J3)
|
||||||
|
(value Conn_01x02_Female)
|
||||||
|
(footprint Connector_PinSocket_2.54mm:PinSocket_1x02_P2.54mm_Vertical)
|
||||||
|
(datasheet ~)
|
||||||
|
(libsource (lib Connector) (part Conn_01x02_Female) (description "Generic connector, single row, 01x02, script generated (kicad-library-utils/schlib/autogen/connector/)"))
|
||||||
|
(sheetpath (names /) (tstamps /))
|
||||||
|
(tstamp 60DAE2B7)))
|
||||||
|
(libparts
|
||||||
|
(libpart (lib Connector) (part Conn_01x01_Female)
|
||||||
|
(description "Generic connector, single row, 01x01, script generated (kicad-library-utils/schlib/autogen/connector/)")
|
||||||
|
(docs ~)
|
||||||
|
(footprints
|
||||||
|
(fp Connector*:*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) J)
|
||||||
|
(field (name Value) Conn_01x01_Female))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name Pin_1) (type passive))))
|
||||||
|
(libpart (lib Connector) (part Conn_01x02_Female)
|
||||||
|
(description "Generic connector, single row, 01x02, script generated (kicad-library-utils/schlib/autogen/connector/)")
|
||||||
|
(docs ~)
|
||||||
|
(footprints
|
||||||
|
(fp Connector*:*_1x??_*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) J)
|
||||||
|
(field (name Value) Conn_01x02_Female))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name Pin_1) (type passive))
|
||||||
|
(pin (num 2) (name Pin_2) (type passive))))
|
||||||
|
(libpart (lib Connector) (part Conn_01x03_Female)
|
||||||
|
(description "Generic connector, single row, 01x03, script generated (kicad-library-utils/schlib/autogen/connector/)")
|
||||||
|
(docs ~)
|
||||||
|
(footprints
|
||||||
|
(fp Connector*:*_1x??_*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) J)
|
||||||
|
(field (name Value) Conn_01x03_Female))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name Pin_1) (type passive))
|
||||||
|
(pin (num 2) (name Pin_2) (type passive))
|
||||||
|
(pin (num 3) (name Pin_3) (type passive))))
|
||||||
|
(libpart (lib Connector) (part Conn_01x04_Female)
|
||||||
|
(description "Generic connector, single row, 01x04, script generated (kicad-library-utils/schlib/autogen/connector/)")
|
||||||
|
(docs ~)
|
||||||
|
(footprints
|
||||||
|
(fp Connector*:*_1x??_*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) J)
|
||||||
|
(field (name Value) Conn_01x04_Female))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name Pin_1) (type passive))
|
||||||
|
(pin (num 2) (name Pin_2) (type passive))
|
||||||
|
(pin (num 3) (name Pin_3) (type passive))
|
||||||
|
(pin (num 4) (name Pin_4) (type passive))))
|
||||||
|
(libpart (lib Device) (part Crystal)
|
||||||
|
(description "Two pin crystal")
|
||||||
|
(docs ~)
|
||||||
|
(footprints
|
||||||
|
(fp Crystal*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) Y)
|
||||||
|
(field (name Value) Crystal))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name 1) (type passive))
|
||||||
|
(pin (num 2) (name 2) (type passive))))
|
||||||
|
(libpart (lib Device) (part R_POT)
|
||||||
|
(description Potentiometer)
|
||||||
|
(docs ~)
|
||||||
|
(footprints
|
||||||
|
(fp Potentiometer*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) RV)
|
||||||
|
(field (name Value) R_POT))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name 1) (type passive))
|
||||||
|
(pin (num 2) (name 2) (type passive))
|
||||||
|
(pin (num 3) (name 3) (type passive))))
|
||||||
|
(libpart (lib Power_Protection) (part USBLC6-2SC6)
|
||||||
|
(description "Bidirectional ESD Protection Diode, SOT-23-6")
|
||||||
|
(docs http://www2.st.com/resource/en/datasheet/CD00050750.pdf)
|
||||||
|
(footprints
|
||||||
|
(fp SOT?23*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) U)
|
||||||
|
(field (name Value) USBLC6-2SC6)
|
||||||
|
(field (name Footprint) Package_TO_SOT_SMD:SOT-23-6))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name IO1) (type passive))
|
||||||
|
(pin (num 2) (name GND) (type passive))
|
||||||
|
(pin (num 3) (name IO2) (type passive))
|
||||||
|
(pin (num 4) (name IO2) (type passive))
|
||||||
|
(pin (num 5) (name VBUS) (type passive))
|
||||||
|
(pin (num 6) (name IO1) (type passive))))
|
||||||
|
(libpart (lib Transistor_BJT) (part DTA114Y)
|
||||||
|
(description "Digital PNP Transistor, 10k/47k, SOT-23")
|
||||||
|
(footprints
|
||||||
|
(fp SOT?23*)
|
||||||
|
(fp SC?59*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) Q)
|
||||||
|
(field (name Value) DTA114Y))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name B) (type input))
|
||||||
|
(pin (num 2) (name E) (type passive))
|
||||||
|
(pin (num 3) (name C) (type passive))))
|
||||||
|
(libpart (lib stm32-rescue) (part C)
|
||||||
|
(footprints
|
||||||
|
(fp C_*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) C)
|
||||||
|
(field (name Value) C))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name ~) (type passive))
|
||||||
|
(pin (num 2) (name ~) (type passive))))
|
||||||
|
(libpart (lib stm32-rescue) (part CP)
|
||||||
|
(footprints
|
||||||
|
(fp CP_*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) C)
|
||||||
|
(field (name Value) CP))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name ~) (type passive))
|
||||||
|
(pin (num 2) (name ~) (type passive))))
|
||||||
|
(libpart (lib stm32-rescue) (part LED-RESCUE-stm32)
|
||||||
|
(footprints
|
||||||
|
(fp LED*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) D)
|
||||||
|
(field (name Value) LED-RESCUE-stm32))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name K) (type passive))
|
||||||
|
(pin (num 2) (name A) (type passive))))
|
||||||
|
(libpart (lib stm32-rescue) (part LM1117-3.3-RESCUE-stm32)
|
||||||
|
(footprints
|
||||||
|
(fp SOT-223*)
|
||||||
|
(fp TO-263*)
|
||||||
|
(fp TO-252*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) U)
|
||||||
|
(field (name Value) LM1117-3.3-RESCUE-stm32))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name GND/ADJ) (type power_in))
|
||||||
|
(pin (num 2) (name VO) (type passive))
|
||||||
|
(pin (num 3) (name VI) (type power_in))
|
||||||
|
(pin (num 4) (name VO) (type power_out))))
|
||||||
|
(libpart (lib stm32-rescue) (part R)
|
||||||
|
(footprints
|
||||||
|
(fp R_*)
|
||||||
|
(fp R_*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) R)
|
||||||
|
(field (name Value) R))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name ~) (type passive))
|
||||||
|
(pin (num 2) (name ~) (type passive))))
|
||||||
|
(libpart (lib stm32-rescue) (part STM32F042C6Tx)
|
||||||
|
(fields
|
||||||
|
(field (name Reference) U)
|
||||||
|
(field (name Value) STM32F042C6Tx)
|
||||||
|
(field (name Footprint) LQFP48))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name VBAT) (type power_in))
|
||||||
|
(pin (num 2) (name PC13/RTC_OUT_ALARM/RTC_OUT_CALIB/RTC_TAMP1/RTC_TS/SYS_WKUP2) (type BiDi))
|
||||||
|
(pin (num 3) (name PC14/RCC_OSC32_IN) (type BiDi))
|
||||||
|
(pin (num 4) (name PC15/RCC_OSC32_OUT) (type BiDi))
|
||||||
|
(pin (num 5) (name PF0/CRS_SYNC/I2C1_SDA/RCC_OSC_IN) (type input))
|
||||||
|
(pin (num 6) (name PF1/I2C1_SCL/RCC_OSC_OUT) (type input))
|
||||||
|
(pin (num 7) (name NRST) (type input))
|
||||||
|
(pin (num 8) (name VSSA) (type power_in))
|
||||||
|
(pin (num 9) (name VDDA) (type power_in))
|
||||||
|
(pin (num 10) (name ADC_IN0/RTC_TAMP2/SYS_WKUP1/TIM2_CH1/TIM2_ETR/TSC_G1_IO1/USART2_CTS/PA0) (type BiDi))
|
||||||
|
(pin (num 11) (name ADC_IN1/TIM2_CH2/TSC_G1_IO2/USART2_DE/USART2_RTS/PA1) (type BiDi))
|
||||||
|
(pin (num 12) (name ADC_IN2/SYS_WKUP4/TIM2_CH3/TSC_G1_IO3/USART2_TX/PA2) (type BiDi))
|
||||||
|
(pin (num 13) (name ADC_IN3/TIM2_CH4/TSC_G1_IO4/USART2_RX/PA3) (type BiDi))
|
||||||
|
(pin (num 14) (name ADC_IN4/I2S1_WS/SPI1_NSS/TIM14_CH1/TSC_G2_IO1/USART2_CK/USB_OE/PA4) (type BiDi))
|
||||||
|
(pin (num 15) (name ADC_IN5/CEC/I2S1_CK/SPI1_SCK/TIM2_CH1/TIM2_ETR/TSC_G2_IO2/PA5) (type BiDi))
|
||||||
|
(pin (num 16) (name ADC_IN6/I2S1_MCK/SPI1_MISO/TIM16_CH1/TIM1_BKIN/TIM3_CH1/TSC_G2_IO3/PA6) (type BiDi))
|
||||||
|
(pin (num 17) (name ADC_IN7/I2S1_SD/SPI1_MOSI/TIM14_CH1/TIM17_CH1/TIM1_CH1N/TIM3_CH2/TSC_G2_IO4/PA7) (type BiDi))
|
||||||
|
(pin (num 18) (name PB0/ADC_IN8/TIM1_CH2N/TIM3_CH3/TSC_G3_IO2) (type BiDi))
|
||||||
|
(pin (num 19) (name PB1/ADC_IN9/TIM14_CH1/TIM1_CH3N/TIM3_CH4/TSC_G3_IO3) (type BiDi))
|
||||||
|
(pin (num 20) (name PB2/TSC_G3_IO4) (type BiDi))
|
||||||
|
(pin (num 21) (name PB10/CEC/I2C1_SCL/SPI2_SCK/TIM2_CH3/TSC_SYNC) (type BiDi))
|
||||||
|
(pin (num 22) (name PB11/I2C1_SDA/TIM2_CH4) (type BiDi))
|
||||||
|
(pin (num 23) (name VSS) (type power_in))
|
||||||
|
(pin (num 24) (name VDD) (type power_in))
|
||||||
|
(pin (num 25) (name PB12/SPI2_NSS/TIM1_BKIN) (type BiDi))
|
||||||
|
(pin (num 26) (name PB13/I2C1_SCL/SPI2_SCK/TIM1_CH1N) (type BiDi))
|
||||||
|
(pin (num 27) (name PB14/I2C1_SDA/SPI2_MISO/TIM1_CH2N) (type BiDi))
|
||||||
|
(pin (num 28) (name PB15/RTC_REFIN/SPI2_MOSI/SYS_WKUP7/TIM1_CH3N) (type BiDi))
|
||||||
|
(pin (num 29) (name CRS_SYNC/RCC_MCO/TIM1_CH1/USART1_CK/PA8) (type BiDi))
|
||||||
|
(pin (num 30) (name I2C1_SCL/TIM1_CH2/TSC_G4_IO1/USART1_TX/PA9) (type BiDi))
|
||||||
|
(pin (num 31) (name I2C1_SDA/TIM17_BKIN/TIM1_CH3/TSC_G4_IO2/USART1_RX/PA10) (type BiDi))
|
||||||
|
(pin (num 32) (name CAN_RX/I2C1_SCL/TIM1_CH4/TSC_G4_IO3/USART1_CTS/USB_DM/PA11) (type BiDi))
|
||||||
|
(pin (num 33) (name CAN_TX/I2C1_SDA/TIM1_ETR/TSC_G4_IO4/USART1_DE/USART1_RTS/USB_DP/PA12) (type BiDi))
|
||||||
|
(pin (num 34) (name IR_OUT/SYS_SWDIO/USB_OE/PA13) (type BiDi))
|
||||||
|
(pin (num 35) (name VSS) (type power_in))
|
||||||
|
(pin (num 36) (name VDDIO2) (type power_in))
|
||||||
|
(pin (num 37) (name SYS_SWCLK/USART2_TX/PA14) (type BiDi))
|
||||||
|
(pin (num 38) (name I2S1_WS/SPI1_NSS/TIM2_CH1/TIM2_ETR/USART2_RX/USB_OE/PA15) (type BiDi))
|
||||||
|
(pin (num 39) (name PB3/I2S1_CK/SPI1_SCK/TIM2_CH2/TSC_G5_IO1) (type BiDi))
|
||||||
|
(pin (num 40) (name PB4/I2S1_MCK/SPI1_MISO/TIM17_BKIN/TIM3_CH1/TSC_G5_IO2) (type BiDi))
|
||||||
|
(pin (num 41) (name PB5/I2C1_SMBA/I2S1_SD/SPI1_MOSI/SYS_WKUP6/TIM16_BKIN/TIM3_CH2) (type BiDi))
|
||||||
|
(pin (num 42) (name PB6/I2C1_SCL/TIM16_CH1N/TSC_G5_IO3/USART1_TX) (type BiDi))
|
||||||
|
(pin (num 43) (name PB7/I2C1_SDA/TIM17_CH1N/TSC_G5_IO4/USART1_RX) (type BiDi))
|
||||||
|
(pin (num 44) (name PF11) (type BiDi))
|
||||||
|
(pin (num 45) (name PB8/CAN_RX/CEC/I2C1_SCL/TIM16_CH1/TSC_SYNC) (type BiDi))
|
||||||
|
(pin (num 46) (name PB9/CAN_TX/I2C1_SDA/IR_OUT/SPI2_NSS/TIM17_CH1) (type BiDi))
|
||||||
|
(pin (num 47) (name VSS) (type power_in))
|
||||||
|
(pin (num 48) (name VDD) (type power_in))))
|
||||||
|
(libpart (lib stm32-rescue) (part SW_Push)
|
||||||
|
(fields
|
||||||
|
(field (name Reference) SW)
|
||||||
|
(field (name Value) SW_Push))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name 1) (type passive))
|
||||||
|
(pin (num 2) (name 2) (type passive))))
|
||||||
|
(libpart (lib stm32-rescue) (part USB_A-RESCUE-stm32)
|
||||||
|
(footprints
|
||||||
|
(fp USB*))
|
||||||
|
(fields
|
||||||
|
(field (name Reference) P)
|
||||||
|
(field (name Value) USB_A-RESCUE-stm32))
|
||||||
|
(pins
|
||||||
|
(pin (num 1) (name VBUS) (type power_in))
|
||||||
|
(pin (num 2) (name D-) (type passive))
|
||||||
|
(pin (num 3) (name D+) (type passive))
|
||||||
|
(pin (num 4) (name GND) (type power_in))
|
||||||
|
(pin (num 5) (name shield) (type passive)))))
|
||||||
|
(libraries
|
||||||
|
(library (logical Connector)
|
||||||
|
(uri /usr/share/kicad/library/Connector.lib))
|
||||||
|
(library (logical Device)
|
||||||
|
(uri /usr/share/kicad/library/Device.lib))
|
||||||
|
(library (logical Power_Protection)
|
||||||
|
(uri /usr/share/kicad/library/Power_Protection.lib))
|
||||||
|
(library (logical Transistor_BJT)
|
||||||
|
(uri /usr/share/kicad/library/Transistor_BJT.lib))
|
||||||
|
(library (logical stm32-rescue)
|
||||||
|
(uri /Big/Data/00__Electronics/STM32/F0_F1_F3-LQFP48_testboard/stm32-rescue.lib)))
|
||||||
|
(nets
|
||||||
|
(net (code 1) (name "Net-(J3-Pad1)")
|
||||||
|
(node (ref U2) (pin 46))
|
||||||
|
(node (ref J3) (pin 1)))
|
||||||
|
(net (code 2) (name "Net-(J12-Pad1)")
|
||||||
|
(node (ref U2) (pin 14))
|
||||||
|
(node (ref J12) (pin 1))
|
||||||
|
(node (ref U2) (pin 15)))
|
||||||
|
(net (code 3) (name "Net-(J3-Pad2)")
|
||||||
|
(node (ref U2) (pin 45))
|
||||||
|
(node (ref J3) (pin 2)))
|
||||||
|
(net (code 4) (name "Net-(U2-Pad4)")
|
||||||
|
(node (ref U2) (pin 4)))
|
||||||
|
(net (code 5) (name /USB_PU)
|
||||||
|
(node (ref Q1) (pin 1))
|
||||||
|
(node (ref U2) (pin 38)))
|
||||||
|
(net (code 6) (name +3V3)
|
||||||
|
(node (ref J6) (pin 3))
|
||||||
|
(node (ref U2) (pin 24))
|
||||||
|
(node (ref R1) (pin 1))
|
||||||
|
(node (ref R2) (pin 1))
|
||||||
|
(node (ref J6) (pin 1))
|
||||||
|
(node (ref J6) (pin 4))
|
||||||
|
(node (ref J6) (pin 2))
|
||||||
|
(node (ref D3) (pin 2))
|
||||||
|
(node (ref RV1) (pin 1))
|
||||||
|
(node (ref U2) (pin 1))
|
||||||
|
(node (ref D2) (pin 2))
|
||||||
|
(node (ref J7) (pin 1))
|
||||||
|
(node (ref J1) (pin 1))
|
||||||
|
(node (ref C9) (pin 2))
|
||||||
|
(node (ref C8) (pin 2))
|
||||||
|
(node (ref C7) (pin 2))
|
||||||
|
(node (ref C10) (pin 2))
|
||||||
|
(node (ref C2) (pin 2))
|
||||||
|
(node (ref SW2) (pin 2))
|
||||||
|
(node (ref D6) (pin 2))
|
||||||
|
(node (ref U1) (pin 2))
|
||||||
|
(node (ref U1) (pin 4))
|
||||||
|
(node (ref C4) (pin 1))
|
||||||
|
(node (ref D1) (pin 2))
|
||||||
|
(node (ref U2) (pin 48))
|
||||||
|
(node (ref C3) (pin 1))
|
||||||
|
(node (ref U2) (pin 36))
|
||||||
|
(node (ref Q1) (pin 2))
|
||||||
|
(node (ref U2) (pin 9))
|
||||||
|
(node (ref D4) (pin 2))
|
||||||
|
(node (ref D5) (pin 2)))
|
||||||
|
(net (code 7) (name "Net-(J4-Pad1)")
|
||||||
|
(node (ref U2) (pin 25))
|
||||||
|
(node (ref J4) (pin 1)))
|
||||||
|
(net (code 8) (name "Net-(J2-Pad1)")
|
||||||
|
(node (ref J2) (pin 1))
|
||||||
|
(node (ref R5) (pin 1))
|
||||||
|
(node (ref U2) (pin 20)))
|
||||||
|
(net (code 9) (name "Net-(D5-Pad1)")
|
||||||
|
(node (ref D5) (pin 1))
|
||||||
|
(node (ref R10) (pin 1)))
|
||||||
|
(net (code 10) (name "Net-(D4-Pad1)")
|
||||||
|
(node (ref R9) (pin 1))
|
||||||
|
(node (ref D4) (pin 1)))
|
||||||
|
(net (code 11) (name GND)
|
||||||
|
(node (ref U2) (pin 8))
|
||||||
|
(node (ref C4) (pin 2))
|
||||||
|
(node (ref U1) (pin 1))
|
||||||
|
(node (ref U3) (pin 2))
|
||||||
|
(node (ref J8) (pin 4))
|
||||||
|
(node (ref P3) (pin 5))
|
||||||
|
(node (ref P1) (pin 1))
|
||||||
|
(node (ref P3) (pin 4))
|
||||||
|
(node (ref U2) (pin 47))
|
||||||
|
(node (ref C3) (pin 2))
|
||||||
|
(node (ref C1) (pin 2))
|
||||||
|
(node (ref SW1) (pin 2))
|
||||||
|
(node (ref R6) (pin 1))
|
||||||
|
(node (ref R3) (pin 2))
|
||||||
|
(node (ref C7) (pin 1))
|
||||||
|
(node (ref C8) (pin 1))
|
||||||
|
(node (ref C9) (pin 1))
|
||||||
|
(node (ref U2) (pin 35))
|
||||||
|
(node (ref C10) (pin 1))
|
||||||
|
(node (ref J1) (pin 4))
|
||||||
|
(node (ref P2) (pin 1))
|
||||||
|
(node (ref C5) (pin 2))
|
||||||
|
(node (ref C6) (pin 2))
|
||||||
|
(node (ref J7) (pin 4))
|
||||||
|
(node (ref R14) (pin 2))
|
||||||
|
(node (ref R5) (pin 2))
|
||||||
|
(node (ref J9) (pin 4))
|
||||||
|
(node (ref J5) (pin 4))
|
||||||
|
(node (ref RV1) (pin 3))
|
||||||
|
(node (ref J5) (pin 3))
|
||||||
|
(node (ref U2) (pin 23))
|
||||||
|
(node (ref J5) (pin 2))
|
||||||
|
(node (ref J5) (pin 1)))
|
||||||
|
(net (code 12) (name /ADC0)
|
||||||
|
(node (ref R15) (pin 1))
|
||||||
|
(node (ref RV1) (pin 2))
|
||||||
|
(node (ref U2) (pin 10)))
|
||||||
|
(net (code 13) (name /U1Rx)
|
||||||
|
(node (ref P1) (pin 3))
|
||||||
|
(node (ref U2) (pin 31)))
|
||||||
|
(net (code 14) (name /U1Tx)
|
||||||
|
(node (ref P1) (pin 2))
|
||||||
|
(node (ref U2) (pin 30)))
|
||||||
|
(net (code 15) (name "Net-(U2-Pad3)")
|
||||||
|
(node (ref U2) (pin 3)))
|
||||||
|
(net (code 16) (name /PWMT1ch1)
|
||||||
|
(node (ref J10) (pin 1))
|
||||||
|
(node (ref R11) (pin 2))
|
||||||
|
(node (ref U2) (pin 29)))
|
||||||
|
(net (code 17) (name /SPI2_MISO)
|
||||||
|
(node (ref U2) (pin 27))
|
||||||
|
(node (ref J8) (pin 2)))
|
||||||
|
(net (code 18) (name /SPI2_SCK)
|
||||||
|
(node (ref U2) (pin 26))
|
||||||
|
(node (ref J8) (pin 1)))
|
||||||
|
(net (code 19) (name "Net-(U2-Pad2)")
|
||||||
|
(node (ref U2) (pin 2)))
|
||||||
|
(net (code 20) (name /PWM4)
|
||||||
|
(node (ref R10) (pin 2))
|
||||||
|
(node (ref J11) (pin 4))
|
||||||
|
(node (ref U2) (pin 19)))
|
||||||
|
(net (code 21) (name /PWM3)
|
||||||
|
(node (ref J11) (pin 3))
|
||||||
|
(node (ref U2) (pin 18))
|
||||||
|
(node (ref R9) (pin 2)))
|
||||||
|
(net (code 22) (name /PWM2)
|
||||||
|
(node (ref J11) (pin 2))
|
||||||
|
(node (ref R8) (pin 2))
|
||||||
|
(node (ref U2) (pin 17)))
|
||||||
|
(net (code 23) (name /PWM1)
|
||||||
|
(node (ref R7) (pin 2))
|
||||||
|
(node (ref U2) (pin 16))
|
||||||
|
(node (ref J11) (pin 1)))
|
||||||
|
(net (code 24) (name /U2Rx)
|
||||||
|
(node (ref P2) (pin 3))
|
||||||
|
(node (ref U2) (pin 13))
|
||||||
|
(node (ref U2) (pin 21)))
|
||||||
|
(net (code 25) (name /U2Tx)
|
||||||
|
(node (ref P2) (pin 2))
|
||||||
|
(node (ref U2) (pin 12))
|
||||||
|
(node (ref U2) (pin 22)))
|
||||||
|
(net (code 26) (name /ADC1)
|
||||||
|
(node (ref R15) (pin 2))
|
||||||
|
(node (ref R14) (pin 1))
|
||||||
|
(node (ref U2) (pin 11)))
|
||||||
|
(net (code 27) (name /SPI1_MOSI)
|
||||||
|
(node (ref J9) (pin 3))
|
||||||
|
(node (ref U2) (pin 41)))
|
||||||
|
(net (code 28) (name /SPI1_MISO)
|
||||||
|
(node (ref U2) (pin 40))
|
||||||
|
(node (ref J9) (pin 2)))
|
||||||
|
(net (code 29) (name /SPI1_SCK)
|
||||||
|
(node (ref U2) (pin 39))
|
||||||
|
(node (ref J9) (pin 1)))
|
||||||
|
(net (code 30) (name /SWCLK)
|
||||||
|
(node (ref U2) (pin 37))
|
||||||
|
(node (ref J7) (pin 3)))
|
||||||
|
(net (code 31) (name /SWDIO)
|
||||||
|
(node (ref U2) (pin 34))
|
||||||
|
(node (ref J7) (pin 2)))
|
||||||
|
(net (code 32) (name /I2C_SDA)
|
||||||
|
(node (ref U2) (pin 43))
|
||||||
|
(node (ref R2) (pin 2))
|
||||||
|
(node (ref J1) (pin 3)))
|
||||||
|
(net (code 33) (name /I2C_SCL)
|
||||||
|
(node (ref R1) (pin 2))
|
||||||
|
(node (ref J1) (pin 2))
|
||||||
|
(node (ref U2) (pin 42)))
|
||||||
|
(net (code 34) (name /SPI2_MOSI)
|
||||||
|
(node (ref U2) (pin 28))
|
||||||
|
(node (ref J8) (pin 3)))
|
||||||
|
(net (code 35) (name "Net-(D6-Pad1)")
|
||||||
|
(node (ref R11) (pin 1))
|
||||||
|
(node (ref D6) (pin 1)))
|
||||||
|
(net (code 36) (name +5V)
|
||||||
|
(node (ref P3) (pin 1))
|
||||||
|
(node (ref U3) (pin 5))
|
||||||
|
(node (ref U1) (pin 3)))
|
||||||
|
(net (code 37) (name "Net-(P3-Pad3)")
|
||||||
|
(node (ref P3) (pin 3))
|
||||||
|
(node (ref R16) (pin 2))
|
||||||
|
(node (ref U3) (pin 4)))
|
||||||
|
(net (code 38) (name "Net-(P3-Pad2)")
|
||||||
|
(node (ref U3) (pin 6))
|
||||||
|
(node (ref P3) (pin 2)))
|
||||||
|
(net (code 39) (name /NRST)
|
||||||
|
(node (ref SW1) (pin 1))
|
||||||
|
(node (ref C1) (pin 1))
|
||||||
|
(node (ref U2) (pin 7)))
|
||||||
|
(net (code 40) (name /BOOT0)
|
||||||
|
(node (ref U2) (pin 44))
|
||||||
|
(node (ref R3) (pin 1))
|
||||||
|
(node (ref C2) (pin 1))
|
||||||
|
(node (ref SW2) (pin 1)))
|
||||||
|
(net (code 41) (name "Net-(D1-Pad1)")
|
||||||
|
(node (ref R6) (pin 2))
|
||||||
|
(node (ref D1) (pin 1)))
|
||||||
|
(net (code 42) (name /OSC_OUT)
|
||||||
|
(node (ref U2) (pin 6))
|
||||||
|
(node (ref C6) (pin 1))
|
||||||
|
(node (ref Y1) (pin 2)))
|
||||||
|
(net (code 43) (name /OSC_IN)
|
||||||
|
(node (ref C5) (pin 1))
|
||||||
|
(node (ref Y1) (pin 1))
|
||||||
|
(node (ref U2) (pin 5)))
|
||||||
|
(net (code 44) (name "Net-(D2-Pad1)")
|
||||||
|
(node (ref R7) (pin 1))
|
||||||
|
(node (ref D2) (pin 1)))
|
||||||
|
(net (code 45) (name "Net-(D3-Pad1)")
|
||||||
|
(node (ref R8) (pin 1))
|
||||||
|
(node (ref D3) (pin 1)))
|
||||||
|
(net (code 46) (name "Net-(Q1-Pad3)")
|
||||||
|
(node (ref Q1) (pin 3))
|
||||||
|
(node (ref R16) (pin 1)))
|
||||||
|
(net (code 47) (name "Net-(R13-Pad1)")
|
||||||
|
(node (ref U3) (pin 3))
|
||||||
|
(node (ref R13) (pin 1)))
|
||||||
|
(net (code 48) (name "Net-(R13-Pad2)")
|
||||||
|
(node (ref U2) (pin 33))
|
||||||
|
(node (ref R13) (pin 2)))
|
||||||
|
(net (code 49) (name "Net-(R12-Pad1)")
|
||||||
|
(node (ref U3) (pin 1))
|
||||||
|
(node (ref R12) (pin 1)))
|
||||||
|
(net (code 50) (name "Net-(R12-Pad2)")
|
||||||
|
(node (ref R12) (pin 2))
|
||||||
|
(node (ref U2) (pin 32)))))
|
||||||
253
F0_F1_F3-LQFP48_testboard/stm32.pro
Normal file
253
F0_F1_F3-LQFP48_testboard/stm32.pro
Normal file
@ -0,0 +1,253 @@
|
|||||||
|
update=Ср 23 июн 2021 21:03:53
|
||||||
|
version=1
|
||||||
|
last_client=kicad
|
||||||
|
[cvpcb]
|
||||||
|
version=1
|
||||||
|
NetIExt=net
|
||||||
|
[general]
|
||||||
|
version=1
|
||||||
|
[eeschema]
|
||||||
|
version=1
|
||||||
|
LibDir=
|
||||||
|
[schematic_editor]
|
||||||
|
version=1
|
||||||
|
PageLayoutDescrFile=
|
||||||
|
PlotDirectoryName=
|
||||||
|
SubpartIdSeparator=0
|
||||||
|
SubpartFirstId=65
|
||||||
|
NetFmtName=Pcbnew
|
||||||
|
SpiceAjustPassiveValues=0
|
||||||
|
LabSize=50
|
||||||
|
ERC_TestSimilarLabels=1
|
||||||
|
[pcbnew]
|
||||||
|
version=1
|
||||||
|
PageLayoutDescrFile=
|
||||||
|
LastNetListRead=stm32.net
|
||||||
|
CopperLayerCount=2
|
||||||
|
BoardThickness=1.6
|
||||||
|
AllowMicroVias=0
|
||||||
|
AllowBlindVias=0
|
||||||
|
RequireCourtyardDefinitions=0
|
||||||
|
ProhibitOverlappingCourtyards=1
|
||||||
|
MinTrackWidth=0.2
|
||||||
|
MinViaDiameter=1
|
||||||
|
MinViaDrill=0.6
|
||||||
|
MinMicroViaDiameter=0.2
|
||||||
|
MinMicroViaDrill=0.09999999999999999
|
||||||
|
MinHoleToHole=1
|
||||||
|
TrackWidth1=0.25
|
||||||
|
TrackWidth2=0.25
|
||||||
|
TrackWidth3=0.5
|
||||||
|
TrackWidth4=1
|
||||||
|
TrackWidth5=2
|
||||||
|
ViaDiameter1=2
|
||||||
|
ViaDrill1=0.6
|
||||||
|
ViaDiameter2=1.5
|
||||||
|
ViaDrill2=0.6
|
||||||
|
ViaDiameter3=2
|
||||||
|
ViaDrill3=0.8
|
||||||
|
dPairWidth1=0.2
|
||||||
|
dPairGap1=0.25
|
||||||
|
dPairViaGap1=0.25
|
||||||
|
SilkLineWidth=0.15
|
||||||
|
SilkTextSizeV=1
|
||||||
|
SilkTextSizeH=1
|
||||||
|
SilkTextSizeThickness=0.15
|
||||||
|
SilkTextItalic=0
|
||||||
|
SilkTextUpright=1
|
||||||
|
CopperLineWidth=0.2
|
||||||
|
CopperTextSizeV=1.5
|
||||||
|
CopperTextSizeH=1.5
|
||||||
|
CopperTextThickness=0.3
|
||||||
|
CopperTextItalic=0
|
||||||
|
CopperTextUpright=1
|
||||||
|
EdgeCutLineWidth=0.09999999999999999
|
||||||
|
CourtyardLineWidth=0.05
|
||||||
|
OthersLineWidth=0.15
|
||||||
|
OthersTextSizeV=1
|
||||||
|
OthersTextSizeH=1
|
||||||
|
OthersTextSizeThickness=0.15
|
||||||
|
OthersTextItalic=0
|
||||||
|
OthersTextUpright=1
|
||||||
|
SolderMaskClearance=0
|
||||||
|
SolderMaskMinWidth=0
|
||||||
|
SolderPasteClearance=0
|
||||||
|
SolderPasteRatio=-0
|
||||||
|
[pcbnew/Layer.F.Cu]
|
||||||
|
Name=F.Cu
|
||||||
|
Type=3
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.In1.Cu]
|
||||||
|
Name=In1.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In2.Cu]
|
||||||
|
Name=In2.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In3.Cu]
|
||||||
|
Name=In3.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In4.Cu]
|
||||||
|
Name=In4.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In5.Cu]
|
||||||
|
Name=In5.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In6.Cu]
|
||||||
|
Name=In6.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In7.Cu]
|
||||||
|
Name=In7.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In8.Cu]
|
||||||
|
Name=In8.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In9.Cu]
|
||||||
|
Name=In9.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In10.Cu]
|
||||||
|
Name=In10.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In11.Cu]
|
||||||
|
Name=In11.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In12.Cu]
|
||||||
|
Name=In12.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In13.Cu]
|
||||||
|
Name=In13.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In14.Cu]
|
||||||
|
Name=In14.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In15.Cu]
|
||||||
|
Name=In15.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In16.Cu]
|
||||||
|
Name=In16.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In17.Cu]
|
||||||
|
Name=In17.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In18.Cu]
|
||||||
|
Name=In18.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In19.Cu]
|
||||||
|
Name=In19.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In20.Cu]
|
||||||
|
Name=In20.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In21.Cu]
|
||||||
|
Name=In21.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In22.Cu]
|
||||||
|
Name=In22.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In23.Cu]
|
||||||
|
Name=In23.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In24.Cu]
|
||||||
|
Name=In24.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In25.Cu]
|
||||||
|
Name=In25.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In26.Cu]
|
||||||
|
Name=In26.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In27.Cu]
|
||||||
|
Name=In27.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In28.Cu]
|
||||||
|
Name=In28.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In29.Cu]
|
||||||
|
Name=In29.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.In30.Cu]
|
||||||
|
Name=In30.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.B.Cu]
|
||||||
|
Name=B.Cu
|
||||||
|
Type=0
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.Adhes]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.F.Adhes]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.B.Paste]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.F.Paste]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.B.SilkS]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.F.SilkS]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.Mask]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.F.Mask]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.Dwgs.User]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.Cmts.User]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.Eco1.User]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.Eco2.User]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.Edge.Cuts]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.Margin]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.CrtYd]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.F.CrtYd]
|
||||||
|
Enabled=1
|
||||||
|
[pcbnew/Layer.B.Fab]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.F.Fab]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Layer.Rescue]
|
||||||
|
Enabled=0
|
||||||
|
[pcbnew/Netclasses]
|
||||||
|
[pcbnew/Netclasses/Default]
|
||||||
|
Name=Default
|
||||||
|
Clearance=0.2
|
||||||
|
TrackWidth=0.25
|
||||||
|
ViaDiameter=2
|
||||||
|
ViaDrill=0.6
|
||||||
|
uViaDiameter=0.3
|
||||||
|
uViaDrill=0.1
|
||||||
|
dPairWidth=0.2
|
||||||
|
dPairGap=0.25
|
||||||
|
dPairViaGap=0.25
|
||||||
1406
F0_F1_F3-LQFP48_testboard/stm32.sch
Normal file
1406
F0_F1_F3-LQFP48_testboard/stm32.sch
Normal file
File diff suppressed because it is too large
Load Diff
8
F0_F1_F3-LQFP48_testboard/sym-lib-table
Normal file
8
F0_F1_F3-LQFP48_testboard/sym-lib-table
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
(sym_lib_table
|
||||||
|
(lib (name stm32-rescue)(type Legacy)(uri ${KIPRJMOD}/stm32-rescue.lib)(options "")(descr ""))
|
||||||
|
(lib (name stm32)(type Legacy)(uri /home/eddy/kicad/Kicad-Libraries/library/stm32.lib)(options "")(descr ""))
|
||||||
|
(lib (name vreg)(type Legacy)(uri /home/eddy/kicad/Kicad-Libraries/library/vreg.lib)(options "")(descr ""))
|
||||||
|
(lib (name elements)(type Legacy)(uri ${KIPRJMOD}/elements.lib)(options "")(descr ""))
|
||||||
|
(lib (name switches)(type Legacy)(uri /home/eddy/kicad/Kicad-Libraries/library/switches.lib)(options "")(descr "")(disabled))
|
||||||
|
(lib (name acs712)(type Legacy)(uri ${KIPRJMOD}/acs712.lib)(options "")(descr "")(disabled))
|
||||||
|
)
|
||||||
194
F4-nolib/startup_gcc_stm32f411xe.c
Normal file
194
F4-nolib/startup_gcc_stm32f411xe.c
Normal file
@ -0,0 +1,194 @@
|
|||||||
|
#include "stm32f411xe.h"
|
||||||
|
#include <stddef.h>
|
||||||
|
|
||||||
|
void SystemInit();
|
||||||
|
void __libc_init_array();
|
||||||
|
int main();
|
||||||
|
|
||||||
|
// These magic symbols are provided by the linker.
|
||||||
|
extern void *_estack;
|
||||||
|
extern void *_sidata, *_sdata, *_edata;
|
||||||
|
extern void *_sbss, *_ebss;
|
||||||
|
extern void (*__preinit_array_start[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__preinit_array_end[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__init_array_start[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__init_array_end[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__fini_array_start[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__fini_array_end[]) (void) __attribute__((weak));
|
||||||
|
|
||||||
|
void __attribute__((naked, noreturn)) Reset_Handler()
|
||||||
|
{
|
||||||
|
#ifdef __DEBUG_SRAM__
|
||||||
|
__set_MSP((uint32_t)&_estack);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
SystemInit();
|
||||||
|
|
||||||
|
for (void **pSrc = &_sidata, **pDst = &_sdata; pDst < &_edata; *pDst++ = *pSrc++);
|
||||||
|
for (void **pDst = &_sbss; pDst < &_ebss; *pDst++ = 0); // Zero -> BSS
|
||||||
|
|
||||||
|
// Use with the "-nostartfiles" linker option instead __libc_init_array();
|
||||||
|
// Iterate over all the preinit/init routines (mainly static constructors).
|
||||||
|
for(void(**fConstr)() = __preinit_array_start; fConstr < __preinit_array_end; (*fConstr++)());
|
||||||
|
for(void(**fConstr)() = __init_array_start; fConstr < __init_array_end; (*fConstr++)());
|
||||||
|
|
||||||
|
//__libc_init_array(); // Use with libc start files
|
||||||
|
|
||||||
|
(void)main();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Default_Handler() { for(;;); }
|
||||||
|
|
||||||
|
void NMI_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void HardFault_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void MemManage_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void BusFault_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void UsageFault_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SVC_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DebugMon_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void PendSV_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SysTick_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void WWDG_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void PVD_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TAMP_STAMP_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void RTC_WKUP_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void FLASH_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void RCC_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI0_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Stream0_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Stream1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Stream2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Stream3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Stream4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Stream5_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Stream6_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void ADC_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI9_5_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM1_BRK_TIM9_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM1_UP_TIM10_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM1_TRG_COM_TIM11_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM1_CC_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C1_EV_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C1_ER_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C2_EV_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C2_ER_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SPI1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SPI2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USART1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USART2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI15_10_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void RTC_Alarm_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void OTG_FS_WKUP_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Stream7_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SDIO_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM5_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SPI3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Stream0_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Stream1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Stream2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Stream3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Stream4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void OTG_FS_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Stream5_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Stream6_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Stream7_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USART6_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C3_EV_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C3_ER_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void FPU_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SPI4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SPI5_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
|
||||||
|
|
||||||
|
typedef void(*intvec_elem)();
|
||||||
|
|
||||||
|
__EXTERN_C const intvec_elem __vector_table[] __VECTOR_TABLE_ATTRIBUTE =
|
||||||
|
{ (intvec_elem)&_estack, &Reset_Handler,
|
||||||
|
&NMI_Handler,
|
||||||
|
&HardFault_Handler,
|
||||||
|
&MemManage_Handler,
|
||||||
|
&BusFault_Handler,
|
||||||
|
&UsageFault_Handler,
|
||||||
|
NULL, NULL, NULL, NULL,
|
||||||
|
&SVC_Handler,
|
||||||
|
&DebugMon_Handler,
|
||||||
|
NULL,
|
||||||
|
&PendSV_Handler,
|
||||||
|
&SysTick_Handler,
|
||||||
|
&WWDG_IRQHandler,
|
||||||
|
&PVD_IRQHandler,
|
||||||
|
&TAMP_STAMP_IRQHandler,
|
||||||
|
&RTC_WKUP_IRQHandler,
|
||||||
|
&FLASH_IRQHandler,
|
||||||
|
&RCC_IRQHandler,
|
||||||
|
&EXTI0_IRQHandler,
|
||||||
|
&EXTI1_IRQHandler,
|
||||||
|
&EXTI2_IRQHandler,
|
||||||
|
&EXTI3_IRQHandler,
|
||||||
|
&EXTI4_IRQHandler,
|
||||||
|
&DMA1_Stream0_IRQHandler,
|
||||||
|
&DMA1_Stream1_IRQHandler,
|
||||||
|
&DMA1_Stream2_IRQHandler,
|
||||||
|
&DMA1_Stream3_IRQHandler,
|
||||||
|
&DMA1_Stream4_IRQHandler,
|
||||||
|
&DMA1_Stream5_IRQHandler,
|
||||||
|
&DMA1_Stream6_IRQHandler,
|
||||||
|
&ADC_IRQHandler,
|
||||||
|
NULL, NULL, NULL, NULL,
|
||||||
|
&EXTI9_5_IRQHandler,
|
||||||
|
&TIM1_BRK_TIM9_IRQHandler,
|
||||||
|
&TIM1_UP_TIM10_IRQHandler,
|
||||||
|
&TIM1_TRG_COM_TIM11_IRQHandler,
|
||||||
|
&TIM1_CC_IRQHandler,
|
||||||
|
&TIM2_IRQHandler,
|
||||||
|
&TIM3_IRQHandler,
|
||||||
|
&TIM4_IRQHandler,
|
||||||
|
&I2C1_EV_IRQHandler,
|
||||||
|
&I2C1_ER_IRQHandler,
|
||||||
|
&I2C2_EV_IRQHandler,
|
||||||
|
&I2C2_ER_IRQHandler,
|
||||||
|
&SPI1_IRQHandler,
|
||||||
|
&SPI2_IRQHandler,
|
||||||
|
&USART1_IRQHandler,
|
||||||
|
&USART2_IRQHandler,
|
||||||
|
NULL,
|
||||||
|
&EXTI15_10_IRQHandler,
|
||||||
|
&RTC_Alarm_IRQHandler,
|
||||||
|
&OTG_FS_WKUP_IRQHandler,
|
||||||
|
NULL, NULL, NULL, NULL,
|
||||||
|
&DMA1_Stream7_IRQHandler,
|
||||||
|
NULL,
|
||||||
|
&SDIO_IRQHandler,
|
||||||
|
&TIM5_IRQHandler,
|
||||||
|
&SPI3_IRQHandler,
|
||||||
|
NULL, NULL, NULL, NULL,
|
||||||
|
&DMA2_Stream0_IRQHandler,
|
||||||
|
&DMA2_Stream1_IRQHandler,
|
||||||
|
&DMA2_Stream2_IRQHandler,
|
||||||
|
&DMA2_Stream3_IRQHandler,
|
||||||
|
&DMA2_Stream4_IRQHandler,
|
||||||
|
NULL, NULL, NULL, NULL, NULL, NULL,
|
||||||
|
&OTG_FS_IRQHandler,
|
||||||
|
&DMA2_Stream5_IRQHandler,
|
||||||
|
&DMA2_Stream6_IRQHandler,
|
||||||
|
&DMA2_Stream7_IRQHandler,
|
||||||
|
&USART6_IRQHandler,
|
||||||
|
&I2C3_EV_IRQHandler,
|
||||||
|
&I2C3_ER_IRQHandler,
|
||||||
|
NULL, NULL, NULL, NULL, NULL, NULL, NULL,
|
||||||
|
&FPU_IRQHandler,
|
||||||
|
NULL, NULL,
|
||||||
|
&SPI4_IRQHandler,
|
||||||
|
&SPI5_IRQHandler,
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
267
F4-nolib/startup_iar_gcc_keil_stm32f303xc.c
Normal file
267
F4-nolib/startup_iar_gcc_keil_stm32f303xc.c
Normal file
@ -0,0 +1,267 @@
|
|||||||
|
// STM32F303 Startup file
|
||||||
|
// IAR, GCC, Keil compatible
|
||||||
|
|
||||||
|
#include "stm32f303xc.h"
|
||||||
|
#include <stddef.h>
|
||||||
|
|
||||||
|
#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION>=6100100)
|
||||||
|
#define __KEIL_CODE__
|
||||||
|
#elif defined(__GNUC__)
|
||||||
|
#define __GCC_CODE__
|
||||||
|
#elif defined(__ICCARM__)
|
||||||
|
#define __IAR_CODE__
|
||||||
|
#elif defined( __CC_ARM ) || defined(__MICROLIB)
|
||||||
|
#error "ARMCC v5 and MICROLIB not supported"
|
||||||
|
#else
|
||||||
|
#error "Can't detect compiler"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define __EXTERN_C extern "C"
|
||||||
|
extern "C" {
|
||||||
|
#else
|
||||||
|
#define __EXTERN_C
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __IAR_CODE__
|
||||||
|
//------------------------------
|
||||||
|
// IAR startup code
|
||||||
|
//------------------------------
|
||||||
|
#define __Reset_Handler __cmain
|
||||||
|
#pragma segment="CSTACK"
|
||||||
|
#define __STACK_TOP ((uint32_t)__sfe( "CSTACK" ))
|
||||||
|
void exit(){}
|
||||||
|
void __exit(){}
|
||||||
|
void abort(){}
|
||||||
|
void __cmain();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __KEIL_CODE__
|
||||||
|
//------------------------------
|
||||||
|
// Keil startup code
|
||||||
|
//------------------------------
|
||||||
|
void __main();
|
||||||
|
void SystemInit();
|
||||||
|
void exit() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
#define __Reset_Handler Reset_Handler
|
||||||
|
#define __STACK_TOP (void *)&Image$$ARM_LIB_STACK$$ZI$$Limit
|
||||||
|
extern int Image$$ARM_LIB_STACK$$ZI$$Limit;
|
||||||
|
|
||||||
|
void Reset_Handler()
|
||||||
|
{
|
||||||
|
SystemInit();
|
||||||
|
__main();
|
||||||
|
}
|
||||||
|
#endif // __KEIL_CODE__
|
||||||
|
|
||||||
|
#ifdef __GCC_CODE__
|
||||||
|
//------------------------------
|
||||||
|
// GCC Newlib startup code
|
||||||
|
//------------------------------
|
||||||
|
#define __Reset_Handler Reset_Handler
|
||||||
|
#define __STACK_TOP &_estack
|
||||||
|
void SystemInit();
|
||||||
|
void __libc_init_array();
|
||||||
|
int main();
|
||||||
|
|
||||||
|
// These magic symbols are provided by the linker.
|
||||||
|
extern void *_estack;
|
||||||
|
extern void *_sidata, *_sdata, *_edata;
|
||||||
|
extern void *_sbss, *_ebss;
|
||||||
|
extern void (*__preinit_array_start[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__preinit_array_end[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__init_array_start[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__init_array_end[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__fini_array_start[]) (void) __attribute__((weak));
|
||||||
|
extern void (*__fini_array_end[]) (void) __attribute__((weak));
|
||||||
|
|
||||||
|
void __attribute__((naked, noreturn)) Reset_Handler()
|
||||||
|
{
|
||||||
|
#ifdef __DEBUG_SRAM__
|
||||||
|
__set_MSP((uint32_t)&_estack);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
SystemInit();
|
||||||
|
|
||||||
|
for (void **pSrc = &_sidata, **pDst = &_sdata; pDst < &_edata; *pDst++ = *pSrc++);
|
||||||
|
for (void **pDst = &_sbss; pDst < &_ebss; *pDst++ = 0); // Zero -> BSS
|
||||||
|
|
||||||
|
// Use with the "-nostartfiles" linker option instead __libc_init_array();
|
||||||
|
// Iterate over all the preinit/init routines (mainly static constructors).
|
||||||
|
for(void(**fConstr)() = __preinit_array_start; fConstr < __preinit_array_end; (*fConstr++)());
|
||||||
|
for(void(**fConstr)() = __init_array_start; fConstr < __init_array_end; (*fConstr++)());
|
||||||
|
|
||||||
|
//__libc_init_array(); // Use with libc start files
|
||||||
|
|
||||||
|
(void)main();
|
||||||
|
}
|
||||||
|
#endif // __GCC_CODE__
|
||||||
|
|
||||||
|
void Default_Handler() { for(;;); }
|
||||||
|
|
||||||
|
void NMI_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void HardFault_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void MemManage_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void BusFault_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void UsageFault_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SVC_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DebugMon_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void PendSV_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SysTick_Handler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void WWDG_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void PVD_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TAMP_STAMP_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void RTC_WKUP_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void FLASH_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void RCC_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI0_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI2_TSC_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Channel1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Channel2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Channel3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Channel4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Channel5_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Channel6_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA1_Channel7_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void ADC1_2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USB_HP_CAN_TX_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USB_LP_CAN_RX0_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void CAN_RX1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void CAN_SCE_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI9_5_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM1_BRK_TIM15_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM1_UP_TIM16_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM1_TRG_COM_TIM17_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM1_CC_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C1_EV_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C1_ER_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C2_EV_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void I2C2_ER_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SPI1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SPI2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USART1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USART2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USART3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void EXTI15_10_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void RTC_Alarm_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USBWakeUp_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM8_BRK_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM8_UP_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM8_TRG_COM_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM8_CC_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void ADC3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void SPI3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void UART4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void UART5_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM6_DAC_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void TIM7_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Channel1_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Channel2_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Channel3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Channel4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void DMA2_Channel5_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void ADC4_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void COMP1_2_3_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void COMP4_5_6_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void COMP7_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USB_HP_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USB_LP_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void USBWakeUp_RMP_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
void FPU_IRQHandler() __attribute__ ((weak, alias ("Default_Handler")));
|
||||||
|
|
||||||
|
typedef void(*intvec_elem)();
|
||||||
|
|
||||||
|
__EXTERN_C const intvec_elem __vector_table[] __VECTOR_TABLE_ATTRIBUTE =
|
||||||
|
{ (intvec_elem)__STACK_TOP, &__Reset_Handler,
|
||||||
|
&NMI_Handler,
|
||||||
|
&HardFault_Handler,
|
||||||
|
&MemManage_Handler,
|
||||||
|
&BusFault_Handler,
|
||||||
|
&UsageFault_Handler,
|
||||||
|
NULL, NULL, NULL, NULL,
|
||||||
|
&SVC_Handler,
|
||||||
|
&DebugMon_Handler,
|
||||||
|
NULL,
|
||||||
|
&PendSV_Handler,
|
||||||
|
&SysTick_Handler,
|
||||||
|
&WWDG_IRQHandler,
|
||||||
|
&PVD_IRQHandler,
|
||||||
|
&TAMP_STAMP_IRQHandler,
|
||||||
|
&RTC_WKUP_IRQHandler,
|
||||||
|
&FLASH_IRQHandler,
|
||||||
|
&RCC_IRQHandler,
|
||||||
|
&EXTI0_IRQHandler,
|
||||||
|
&EXTI1_IRQHandler,
|
||||||
|
&EXTI2_TSC_IRQHandler,
|
||||||
|
&EXTI3_IRQHandler,
|
||||||
|
&EXTI4_IRQHandler,
|
||||||
|
&DMA1_Channel1_IRQHandler,
|
||||||
|
&DMA1_Channel2_IRQHandler,
|
||||||
|
&DMA1_Channel3_IRQHandler,
|
||||||
|
&DMA1_Channel4_IRQHandler,
|
||||||
|
&DMA1_Channel5_IRQHandler,
|
||||||
|
&DMA1_Channel6_IRQHandler,
|
||||||
|
&DMA1_Channel7_IRQHandler,
|
||||||
|
&ADC1_2_IRQHandler,
|
||||||
|
&USB_HP_CAN_TX_IRQHandler,
|
||||||
|
&USB_LP_CAN_RX0_IRQHandler,
|
||||||
|
&CAN_RX1_IRQHandler,
|
||||||
|
&CAN_SCE_IRQHandler,
|
||||||
|
&EXTI9_5_IRQHandler,
|
||||||
|
&TIM1_BRK_TIM15_IRQHandler,
|
||||||
|
&TIM1_UP_TIM16_IRQHandler,
|
||||||
|
&TIM1_TRG_COM_TIM17_IRQHandler,
|
||||||
|
&TIM1_CC_IRQHandler,
|
||||||
|
&TIM2_IRQHandler,
|
||||||
|
&TIM3_IRQHandler,
|
||||||
|
&TIM4_IRQHandler,
|
||||||
|
&I2C1_EV_IRQHandler,
|
||||||
|
&I2C1_ER_IRQHandler,
|
||||||
|
&I2C2_EV_IRQHandler,
|
||||||
|
&I2C2_ER_IRQHandler,
|
||||||
|
&SPI1_IRQHandler,
|
||||||
|
&SPI2_IRQHandler,
|
||||||
|
&USART1_IRQHandler,
|
||||||
|
&USART2_IRQHandler,
|
||||||
|
&USART3_IRQHandler,
|
||||||
|
&EXTI15_10_IRQHandler,
|
||||||
|
&RTC_Alarm_IRQHandler,
|
||||||
|
&USBWakeUp_IRQHandler,
|
||||||
|
&TIM8_BRK_IRQHandler,
|
||||||
|
&TIM8_UP_IRQHandler,
|
||||||
|
&TIM8_TRG_COM_IRQHandler,
|
||||||
|
&TIM8_CC_IRQHandler,
|
||||||
|
&ADC3_IRQHandler,
|
||||||
|
NULL, NULL, NULL,
|
||||||
|
&SPI3_IRQHandler,
|
||||||
|
&UART4_IRQHandler,
|
||||||
|
&UART5_IRQHandler,
|
||||||
|
&TIM6_DAC_IRQHandler,
|
||||||
|
&TIM7_IRQHandler,
|
||||||
|
&DMA2_Channel1_IRQHandler,
|
||||||
|
&DMA2_Channel2_IRQHandler,
|
||||||
|
&DMA2_Channel3_IRQHandler,
|
||||||
|
&DMA2_Channel4_IRQHandler,
|
||||||
|
&DMA2_Channel5_IRQHandler,
|
||||||
|
&ADC4_IRQHandler,
|
||||||
|
NULL, NULL,
|
||||||
|
&COMP1_2_3_IRQHandler,
|
||||||
|
&COMP4_5_6_IRQHandler,
|
||||||
|
&COMP7_IRQHandler,
|
||||||
|
NULL, NULL, NULL, NULL, NULL, NULL, NULL,
|
||||||
|
&USB_HP_IRQHandler,
|
||||||
|
&USB_LP_IRQHandler,
|
||||||
|
&USBWakeUp_RMP_IRQHandler,
|
||||||
|
NULL, NULL, NULL, NULL,
|
||||||
|
&FPU_IRQHandler
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
Loading…
x
Reference in New Issue
Block a user