Compare commits

..

88 Commits

Author SHA1 Message Date
King Kévin a8810edd3b make: improve panelization 2024-04-27 10:40:12 +02:00
King Kévin 0038c3bdf3 lib: update repo 2024-04-19 04:20:05 +02:00
King Kévin 209b5852e0 brd: add contraints and predefined sizes 2024-04-19 04:18:14 +02:00
King Kévin 870be28af6 sch/brd: save as KiCAD v8 2024-04-19 04:01:49 +02:00
King Kévin bf94fcb10c make: fix clean 2024-04-19 04:00:26 +02:00
King Kévin 6823a71175 doc: update dev notes to KiCAD v8 2024-04-19 04:00:26 +02:00
King Kévin 9b8c48a33c make: add svg render 2024-04-19 04:00:26 +02:00
King Kévin 2497f9d94b make: use ibom from kicad8 2024-04-19 04:00:26 +02:00
King Kévin 88deb003a6 lib: update repo 2024-03-18 23:44:10 +01:00
King Kévin 529880abb4 make dragon kicad compatible 2024-03-18 23:43:19 +01:00
King Kévin fa16059e46 add old and new year logo 2024-03-08 07:24:21 +01:00
King Kévin 200f8b179d make: remove components from 2d rendering 2024-03-08 07:14:50 +01:00
King Kévin 07570f2911 make: update bom tool 2024-03-08 07:14:21 +01:00
King Kévin 0830600044 make: include DNF parts 2024-03-08 07:14:21 +01:00
King Kévin 3933cbccf8 make: export 3d model 2024-03-08 07:14:21 +01:00
King Kévin 89b65b72de make: add MPN in BoM 2024-03-08 07:13:47 +01:00
King Kévin 9e186892e5 make: ignore DRC 2024-03-08 07:12:31 +01:00
King Kévin ddf9deb7fc lib: update repo 2024-03-08 07:07:09 +01:00
King Kévin 0d73e5171d remove refdes2fab.py and this is a just a gloabal plugin for me 2023-12-18 20:47:12 +01:00
King Kévin 3e78d6beb5 lib: update logo properties 2023-10-01 10:12:16 +02:00
King Kévin c133c944de lib: add silk logo (less DRC errors) 2023-10-01 10:12:16 +02:00
King Kévin 16b19cc0d4 lib: update repo 2023-10-01 10:09:52 +02:00
King Kévin 7310a8173a lib: update repo 2023-09-19 05:12:28 +02:00
King Kévin e97b5bf01f lib: update part database 2023-09-19 05:11:40 +02:00
King Kévin 4aef742dc5 lib: generate Kicad7 library 2023-09-19 05:11:17 +02:00
King Kévin f84deb30b8 lib: remove JLCPCB correction info as it is in the database now 2023-09-19 05:10:41 +02:00
King Kévin 50444cd555 bom: ignore some fields 2023-08-11 11:06:14 +02:00
King Kévin cedd9571ee lib: update repo 2023-08-11 11:05:29 +02:00
King Kévin 7ba4b33939 make: use JLCPCB field in bom fabrication export 2023-08-11 11:04:37 +02:00
King Kévin 6fe5a0e425 make: prevent bom backup 2023-08-11 11:04:37 +02:00
King Kévin 6eb31f0646 ignore kicad lock files 2023-08-11 11:04:37 +02:00
King Kévin b893e7b57d make: ignore DRC for export 2023-08-11 11:04:37 +02:00
King Kévin ffbdffdf48 kicad: update files to v7 2023-03-30 22:32:40 +02:00
King Kévin 59b145d66e doc: better list dependencies 2023-03-30 22:30:26 +02:00
King Kévin c63fbf1689 make: use kikit again to generate fabrication 2023-03-30 22:30:26 +02:00
King Kévin d0d4203d20 make: add bom generator (not included in pip) 2023-03-30 22:30:26 +02:00
King Kévin cacdcb4ceb make: update bom generation 2023-03-30 22:30:26 +02:00
King Kévin 87cb8cb49b make: now use ibom plugin 2023-03-30 22:30:26 +02:00
King Kévin 99ab15f5eb make: switch back from kicad nightly 2023-03-30 22:30:26 +02:00
King Kévin 253f301eb0 lib: update database 2023-03-30 22:30:26 +02:00
King Kévin f1227afdcb make: fabrication does not need schematic 2023-03-30 22:30:26 +02:00
King Kévin 33f9b2cb87 make: add subsheet support 2023-03-30 22:29:07 +02:00
King Kévin 8fa5152b25 make: use kicad-cli to export fabrication (kikit does not support v7 yet) 2023-03-30 22:26:57 +02:00
King Kévin b066d8b473 make: update pcbdraw call 2023-03-30 22:26:57 +02:00
King Kévin d6ed8e8f86 make: use kicad-cli to generate bom 2023-03-30 22:26:57 +02:00
King Kévin ad93fccfcd make: use kicad-cli to render schematic 2023-03-30 22:26:54 +02:00
King Kévin 5849e04d54 lib: update partdb library 2023-03-30 22:25:49 +02:00
King Kévin 0b268fef02 lib: add logos 2023-03-30 22:25:49 +02:00
King Kévin cf6e95493f lib: switch kicad footprint to v7 2023-03-30 22:25:49 +02:00
King Kévin 58e504ea47 lib: disable qeda pin shapes 2023-03-30 22:23:41 +02:00
King Kévin 87819cd3e6 lib: add partdb library 2023-03-30 22:23:41 +02:00
King Kévin 5d9a596047 lib: enable audio connector library 2023-03-30 22:23:41 +02:00
King Kévin 8992163da1 lib: switch to version 7 2023-03-30 22:23:41 +02:00
King Kévin 4e8d15f64c sch: set kicad6 library 2022-12-24 03:09:46 +01:00
King Kévin 9b313a227c lib: update repo 2022-12-24 03:08:33 +01:00
King Kévin 283b18e1e9 lib: switch output to KiCad 6 2022-12-24 03:08:20 +01:00
King Kévin 9490a25e50 lib: add JLCPCB corrections for USB connectors 2022-12-24 03:05:45 +01:00
King Kévin f69a88300f brd: add material propertires 2022-09-13 12:19:22 +02:00
King Kévin f558b68515 add script to put refdes in fab layer 2022-09-13 12:14:21 +02:00
King Kévin b612622310 make: specify ibom generator 2022-08-10 17:43:30 +02:00
King Kévin c3ce63cbcd make: output iteractive bom 2022-08-10 14:45:31 +02:00
King Kévin 1d561046dd doc: add JLCPCB position correction 2022-08-10 12:39:29 +02:00
King Kévin 4636a6508b doc: replace rake with make 2022-08-10 12:37:46 +02:00
King Kévin e787a3412e add parts placement corrections 2022-07-13 11:10:43 +02:00
King Kévin dc767e3e37 make: output panel fab sooner 2022-07-13 11:10:21 +02:00
King Kévin ac4807e5ac make: remove git hash from revision 2022-07-04 10:17:51 +02:00
King Kévin df2e0df1d7 lib: update repo 2022-06-22 09:13:01 +02:00
King Kévin 54dfc1d55d rake: replace with more common make file 2022-06-22 09:12:23 +02:00
King Kévin 991fb55439 lib: rename generated lib to qeda 2022-06-17 18:06:46 +02:00
King Kévin d00955e75d brd: add net sizes 2022-06-17 17:55:41 +02:00
King Kévin 025d70af1b sch/brd: add template kicad schematic and board layout 2022-06-10 19:56:34 +02:00
King Kévin 8b216cf9ff lib: add most common components 2022-06-10 19:55:18 +02:00
King Kévin b1c719eebb git: remove cache file 2022-06-10 19:54:18 +02:00
King Kévin 4fdef09f30 sch/brd: remove lepton and ringdove files 2022-06-10 19:32:19 +02:00
King Kévin 4699c6b609 lib: update repo 2022-06-10 19:32:19 +02:00
King Kévin 88b9e8eb72 doc: update development doc for kicad toolchain 2022-06-10 19:32:19 +02:00
King Kévin ecb253e18b save JLC PnP corrections 2022-06-10 19:32:19 +02:00
King Kévin 2e982048c5 lib: document correction 2022-06-10 19:32:19 +02:00
King Kévin fc17a5abe3 rake: version panel configuration 2022-06-10 19:32:19 +02:00
King Kévin 0d85bfb90a rake: add panelization target 2022-06-10 19:32:19 +02:00
King Kévin 2882cb46c8 lib: remove date information 2022-06-10 19:32:19 +02:00
King Kévin 834f8c6f51 rake: use custom bom generator configuration 2022-06-10 19:32:19 +02:00
King Kévin 118fcf108c rake: change Rakefile for KiCAD processing 2022-06-10 19:32:13 +02:00
King Kévin 932d8f9a39 git: ignore KiCAD output and cache 2022-06-10 19:31:54 +02:00
King Kévin 097ceb5efc lib: add kikit footprints 2022-06-10 19:31:54 +02:00
King Kévin 26d6478b5c lib: add kicad library config 2022-06-10 19:31:54 +02:00
King Kévin acabbdfa31 lib: remove lepton and ringdove files 2022-06-10 19:31:49 +02:00
King Kévin baecb40eaf lib: allow generating kicad library 2022-06-10 19:31:41 +02:00
46 changed files with 7481 additions and 13329 deletions

2
.gitignore vendored
View File

@ -14,6 +14,7 @@ fp-info-cache
# temporary files
*~
\#*\#
~*.lck
# outputs
*.svg
@ -23,6 +24,7 @@ fp-info-cache
*.zip
*.bom.csv
*.cpl.csv
*.3d.step
*.versioned.*
fabrication

View File

@ -1,17 +1,16 @@
config:
output: kicad
nodate: true
output: kicad7
symbol:
pinIcon: false
pattern:
densityLevel: 'N'
lineWidth:
silkscreen: 0.2
polarityMark: none
preferManufacturer: true
preferManufacturer: false
smoothPadCorners: false
library:
- connector/hdmi-001s
- ic/eeprom_ft24c16a-e@l
- resistor/r0603
- capacitor/c0603
- mcu/st_stm8s003x3@p
- mechanical/dip-switch_dsicxxls@dsic07ls
- diode/led0805

View File

@ -1,34 +0,0 @@
v2
==
instead of an edge plug, the monitor connector is also a receptacle.
this prevents the firewall from sticking out of the monitor too much, particularly when installed in tight spaces.
it also allows to place the HDMI firewall inline even if you don't have access to the monitor's HDMI port.
finally it also allows the board to be manufactured more easily.
the programmer is now included in the firewall.
this offers very easy copy of the EDID data.
no need to use complex linux commands or stand-alone separate programmer.
the programmer uses the embedded EEPROM and acts as I²C slave.
a DIP switch allows to selectively block or forward interfaces.
v1
==
this version comes as dongle, which can directly be plugged in the monitor.
the impedance and length of the differential signal pairs are properly taken care of.
a breakable tab replaces the WP switch.
pads are still present to override the disabled WP and 5V.
the shield is not connected to ground, which causes EEPROM read errors with cheap HDMI cables skimping on the ground wire (pin 17).
the workaround is to scratch the solder mask near one of the HDMI receptacle shell tab and solder it.
v0
==
first working version.
based on the design of the original research.
the HDMI connectors are on opposite sides of the board to make the routing easy (the differential signals are straight lines).
the impedance does not seem to by optimal, leading to EMF leakage (reported by the original researchers).

View File

@ -5,13 +5,23 @@ requirements
to be able to generate the outputs, you need following software:
- make: takes care of generating the output files
- [QEDA](http://qeda.org/): to generate footprints for the parts
- [KiCad](https://www.kicad.org/): EDA software used for schematic capture and board layout
- [KiCad v8](https://www.kicad.org/): EDA software used for schematic capture and board layout
- [PcbDraw](https://github.com/yaqwsx/PcbDraw): to generate board layout rendering
- [KiKit](https://github.com/yaqwsx/KiKit): to generate fabrications files (Gerber, Excellon)
- [KiAuto](https://github.com/INTI-CMNB/KiAuto): to generate schematic printout (PDF)
- [KiBoM](https://github.com/SchrodingersGat/KiBoM): to generate Bill of Material (CSV)
- [Interactive HTML BOM](https://github.com/openscopeproject/InteractiveHtmlBom): to generate placement guide
install Interactive HTML BOM using KiCad's Plugin and Content Manager.
for the others:
~~~
npm install qeda
pip install pcbdraw kibom kikit
~~~
you can additionally install KiKit using KiCad's Plugin and Content Manager for an integrated GUI.
compiling
=========
@ -25,11 +35,13 @@ almost all of the symbols and footprints used in the schematic and board layout
the `library` folder contains the QEDA parts definitions.
to install QEDA using NPM from the official repository:
~~~
sudo npm install -g qeda
~~~
to install QEDA from the sources:
~~~
git clone https://github.com/qeda/qeda
cd qeda
@ -38,6 +50,7 @@ sudo npm install --global
~~~
to generate the parts:
~~~
make lib
~~~
@ -54,6 +67,7 @@ it uses standard symbols, and the ones in the `kicad/` folder.
most symbols are generated by QEDA as described above.
to export as pdf:
~~~
make print
~~~
@ -62,6 +76,7 @@ BOM
---
to export the bill of material (as CSV):
~~~
make bom
~~~
@ -73,9 +88,10 @@ the `.kicad_brd` file is the board layout source file.
it has been drawn using the [KiCAD pcbnew](https://docs.kicad.org/6.0/en/pcbnew/pcbnew.html) PCB editor.
it uses the footprints from the `kicad/` folder.
most footprints are generated by QEDA as described above.
most symbols are generated by QEDA as described above.
to export gerber files for PCB manufacturer (and photo preview + overview document):
~~~
make fabrication
~~~

View File

@ -1,11 +0,0 @@
package;x;y;rot
LEDC2012X80N;0;0;-90
UC1608X55N;0;0;-90
CAPC1608X92N;0;0;-90
SOT95P237X112-3N;0;0;180
CONNECTOR_MY-1220-03;0;-1.1;0
CONNECTOR_XKB_U262-24XN-4BV64;0;-1.3;180
CONNECTOR_U231-09XN-4BLRA00;0;-3.0;0
SOP254P976X355-14N;0;0;-90
SOP65P640X120-20N;0;0;-90
CONNECTOR_HDMI-001S;0;1.1;0
1 package x y rot
2 LEDC2012X80N 0 0 -90
3 UC1608X55N 0 0 -90
4 CAPC1608X92N 0 0 -90
5 SOT95P237X112-3N 0 0 180
6 CONNECTOR_MY-1220-03 0 -1.1 0
7 CONNECTOR_XKB_U262-24XN-4BV64 0 -1.3 180
8 CONNECTOR_U231-09XN-4BLRA00 0 -3.0 0
9 SOP254P976X355-14N 0 0 -90
10 SOP65P640X120-20N 0 0 -90
11 CONNECTOR_HDMI-001S 0 1.1 0

28
KiBOM_CLI.py Normal file
View File

@ -0,0 +1,28 @@
#!/usr/bin/env python3
"""
@package
KiBOM - Bill of Materials generation for KiCad
Generate BOM in xml, csv, txt, tsv, html or xlsx formats.
- Components are automatically grouped into BoM rows (grouping is configurable)
- Component groups count number of components and list component designators
- Rows are automatically sorted by component reference(s)
- Supports board variants
Extended options are available in the "bom.ini" config file in the PCB directory
(this file is auto-generated with default options the first time the script is executed).
For usage help:
python KiBOM_CLI.py -h
"""
import sys
import os
here = os.path.abspath(os.path.dirname(__file__))
sys.path.insert(0, here)
from kibom.__main__ import main # noqa: E402
main()

View File

@ -1,13 +1,20 @@
# project file name (use for schematic and board layout)
NAME ?= hdmi_firewall
NAME ?= template
SUBSHEET ?=
# path to KiCad CLI
KICAD = kicad-cli
# path to qeda
QEDA := qeda
# path to KiBOM
KIBOM := kibom
# path to InteractiveHtmlBom
IBOMGEN := ~/.local/share/kicad/8.0/3rdparty/plugins/org_openscopeproject_InteractiveHtmlBom/generate_interactive_bom.py
# read project version
VERSION := $(shell cat version)
# current date for stamping output
DATE = $(shell date +%Y-%m-%d)
# revision based on number of changes on schematic or board layout and current git commit
# revision based on number of changes on schematic or board layout
REVISION := $(shell git log --pretty=oneline "${NAME}.kicad_sch" "${NAME}.kicad_pcb" | wc -l)
# generate file with version information
@ -18,17 +25,34 @@ define version_rule
sed --in-place 's/\$$$$version\$$$$/${VERSION}/g' $$@
sed --in-place 's/\$$$$date\$$$$/${DATE}/g' $$@
sed --in-place 's/\$$$$revision\$$$$/${REVISION}/g' $$@
sed --in-place 's/\.kicad_sch/.versioned.kicad_sch/g' $$@
endef
$(foreach EXT,$(VERSIONED_EXT),$(eval $(call version_rule,$(EXT))))
VERSIONED_SHEET = $(foreach SHEET,$(NAME) $(SUBSHEET),$(SHEET).versioned.kicad_sch)
all: print fabrication
FABRICATION_DIR := fabrication
IBOM := ${FABRICATION_DIR}/ibom.html
print: ${NAME}.sch.pdf ${NAME}.brd-top.png ${NAME}.brd-bot.png ${NAME}.bom.csv
all: $(VERSIONED_SHEET) ${NAME}.sch.pdf ${NAME}.bom.csv render fab
fab: ${FABRICATION_DIR} ${IBOM}
render: ${NAME}.brd-top.png ${NAME}.brd-bot.png ${NAME}.brd-top.svg ${NAME}.brd-bot.svg ${NAME}.3d.step
# generate fabrication files (gerbers/drill/BoM/PnP)
FABRICATION_DIR := fabrication
fabrication: ${NAME}.versioned.kicad_sch ${NAME}.versioned.kicad_pcb
kikit fab jlcpcb --drc --assembly --schematic $^ ${FABRICATION_DIR}
${FABRICATION_DIR}: ${NAME}.versioned.kicad_sch ${NAME}.versioned.kicad_pcb
kikit fab jlcpcb --no-drc --assembly --field JLCPCB,LCSC --schematic $^ $@
# generate fabrication files (gerbers/drill/uncorrected PnP)
#${FABRICATION_DIR}: ${NAME}.versioned.kicad_pcb
# mkdir -p ${FABRICATION_DIR}
# $(KICAD) pcb export gerbers --output ${FABRICATION_DIR} $<
# $(KICAD) pcb export drill --output ${FABRICATION_DIR}/ $<
# $(KICAD) pcb export pos --output ${FABRICATION_DIR}/${NAME}.versioned.pos $<
# generate interactive BoM
${IBOM}: ${NAME}.versioned.kicad_pcb
python $(IBOMGEN) --no-browser --dest-dir `dirname $@` --name-format `basename $@ ".html"` --show-fields "Value" $< &>/dev/null
# generate symbols and footprints from parts
lib:
@ -36,36 +60,53 @@ lib:
# generate printable version (PDF) of schematic
%.sch.pdf: %.versioned.kicad_sch %.versioned.kicad_pro
eeschema_do export $< .
mv $*.versioned.pdf $@
$(KICAD) sch export pdf --output $@ $<
# generate render from layout (top side)
%.brd-top.png: %.versioned.kicad_pcb
pcbdraw --silent $< --dpi 600 $@
pcbdraw plot --silent --no-components --dpi 600 --side front $< $@
# generate render from layout (bottom side)
%.brd-bot.png: %.versioned.kicad_pcb
pcbdraw --silent $< --dpi 600 --back $@
pcbdraw plot --silent --no-components --dpi 600 --side back $< $@
# generate render from layout (top side)
%.brd-top.svg: %.versioned.kicad_pcb
$(KICAD) pcb export svg --layers F.Cu,F.Paste,F.Silkscreen,Edge.Cuts --page-size-mode 2 --exclude-drawing-sheet --output $@ $<
# generate render from layout (bottom side)
%.brd-bot.svg: %.versioned.kicad_pcb
$(KICAD) pcb export svg --layers B.Cu,B.Paste,B.Silkscreen,Edge.Cuts --mirror --page-size-mode 2 --exclude-drawing-sheet --output $@ $<
# export Bill of Material (as CSV)
%.bom.csv: %.versioned.kicad_sch %.versioned.kicad_pro
eeschema_do bom_xml $< .
kibom $*.versioned.xml $@
%.bom.xml: %.versioned.kicad_sch %.versioned.kicad_pro
$(KICAD) sch export python-bom --output $@ $<
# export 3D model
%.3d.step: %.versioned.kicad_pcb
$(KICAD) pcb export step --output $@ $<
# export Bill of Material (as CSV)
%.bom.csv: %.bom.xml
$(KIBOM) $< $@
# generate panel
PANEL_DIR := panel
panel: panel.kicad_pcb
panel.kicad_pcb: ${NAME}.versioned.kicad_pcb ${NAME}.versioned.kicad_pro ${NAME}.versioned.kicad_sch ${NAME}.versioned.json
kikit panelize -p ${NAME}.versioned.json ${NAME}.versioned.kicad_pcb $@
PANEL_DIR := panel_fab
panel: panel.kicad_pcb panel.brd-top.svg panel.brd-bot.svg panel.brd-top.png panel.brd-bot.png ${PANEL_DIR}
panel.kicad_pcb: ${NAME}.versioned.kicad_pcb ${NAME}.versioned.kicad_pro ${NAME}.versioned.kicad_sch panel.versioned.json
kikit panelize -p panel.versioned.json ${NAME}.versioned.kicad_pcb $@
sed --in-place 's/\"missing_courtyard\": \"warning\"/\"missing_courtyard\": \"ignore\"/g' $(patsubst %.kicad_pcb,%.kicad_pro,$@) # the mouse bites don't have a courtyard
kikit fab jlcpcb --drc --assembly --missingError --schematic ${NAME}.versioned.kicad_sch $@ ${PANEL_DIR}
pcbdraw --silent $@ --dpi 600 panel.brd-top.png
pcbdraw --silent $@ --dpi 600 --back panel.brd-bot.png
${PANEL_DIR}: ${NAME}.versioned.kicad_sch panel.kicad_pcb
kikit fab jlcpcb --assembly --missingError --field JLCPCB,LCSC --schematic $^ $@
clean:
rm -f $(foreach EXT,$(VERSIONED_EXT),${NAME}.versioned.$(EXT))
rm -f ${NAME}.sch.pdf ${NAME}.brd-top.png ${NAME}.brd-bot.png ${NAME}.versioned.xml ${NAME}.bom.csv
rm -f ${NAME}.sch.pdf ${NAME}.brd-top.png ${NAME}.brd-bot.png ${NAME}.brd-top.svg ${NAME}.brd-bot.svg ${NAME}.versioned.xml ${NAME}.bom.csv
rm -f ${NAME}.versioned.kicad_prl ${NAME}.versioned.kicad_pro-bak ${NAME}.versioned.xml ${NAME}.versioned.csv
rm -f ${IBOM}
rm -rf ${FABRICATION_DIR}
rm -f panel.kicad_pcb panel.kicad_pro
rm -f panel.versioned.json panel.kicad_pcb panel.kicad_pro panel.brd-top.svg panel.brd-bot.svg panel.brd-top.png panel.brd-bot.png
rm -rf ${PANEL_DIR}

214
README.md
View File

@ -1,219 +1,7 @@
The HDMI firewall prevents devices from hacking HDMI equipment, and vice-versa.
<img src="picture/front_v2.webp" title="front" height="250"/>
<img src="picture/back_v2.webp" title="back" height="250"/>
these are the hardware design files for **insert project name here**.
purpose
=======
HDMI is mainly used to transfer audio and video, but also offers a number of additional features (e.g. HDCP, CEC, HEC, ARC, MHL).
This increases the attack surface, and since the security of their implement in embedded devices is far from ideal, an attacker could exploit them and inject malicious code.
Now your unsuspicious video equipment is compromised and threatens your IT/network security.
And your monitor could then in turn hack back any other device connected to it.
For example, let's imagine you invite an external guest for a presentation inside your company.
You offer to connect to a smart TV or video-projector so he can show his slides.
This is the perfect opportunity for the guest to hack it.
Now your smart TV can act as a spy in your network.
Or next time an employee connects to the projector, his laptop is hacked back.
And voila, the innocent guest managed to infiltrate your company network, and can exfiltrate confidential information.
The HDMI firewall can block all additional interfaces, and only allow audio and video data transfer.
It is based on the research of Pierre-Michel Ricordel and José Lopes Esteves from ANSSI/SDE/ST/LSF presented at the IT security conference [SSTIC 2021](https://sstic.org/2021/presentation/un_pare_feu_pour_le_hdmi/).
Some security research and vulnerabilities around CEC and EDID are listed in [slide 4](https://www.sstic.org/media/SSTIC2021/SSTIC-actes/un_pare_feu_pour_le_hdmi/SSTIC2021-Slides-un_pare_feu_pour_le_hdmi-lopes-esteves_ricordel.pdf).
usage
=====
First plug the HDMI cable going to the monitor on the HDMI firewall on the port labeled **MONITOR**.
Then plug the HDMI cable going to the device on the HDMI firewall on the port labeled **DEVICE**.
That's it, your equipment (monitor and device) are now protected.
But the firewall should be fine tuned as described below.
The HDMI firewall comes with a generic HD profile, but this might not correspond to the capabilities of your monitor.
The resulting image could be distorted, or completely missing.
Thus, you first have to copy the Extended Display Identification Data (EDID) information of the equipment to protect.
This data includes information such as the supported resolutions.
The HDMI firewall can copy the EDID from the monitor:
1. ensure the firewall is connected to the monitor
1. unplug the device from the firewall
1. toggle the small switch labeled EDID/7 to the ALLOW/ON position
1. ensure the SDA/2 and SCL/3 switches are on the BLOCK/OFF position
1. plug the device to the firewall
1. this will power the firewall, which will copy the monitor EDID onto its internal memory, shown by a short blink of the ERROR LED
1. unplug the device, and switch back the EDID/7 switch to the BLOCK/OFF position so the firewall keeps and uses the copied EDID information
1. when connecting the device back in, you should see the same name as the monitor, with a '|' at the end, indicating you are using the EDID from the firewall
The HDMI firewall allows to select which interfaces are blocked using the switches.
The highest security is provided when blocking all lines by setting the switches to the BLOCK position.
If you still trust your equipment enough and want to use a feature, you can set the corresponding switch to the ALLOW/ON position:
- 5V: some monitors require this line to detect when a device is plugged in, and since currently no other information is transferred over this line, it is rather safe to enable it
- Display Data Channel (DDC): High-bandwidth Digital Content Protection (HDCP) uses this interface. To enable it, switch SDA and SCL on. Warning: since the EDID is also transferred over this interface, the firewall can't provide a write-protected copy of it. Instead the original monitor EDID is used, maybe not write-protected.
- Consumer Electronics Control (CEC): this interface allows to remotely control equipment, such as setting the volume and powering on/off all connected devices and monitors at once
- HDMI Ethernet Channel (HEC), Audio Return Channel (ARC), and Mobile High-Definition Link (MHL): to enable these interfaces, switch UTIL and HPD on to forward the HEAC+ and HEAC- lines
The HDMI firewall can also be used to provide custom EDID, as it sometimes is faulty in the monitor.
For that you need to program the raw binary EDID (with up to 1 extension block) onto the STM8S103 EEPROM using the RST and SWIM lines made available on the back of the board.
limitations
===========
The HDMI firewall use impedance controlled lines: 4-layer impedance controlled board, differential pair routing, intra- and inter-pair length matching.
This should allow and audio any video signal to be transmitted to the monitor.
But I only have 2K equipment I could test it on.
I could not test the firewall against 4K, 8K, or 3D capable monitors.
CEC remote control has been tested.
But I don't have any equipment using HDCP, HEC, ARC, or MHL.
Thus I could also not test these interfaces.
The firewall only supports EDID with up to 1 extension block.
This is the case for all monitors I've seen.
Some high end monitors supporting numerous features might have additional extensions blocks.
Thus the firewall might prevent from using the monitor to its full potential.
You can still use the original EDID from the monitor by setting the SDA/2 and SCL/3 switches to the ALLOW/ON position.
The DDC channel won't be firewalled anymore though.
Feel free to report any success or issues to `hdmi@cuvoodoo.info`.
availability
============
The HDMI firewall is available on [tindie](https://www.tindie.com/products/cuvoodoo/hdmi-firewall/).
The schematic pdf and board gerbers are available as [release](https://git.cuvoodoo.info/kingkevin/board/releases/tag/hdmi_firewall_v2).
firmware
========
The firmware and sources for the HDMI firewall embedded programmer are available [here](https://git.cuvoodoo.info/kingkevin/stm8s/src/branch/hdmi_firewall).
troubleshooting
===============
If the monitor does not detect the device or does not display anything (but should), try to re-enable the 5V forward (as per default) by switching the 5V/1 switch to ALLOW/ON.
If the ERROR LED stays on, it means copying the EDID failed:
- be sure the monitor is connected before you connect the device (which powers the firewall)
- be sure the SDA/2 and SCL/3 switches are set to BLOCK so the firewall can use the DDC interface to read the EDID
- the EDID of the monitor might be corrupted or have an invalid checksum, in which case the firewall will not copy it
- the firewall EEPROM memory has worn out or is defective (it should last 300 thousand copies)
custom EDID
===========
It is possible to write custom EDID on the HDMI firewall, for example because:
- the monitor's original EDID is corrupted
- you want to disable a feature or resolution causing your device to misbehave
- you want to re-enable a feature the monitor actually supports
- the KVM switch does not reflect the HDMI monitor change
- you want to do security research
For that you can use the debugging pins left on the board, and [program](https://git.cuvoodoo.info/kingkevin/stm8s/src/branch/hdmi_firewall/README.md) the raw EDID in the STM8S EEPROM area using an ST-LINK/V2 programmer.
If you switch EDID to the ALLOW position, the HDMI firewall's EEPROM is not write-protected (on devices shipped after 2022-08-19).
This allows to use the HDMI connection to write the EEPROM content using the DDC's I²C bus, and does not required an external programmer.
These instructions are for Linux.
For Windows see the instructions provided in the [original research slides](https://www.sstic.org/media/SSTIC2021/SSTIC-actes/un_pare_feu_pour_le_hdmi/SSTIC2021-Slides-un_pare_feu_pour_le_hdmi-lopes-esteves_ricordel.pdf) (untested).
Install tools to read/write I²C devices:
- for Debian-based distributions
~~~
sudo apt install i2c-tools
~~~
Make the I²C buses user accessible (under /dev/i2c-*):
~~~
sudo modprobe i2c-dev
~~~
Now we have to figure out which I²C bus corresponds to the HDMI port.
First list the available buses:
~~~
sudo i2cdetect -l
~~~
You should see something like this:
~~~
i2c-0 smbus SMBus PIIX4 adapter port 0 at 0b00 SMBus adapter
i2c-1 smbus SMBus PIIX4 adapter port 2 at 0b00 SMBus adapter
i2c-2 smbus SMBus PIIX4 adapter port 1 at 0b20 SMBus adapter
i2c-3 i2c AMDGPU DM i2c hw bus 0 I2C adapter
i2c-4 i2c AMDGPU DM i2c hw bus 1 I2C adapter
i2c-5 i2c AMDGPU DM i2c hw bus 2 I2C adapter
i2c-6 i2c AMDGPU DM i2c hw bus 3 I2C adapter
i2c-7 i2c AMDGPU DM aux hw bus 0 I2C adapter
i2c-8 i2c AMDGPU DM aux hw bus 2 I2C adapter
i2c-9 i2c AMDGPU DM aux hw bus 3 I2C adapter
i2c-10 i2c DPMST I2C adapter
i2c-11 i2c DPMST I2C adapter
~~~
Candidate buses are 3 to 9, used by the GPU (number after i2c- in the first column).
Disconnect everything from the HDMI port, and scan for devices on each I²C bus (replace BUS with the bus number):
~~~
sudo i2cdetect -y BUS
~~~
Since nothing is connected, no device should be detected, and the output should look like this:
~~~
0 1 2 3 4 5 6 7 8 9 a b c d e f
00: -- -- -- -- -- -- -- --
10: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
50: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
70: -- -- -- -- -- -- -- --
~~~
Now connect the HDMI firewall on the device side to your HDMI port and re-scan for devices.
If you see the following result, you found the I²C bus of the HDMI port.
Else continue with the next bus.
~~~
0 1 2 3 4 5 6 7 8 9 a b c d e f
00: -- -- -- -- -- -- -- --
10: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
50: 50 -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
70: -- -- -- -- -- -- -- --
~~~
Write your custom EDID data `edid.bin` to the HDMI firewall (replace BUS with corresponding bus number):
~~~
for addr in `seq 0 255`; do echo $addr; sudo i2cset -y BUS 0x50 $addr 0x`xxd -p -l 1 -s $addr edid.bin`; done
~~~
To verify the data has been written correctly, compare original data with the one on the EEPROM:
~~~
# display original dumped data
xxd -g 1 edid.bin
# display data written on EEPROM
sudo i2cdump -y BUS 0x50
~~~
Once writing the EDID to the HDMI firewall memory succeeded:
- re-enable write protection by toggling the EDID switch to the BLOCK position
- re-plug the HDMI firewall for the device to retrieve the newly written EDID
To read and play with EDID under Linux, you can use the tips provided for the previous [HDMI firewall v1](https://git.cuvoodoo.info/kingkevin/board/src/tag/hdmi_firewall_v1/README.md).

76
bom.ini
View File

@ -1,10 +1,37 @@
[BOM_OPTIONS]
; General BoM options here
; If 'ignore_dnf' option is set to 1, rows that are not to be fitted on the PCB will not be written to the BoM file
ignore_dnf = 0
number_rows = 0
; If 'html_generate_dnf' option is set to 1, also generate a list of components not fitted on the PCB (HTML only)
html_generate_dnf = 1
; If 'use_alt' option is set to 1, grouped references will be printed in the alternate compressed style eg: R1-R7,R18
use_alt = 0
; If 'alt_wrap' option is set to and integer N, the references field will wrap after N entries are printed
alt_wrap = 0
; If 'number_rows' option is set to 1, each row in the BoM will be prepended with an incrementing row number
number_rows = 1
; If 'group_connectors' option is set to 1, connectors with the same footprints will be grouped together, independent of the name of the connector
group_connectors = 1
test_regex = 0
; If 'test_regex' option is set to 1, each component group will be tested against a number of regular-expressions (specified, per column, below). If any matches are found, the row is ignored in the output file
test_regex = 1
; If 'merge_blank_fields' option is set to 1, component groups with blank fields will be merged into the most compatible group, where possible
merge_blank_fields = 1
; Specify output file name format, %O is the defined output name, %v is the version, %V is the variant name which will be ammended according to 'variant_file_name_format'.
output_file_name = %O%V
; Specify the variant file name format, this is a unique field as the variant is not always used/specified. When it is unused you will want to strip all of this.
variant_file_name_format = _(%V)
; Field name used to determine if a particular part is to be fitted
fit_field = Config
; Make a backup of the bom before generating the new one, using the following template
;make_backup = %O.tmp
; Default number of boards to produce if none given on CLI with -n
number_boards = 1
; Default PCB variant if none given on CLI with -r
board_variant = ['default']
; Whether to hide headers from output file
hide_headers = False
; Whether to hide PCB info from output file
hide_pcb_info = False
[IGNORE_COLUMNS]
; Any column heading that appears here will be excluded from the Generated BoM
@ -15,9 +42,14 @@ Footprint
Footprint Lib
Build Quantity
sheetpath
qeda_part
qeda_variant
name
JLCPCB_CORRECTION
Rating
[COLUMN_ORDER]
; Columns will apear in the order they are listed here
; Columns will appear in the order they are listed here
; Titles are case-insensitive
References
Value
@ -28,15 +60,49 @@ Part Lib
Footprint
Footprint Lib
Build Quantity
Manufacturer
MPN
DigiKey
LCSC
JLCPCB
Datasheet
[GROUP_FIELDS]
; List of fields used for sorting individual components into groups
; Components which match (comparing *all* fields) will be grouped together
; Field names are case-insensitive
Part
Part Lib
Value
Footprint
Footprint Lib
[COMPONENT_ALIASES]
; A series of values which are considered to be equivalent for the part name
; Each line represents a list of equivalent component name values separated by white space
; e.g. 'c c_small cap' will ensure the equivalent capacitor symbols can be grouped together
; Aliases are case-insensitive
c c_small cap capacitor
r r_small res resistor
sw switch
l l_small inductor
zener zenersmall
d diode d_small
[REGEX_INCLUDE]
; A series of regular expressions used to include parts in the BoM
; If there are any regex defined here, only components that match against ANY of them will be included in the BOM
; Column names are case-insensitive
; Format is: "[ColumName] [Regex]" (white-space separated)
[REGEX_EXCLUDE]
; A series of regular expressions used to exclude parts from the BoM
; If a component matches ANY of these, it will be excluded from the BoM
; Column names are case-insensitive
; Format is: "[ColumName] [Regex]" (white-space separated)
References ^TP[0-9]*
References ^FID
Part mount.*hole
Part solder.*bridge
Part test.*point
Footprint test.*point
Footprint mount.*hole
Footprint fiducial

View File

@ -1,5 +1,6 @@
(fp_lib_table
(version 7)
(lib (name "qeda")(type "KiCad")(uri "${KIPRJMOD}/kicad/qeda.pretty")(options "")(descr ""))
(lib (name "kikit")(type "KiCad")(uri "${KIPRJMOD}/kicad/kikit.pretty")(options "")(descr ""))
(lib (name "custom")(type "KiCad")(uri "${KIPRJMOD}/kicad/custom.pretty")(options "")(descr ""))
(lib (name "logo")(type "KiCad")(uri "${KIPRJMOD}/kicad/logo.pretty")(options "")(descr ""))
)

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -1,586 +0,0 @@
(footprint "qr" (version 20211014) (generator pcbnew)
(layer "F.Cu")
(tedit 0)
(fp_text reference "QR*****" (at 0 9.75) (layer "F.SilkS")
(effects (font (size 1 1) (thickness 0.15)))
(tstamp 9e6b350f-4f76-445c-8b14-e5fba0b3c339)
)
(fp_text value "qr" (at 0 -9.75) (layer "F.SilkS")
(effects (font (size 1 1) (thickness 0.15)))
(tstamp bf1afb24-41a3-4ce2-849b-41193908d732)
)
(fp_rect (start -1.25 -1.75) (end -0.75 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 008d9bf7-df0b-4f0e-9a3a-62d5e135d9fc))
(fp_rect (start 6.75 -5.25) (end 7.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 00938406-3197-4e78-9bf6-ec17e23fa7f9))
(fp_rect (start 0.25 -4.75) (end 0.75 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 01556b6f-db5c-4dc0-b16e-b8fc83d28094))
(fp_rect (start -1.25 -5.25) (end -0.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 018d1958-5221-4b77-9657-c7d8fac8a9e3))
(fp_rect (start -7.25 7.75) (end -6.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 02510734-50da-4e20-acb8-8016ab1a7e3b))
(fp_rect (start -6.75 7.75) (end -6.25 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 029b4955-b66d-4133-a388-80926b16133e))
(fp_rect (start 6.75 -1.75) (end 7.25 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 02e38b0a-ed5b-4463-94bf-9ce149b9ebe0))
(fp_rect (start -4.75 -0.25) (end -4.25 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 02ef10c7-adc0-41a6-b708-8d45908af5da))
(fp_rect (start 7.25 5.25) (end 7.75 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 03293cd0-8b40-46c8-9ae9-826fc80eef04))
(fp_rect (start -1.75 -4.25) (end -1.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 03502eb3-0d7d-40aa-8306-3088047130a0))
(fp_rect (start -0.75 0.75) (end -0.25 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 035ddf16-d9b4-471f-b23d-51008ca26b9d))
(fp_rect (start -7.25 2.25) (end -6.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 03af1ce5-e002-4293-9084-f50df3abcbe1))
(fp_rect (start 2.75 2.25) (end 3.25 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 03d7d2e9-51cd-43de-9126-65a1d258cc3c))
(fp_rect (start -6.75 -2.25) (end -6.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 04261d17-0901-45e9-a4ea-758c2550555f))
(fp_rect (start -6.75 2.75) (end -6.25 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 058d4ea5-7956-4028-84bd-671a4194265c))
(fp_rect (start 5.75 3.75) (end 6.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 05fbc8f9-3353-4c5e-a205-a59271af6b89))
(fp_rect (start -8.25 3.75) (end -7.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 066c73a1-a722-46cc-8c59-2f329c119b3a))
(fp_rect (start 6.25 6.25) (end 6.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 0780f3d3-4f03-4b4c-9106-9850541bbc05))
(fp_rect (start 1.75 6.75) (end 2.25 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 08391784-b3e9-4414-9904-050300b66ac7))
(fp_rect (start -1.75 2.25) (end -1.25 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 08c918f7-8fb5-4ad0-ab08-9a9f491a36ba))
(fp_rect (start -5.25 -5.25) (end -4.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 08d9eea2-5847-45b8-a824-37958ec0380e))
(fp_rect (start -8.25 -4.25) (end -7.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 0938dc38-2baf-4202-ada7-26e895329da7))
(fp_rect (start 7.75 -5.75) (end 8.25 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 0b747d3e-5fa5-499e-af05-4957ada1603d))
(fp_rect (start -1.75 -0.25) (end -1.25 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 0bdb8eb2-1208-443d-bd5d-80f93de32008))
(fp_rect (start 5.75 1.75) (end 6.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 0d0f6bb0-c6fb-438b-87c7-53a70f3007f5))
(fp_rect (start -6.25 2.25) (end -5.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 0df7b1ab-9fb2-42b6-b3ab-e3e30ff526f8))
(fp_rect (start 3.25 6.75) (end 3.75 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 0ed367a8-9d3b-4a3b-8852-6aa44eba4480))
(fp_rect (start 6.25 3.75) (end 6.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 0f415d0a-4861-4df6-82d1-d5757a33cd3e))
(fp_rect (start 5.25 1.25) (end 5.75 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 0f802ffe-949c-45e7-997f-da72150665b3))
(fp_rect (start 6.25 1.75) (end 6.75 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1017e9b7-1c96-4b0a-83da-67088d937cf5))
(fp_rect (start -4.75 -4.25) (end -4.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 111400f2-24a9-4c12-b3aa-d2f0601042d5))
(fp_rect (start 6.25 2.25) (end 6.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 11bb9ccc-265d-4091-bc67-2b936c3bbfb0))
(fp_rect (start 1.25 -4.75) (end 1.75 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 11be8715-7049-4601-ab56-81f88ab5e356))
(fp_rect (start -2.25 -0.75) (end -1.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 11f2076c-8d3e-4d5f-ba17-8bfcd34a30dc))
(fp_rect (start -5.25 -4.25) (end -4.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1310b6a0-7aa6-40a4-98e9-1419d49fcbf1))
(fp_rect (start 2.75 0.75) (end 3.25 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 132301c1-cab9-4592-ba51-e4e4a5fca339))
(fp_rect (start 6.25 -7.25) (end 6.75 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1347c0b5-22f7-4bbf-9d60-cb2a3270e2cc))
(fp_rect (start 6.75 -3.75) (end 7.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 138d1c7b-3e65-42ee-8299-496eea7b4bd8))
(fp_rect (start 0.25 0.75) (end 0.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 14880cbf-596e-4ff2-b58a-463f638716bf))
(fp_rect (start -0.25 -0.75) (end 0.25 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 14a4b050-8210-491a-a1b2-8cc4d72298cb))
(fp_rect (start 5.25 5.75) (end 5.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 14b2b7f2-4619-4d3c-9670-4575eccf336a))
(fp_rect (start 5.75 -6.25) (end 6.25 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 14c73277-ce2c-41c8-a77d-062150b40938))
(fp_rect (start -3.75 -5.75) (end -3.25 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 14ffd0cd-da4e-4694-8b98-0fa87d0daf61))
(fp_rect (start -6.25 6.75) (end -5.75 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 15ebf12b-eb90-45af-a73d-5bcf4cae7ba9))
(fp_rect (start 6.75 -1.25) (end 7.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 15f18e2c-8716-4735-92c1-4bee31d699b1))
(fp_rect (start -7.75 0.75) (end -7.25 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 165d50f2-5c54-4dd6-977f-bc2cb9520adc))
(fp_rect (start -8.25 -7.75) (end -7.75 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 169d7211-8d5c-4564-a95f-8904faf52384))
(fp_rect (start -5.25 2.75) (end -4.75 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 177e4de7-86f0-4c08-838c-ef52d77c4d19))
(fp_rect (start -8.25 -3.75) (end -7.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 17b08bdc-aca4-4a00-91c0-3b00312992a0))
(fp_rect (start -6.25 1.75) (end -5.75 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 17c0af7a-a819-4966-bb6b-9648cac7ad77))
(fp_rect (start 4.25 -1.25) (end 4.75 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1af7a4c7-94dc-4b16-a9ca-5e10175c9bb4))
(fp_rect (start -3.25 -3.75) (end -2.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1b6d3ba4-7c56-4af8-a492-5bd95715b300))
(fp_rect (start -1.25 -0.75) (end -0.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1b7ab684-3857-4d01-85a3-5f7563e52bf4))
(fp_rect (start -5.25 -2.25) (end -4.75 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1bcf33d0-f9be-4c1a-838d-9e335aeb9966))
(fp_rect (start 4.75 0.75) (end 5.25 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1bed4bfd-72bf-48c2-b894-058c57ac1dcc))
(fp_rect (start 3.75 -5.25) (end 4.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1c554959-db2d-459c-a889-54845516d0ff))
(fp_rect (start 3.75 -5.75) (end 4.25 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1ceb171a-ff7a-43ea-a0e9-5b513c0813e1))
(fp_rect (start -4.25 4.25) (end -3.75 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1cf9ef5c-71e6-4bb3-8cba-02da70c6bc64))
(fp_rect (start -5.75 -5.25) (end -5.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1e361ab6-2b75-4698-a40b-19e42cf7434d))
(fp_rect (start 1.25 -1.75) (end 1.75 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1f0c1b18-0fda-4f84-a744-0debf1b1221d))
(fp_rect (start -8.25 5.75) (end -7.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1f5a0567-4a9c-441a-be38-768cc7b7cdb3))
(fp_rect (start 4.75 -5.75) (end 5.25 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 1f8470d3-2fe2-4853-a1b0-19b09a8fa732))
(fp_rect (start 5.75 -8.25) (end 6.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 20c217e7-b916-4cc2-85ac-9dc2d0bb1dae))
(fp_rect (start 6.25 -6.25) (end 6.75 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 20d5dd0e-46b2-40db-98aa-6197af00ca3c))
(fp_rect (start 5.75 -7.25) (end 6.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2112cd90-6b85-481b-a7b7-58e10696e91e))
(fp_rect (start -5.25 -1.25) (end -4.75 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 21e42d35-42cc-423d-9ed0-fb3c8c3363b7))
(fp_rect (start 1.25 2.75) (end 1.75 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2209dcb9-e729-44a2-88e2-5ccc13def596))
(fp_rect (start -3.75 -3.75) (end -3.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2216986d-d734-4750-a2d1-f213d1a260c0))
(fp_rect (start 5.75 3.25) (end 6.25 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 221e0c16-e39a-4b3c-b849-d875252ebb39))
(fp_rect (start 7.75 -6.75) (end 8.25 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 222f5976-e602-43fd-86a1-b5ca30391bf5))
(fp_rect (start -7.75 -0.75) (end -7.25 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 22698583-9f09-4b33-9648-2f7fbcf89177))
(fp_rect (start -4.25 4.75) (end -3.75 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 22f05fb8-73e3-4c3d-810a-cae112e5205c))
(fp_rect (start 4.75 1.25) (end 5.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 241a7c35-28a8-4d76-b832-9af5a7a71b5e))
(fp_rect (start 1.75 -5.75) (end 2.25 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 24511be0-402a-46d0-8465-67c87fa85782))
(fp_rect (start 2.75 -6.75) (end 3.25 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2506bd70-32ff-4a58-97df-b7eac111fd85))
(fp_rect (start 4.25 0.25) (end 4.75 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 264145ae-9b08-47b1-a3c2-e34973db43ab))
(fp_rect (start -5.25 -7.25) (end -4.75 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 26e8b733-4e53-4a85-9f76-9b12f09efe3d))
(fp_rect (start -5.25 5.75) (end -4.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 27094ddc-5b0b-4d51-bc91-052e93536d53))
(fp_rect (start 4.75 -6.75) (end 5.25 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 27c1d2be-4e2b-4453-8eea-93364c92ffba))
(fp_rect (start 2.25 -6.75) (end 2.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 29096d1b-1332-4e78-9911-102589b9a4ba))
(fp_rect (start 5.25 3.75) (end 5.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2982d0ab-a03e-4749-85db-7873f8c49070))
(fp_rect (start -6.25 0.25) (end -5.75 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2a0566c8-99b0-4db5-b22c-6f31e0194ad3))
(fp_rect (start 2.25 -0.25) (end 2.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2a0f53ba-91ca-4a6c-80dd-860e5294e227))
(fp_rect (start -2.25 -2.75) (end -1.75 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2a4bdfcd-23da-466c-a641-2a6a7b59bba6))
(fp_rect (start 0.75 -1.75) (end 1.25 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2b795e9d-89b8-461e-a9b3-d5c0b38b4d37))
(fp_rect (start -2.75 -2.75) (end -2.25 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2bcfe39f-472b-47af-a282-496728ae0f7d))
(fp_rect (start -5.25 7.75) (end -4.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2c6b9901-cd8a-48be-b8f2-dce72e9ad4bb))
(fp_rect (start 7.25 -0.25) (end 7.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2dbad0ec-ad07-41f5-896e-85b7cf6d538b))
(fp_rect (start 4.75 -7.25) (end 5.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2df0154a-af6d-4896-87dd-f15f5743011e))
(fp_rect (start -6.25 -8.25) (end -5.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2e6ab65c-494b-4d79-88e6-b23e3a8a65d2))
(fp_rect (start 1.75 -4.75) (end 2.25 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2ec80302-2da3-40ff-b474-290de218fa68))
(fp_rect (start 1.75 -3.75) (end 2.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2ee14f4d-4e42-4dd1-8332-7e1304e5eade))
(fp_rect (start -6.25 3.75) (end -5.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2f18add8-f7ed-4a04-9fb8-ae5e9c1d7014))
(fp_rect (start 5.75 4.75) (end 6.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2f3205de-9db5-44c8-acda-d0153e426434))
(fp_rect (start 1.75 -7.25) (end 2.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 2fc31cee-dc7b-4190-a92f-97e518556aaf))
(fp_rect (start 4.75 3.75) (end 5.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 300340c0-c8c7-4413-ab6e-fb5740bf5664))
(fp_rect (start 3.25 -3.75) (end 3.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3087bcc5-0750-4887-bb27-bea5b09094bc))
(fp_rect (start 2.75 -5.75) (end 3.25 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 31478265-5f49-43ba-8cee-74ecb351bb43))
(fp_rect (start -7.25 6.75) (end -6.75 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 31b7ed19-462a-49cf-9480-c278cc306810))
(fp_rect (start 4.75 6.25) (end 5.25 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 31f84391-3c0b-46dd-90c2-f11faa8a520f))
(fp_rect (start -1.25 -3.25) (end -0.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 328c24be-d163-4aec-a236-78393f2e54bb))
(fp_rect (start -6.75 3.25) (end -6.25 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3434ab49-e488-46d3-9605-a2fdeab6208d))
(fp_rect (start -3.25 7.75) (end -2.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 357177fe-feb4-49f6-823f-6c20d5fe75b6))
(fp_rect (start -1.75 -2.75) (end -1.25 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 35b4a5da-15d3-4e3b-b0e6-4d21e026cb7d))
(fp_rect (start 3.75 -1.75) (end 4.25 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 372f4e64-1312-44d1-b652-57a936ab6227))
(fp_rect (start -3.75 2.25) (end -3.25 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 38086dd8-87f9-4d72-9116-fdece54eb902))
(fp_rect (start -5.75 2.25) (end -5.25 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 38189b8f-087b-42be-bc88-6f9f93a2632e))
(fp_rect (start -2.75 4.75) (end -2.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 38a6aefd-899c-413f-bc11-50406d4eb787))
(fp_rect (start 1.25 6.25) (end 1.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 38ee5968-a95e-4bbd-b213-83a785b233c0))
(fp_rect (start 1.75 7.75) (end 2.25 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 38f45f67-7617-4550-8e8e-c3e8cc8d5110))
(fp_rect (start 2.75 -4.25) (end 3.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 38fd943d-541c-4807-9958-156d2c659e87))
(fp_rect (start -3.25 -5.75) (end -2.75 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 39100e97-9d8b-47d0-aae1-249700bfe8c0))
(fp_rect (start -1.25 4.25) (end -0.75 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3a3a302b-4fb6-410d-99e0-716d977c2a71))
(fp_rect (start 4.25 -0.75) (end 4.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3abaa1f3-9fab-41ea-9336-1de06b2a7846))
(fp_rect (start -8.25 -0.75) (end -7.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3b97bb8d-ff99-479c-aa11-a860b3161084))
(fp_rect (start 1.25 -7.75) (end 1.75 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3c2669db-7e9c-4a59-94f0-b77c25e717df))
(fp_rect (start -3.75 -8.25) (end -3.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3d04ba63-a5eb-4851-a130-d1f1dfa7b424))
(fp_rect (start -6.25 -6.25) (end -5.75 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3e3f18b7-11d7-43d1-9c04-fbb143c13833))
(fp_rect (start 3.25 -1.25) (end 3.75 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3f445c2e-caed-4c90-bea4-fb1f0b34ec28))
(fp_rect (start 0.75 -5.25) (end 1.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3f58726d-ed05-4af8-a181-7517e982ead1))
(fp_rect (start 3.75 3.75) (end 4.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 3f716f92-9629-43b1-b099-b46a59fb1709))
(fp_rect (start 6.25 -3.25) (end 6.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 40719ab3-e87a-457e-b382-93d56f1856bc))
(fp_rect (start 4.25 -3.75) (end 4.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 40942c95-2d18-4545-9fba-f454cca55037))
(fp_rect (start 6.25 5.75) (end 6.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 40f38f28-a996-4f9e-a44d-f1be5ef65ce0))
(fp_rect (start 4.25 -1.75) (end 4.75 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 41ea8ad6-fd61-40b5-8122-7f374fb3550e))
(fp_rect (start 4.25 2.25) (end 4.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 424c5b64-856c-4ab2-8511-cecdd878484a))
(fp_rect (start 7.25 4.25) (end 7.75 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 427845b8-62f6-47ed-bee3-c85ebcb2a449))
(fp_rect (start 3.75 -0.25) (end 4.25 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 431db9ab-e851-4eb3-9153-92a05f8a6fb7))
(fp_rect (start 1.25 -6.25) (end 1.75 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 43ec6ca7-2ff1-4250-8ce8-efc0d1398e5e))
(fp_rect (start 0.75 -1.25) (end 1.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 45edf1de-6d1c-46c9-93ba-1779adfe2812))
(fp_rect (start 6.75 2.25) (end 7.25 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4608e1d9-c3d6-438b-8e69-3452d3419604))
(fp_rect (start 7.75 -7.75) (end 8.25 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 464c294b-1d61-4e30-8c72-d5d85aa9a0bb))
(fp_rect (start 5.25 -4.25) (end 5.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 46d5266a-c779-4c40-a6e1-db23ff1a44ab))
(fp_rect (start -6.75 -6.25) (end -6.25 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4789bd56-3d89-4ccb-9086-58c3a30bae02))
(fp_rect (start 1.25 3.25) (end 1.75 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4842b9d5-01f0-46b5-8f2a-7b5d685d414f))
(fp_rect (start -6.25 4.75) (end -5.75 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 48e75e94-9fc3-437b-be79-834f94444c56))
(fp_rect (start -0.25 0.75) (end 0.25 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4b5df782-6243-4126-b89a-e0065c2e2b91))
(fp_rect (start -4.75 -1.75) (end -4.25 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4ba9be4e-408b-45bf-b78c-6a4eea47985f))
(fp_rect (start -1.75 -8.25) (end -1.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4c166662-8648-4792-a54c-8750a7b387b8))
(fp_rect (start -6.75 -7.25) (end -6.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4cde5d1f-bab2-409c-9c81-2b4b236116d9))
(fp_rect (start -2.75 7.25) (end -2.25 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4cde73b6-d734-49d9-a9ba-d53cddf895ff))
(fp_rect (start -0.75 -4.25) (end -0.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4d667e54-e760-4a8a-a090-680a0bc5aaa4))
(fp_rect (start 7.25 -1.25) (end 7.75 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4e078c7b-e994-4321-8a3f-bcde7f824026))
(fp_rect (start -4.25 -1.75) (end -3.75 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4eb8d5b6-f731-4d24-be06-aa78f02f92b9))
(fp_rect (start 3.25 6.25) (end 3.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4ef00b21-5885-4e3b-92fc-546611890d19))
(fp_rect (start -0.75 3.75) (end -0.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 4fa4fc1a-f707-40d8-b894-2950ff81d4fc))
(fp_rect (start 4.25 -4.25) (end 4.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5022cbb0-63b1-4830-af5a-94ed41e1e25f))
(fp_rect (start -8.25 0.75) (end -7.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 504c8cec-e651-46cd-b180-44b27efdb21e))
(fp_rect (start 1.75 0.75) (end 2.25 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5075a09a-6136-4717-914f-d7123e330815))
(fp_rect (start -0.75 -3.75) (end -0.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 51f86caa-cd88-41aa-b238-74d575381e8f))
(fp_rect (start -0.75 4.75) (end -0.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 52311b86-4b5c-4fbf-8447-0d8a9e9ed54a))
(fp_rect (start 0.75 -4.75) (end 1.25 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 53627789-9fc2-49d9-accd-4adfc3b92df0))
(fp_rect (start 2.75 3.75) (end 3.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 537bfdd8-aab4-4565-9419-99180634cfd3))
(fp_rect (start 3.25 -2.25) (end 3.75 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 53d33ae5-d86f-48dc-abe1-9a8fe68fc09e))
(fp_rect (start 6.25 -5.25) (end 6.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 549337b4-c0ac-4335-81db-edbe940398e8))
(fp_rect (start 2.75 7.75) (end 3.25 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5538e2dc-9708-4fac-b5f4-a376564252dd))
(fp_rect (start -7.25 -5.25) (end -6.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 569c136e-7e55-46e1-9d8b-d448dfbf5b50))
(fp_rect (start -8.25 7.75) (end -7.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 56fac4f0-7f0b-44cf-afec-1df5c9110dd0))
(fp_rect (start -5.25 6.25) (end -4.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5717359b-7cb5-4db6-9055-ce231432fbd9))
(fp_rect (start -4.75 0.75) (end -4.25 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 581e5534-1b62-4b22-b751-8332e456486a))
(fp_rect (start 2.75 -5.25) (end 3.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 583e26d5-9014-483c-8514-fd10636a43bf))
(fp_rect (start -1.25 -5.75) (end -0.75 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 585b4b72-6963-45ca-92b7-a36e06d857b9))
(fp_rect (start -3.25 5.75) (end -2.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 59048b34-757a-4374-a746-e8990a9b7869))
(fp_rect (start 4.25 -3.25) (end 4.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5a973761-667e-448d-a05b-9ef570956fda))
(fp_rect (start -3.75 -1.25) (end -3.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5ad7d6d8-6d6a-4e83-bf6e-7d09c234ca87))
(fp_rect (start 1.75 5.25) (end 2.25 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5b531049-744a-44e3-a9bb-08cb6b54f2b9))
(fp_rect (start 0.25 -7.25) (end 0.75 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5ba4cb5f-3237-4306-a1f8-c480ba26f98d))
(fp_rect (start 7.25 -2.75) (end 7.75 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5bcd8175-7f84-42e8-bc8f-9ffa177d364b))
(fp_rect (start -7.25 -0.25) (end -6.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5bd85188-3595-4402-9673-d201ec139bdf))
(fp_rect (start 0.25 3.25) (end 0.75 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5bf4fbc1-97e6-4c12-a6e9-f5d8b8bf4138))
(fp_rect (start 3.25 3.75) (end 3.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5c30e00e-9339-4065-9934-e4cabfe4347a))
(fp_rect (start -8.25 6.75) (end -7.75 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5c72944b-f75f-462c-8278-56341964777d))
(fp_rect (start -4.75 -0.75) (end -4.25 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5c7324ad-f160-48eb-9c88-3e90478d5cae))
(fp_rect (start -3.25 -3.25) (end -2.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5cc7488e-903d-4ef1-ab57-8d4896d988ee))
(fp_rect (start 3.75 -4.25) (end 4.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5d4d4883-39ef-43b5-b67d-8da0b1aa0f40))
(fp_rect (start 4.75 -1.25) (end 5.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5d50c417-5126-4eca-96b4-7e60eeaee187))
(fp_rect (start -0.75 1.75) (end -0.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5dade18a-9710-46d8-a87e-d8d327bb80ec))
(fp_rect (start 7.75 -8.25) (end 8.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5ddde671-5b2f-43a4-a7e3-33c15ea02831))
(fp_rect (start -5.25 -6.75) (end -4.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5e3210a3-828a-406d-ac0a-1d8d9cc8b1aa))
(fp_rect (start 4.75 -4.25) (end 5.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5ef87385-7fce-4b26-ab3a-de60e5351105))
(fp_rect (start -3.25 -2.75) (end -2.75 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 5fab284c-a8f6-49ba-a3e9-510887220bdb))
(fp_rect (start 0.75 -3.75) (end 1.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6103233b-b3cb-4106-9367-e6a0e4f877bc))
(fp_rect (start -7.75 -5.25) (end -7.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 61ac6e3c-761a-4f9b-aa3a-d27d072f07da))
(fp_rect (start -1.75 4.25) (end -1.25 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6229c8b5-ee03-4943-929b-9995766cd9e5))
(fp_rect (start 5.75 -4.25) (end 6.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 624b869b-0154-42d4-bbfd-413cb6bffe4c))
(fp_rect (start -2.25 -0.25) (end -1.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6299deea-a17f-411b-8628-d16c3430f5e5))
(fp_rect (start -3.25 -7.75) (end -2.75 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 62cd706d-2f0a-49b3-840c-935f16270208))
(fp_rect (start -2.75 -7.25) (end -2.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6309e3a3-d166-431d-9fc7-230207c7c8a1))
(fp_rect (start 3.75 4.75) (end 4.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 63c65c51-8914-4761-9fe8-e581e43280da))
(fp_rect (start 7.75 -5.25) (end 8.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 641347cc-d6d1-45ce-be47-5b59389ecb51))
(fp_rect (start 0.25 -6.75) (end 0.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 645e0993-11bb-4a94-8312-efc204133ffd))
(fp_rect (start -8.25 -3.25) (end -7.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 64e65a31-c790-4392-891d-14ee415f0f5f))
(fp_rect (start -4.25 -6.75) (end -3.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 658069ae-f13a-42c3-a8c0-127864644339))
(fp_rect (start 1.75 1.75) (end 2.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6753de14-e035-4ad1-a6e8-8e5499f8633c))
(fp_rect (start -3.75 4.25) (end -3.25 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6761c3a8-898f-4e69-ba85-2748645964b8))
(fp_rect (start 0.25 -6.25) (end 0.75 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6792ad4a-7848-470d-940e-ee3a73ff45a8))
(fp_rect (start 4.25 5.75) (end 4.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 67df5d10-8bab-4052-88a7-7073eaeb725d))
(fp_rect (start -5.75 7.75) (end -5.25 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 69d8761e-5a33-44ac-b908-7b0307d00839))
(fp_rect (start -0.75 6.75) (end -0.25 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6a69b367-7f3f-4810-8832-fcf4062331d4))
(fp_rect (start -6.25 -3.75) (end -5.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6abc7a40-1af8-465d-8938-15929b818f51))
(fp_rect (start -2.25 0.75) (end -1.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6ac5f1da-4b9c-49dc-a47a-19efecb207f3))
(fp_rect (start -7.25 6.25) (end -6.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6bd16a1f-2708-4567-9040-3c72a041236d))
(fp_rect (start 3.75 0.25) (end 4.25 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6bf1812d-ad50-4d26-bc44-e22ca96f8951))
(fp_rect (start 2.25 1.25) (end 2.75 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6c069b10-5794-46f6-b7fd-417d447edc39))
(fp_rect (start -1.75 6.25) (end -1.25 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6c6377d6-1b62-41b9-8820-5d644c224adc))
(fp_rect (start 3.25 -0.75) (end 3.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6cbd4c35-0a08-40d6-ace4-e55606c2b542))
(fp_rect (start 2.75 -2.25) (end 3.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6cc46eed-f134-4424-9a79-841d5b7d638d))
(fp_rect (start -0.25 -3.25) (end 0.25 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6d166bb5-9ae1-41cf-875c-a789850910af))
(fp_rect (start -2.75 3.25) (end -2.25 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6d4489f4-ac83-460e-92dc-cbf640d136a6))
(fp_rect (start 2.75 -0.25) (end 3.25 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6da13831-9b78-42e6-869e-5a72f02f8190))
(fp_rect (start 7.75 -6.25) (end 8.25 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6e58d63f-1786-463e-b899-5c7665f9efe3))
(fp_rect (start -8.25 -8.25) (end -7.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6f333460-8c3c-4098-a256-9680723eee5e))
(fp_rect (start -7.25 -0.75) (end -6.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6f5a240a-8a2b-4b60-891e-24e7f9be3a1c))
(fp_rect (start -4.75 -2.75) (end -4.25 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6f9787f0-4837-497a-b9e4-bd8d3fd29972))
(fp_rect (start 0.75 7.75) (end 1.25 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 6ff42d61-416e-4386-b13d-97df4e7ed845))
(fp_rect (start -5.25 1.75) (end -4.75 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 70045c0a-b1ae-4767-9206-84a5f06f9113))
(fp_rect (start 6.75 6.25) (end 7.25 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 70dca59c-6bad-4073-a56b-029221dcfbe2))
(fp_rect (start 0.75 0.25) (end 1.25 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 71283231-bfd7-451e-bc03-9cf8c3733b8a))
(fp_rect (start 4.25 3.75) (end 4.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 716c0626-4796-466f-9630-b47fc8ce9d0b))
(fp_rect (start 2.25 -3.75) (end 2.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 72b7aef7-2d76-4cf7-9e15-47f82a2b2892))
(fp_rect (start -0.25 -3.75) (end 0.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 73275965-8070-4cca-939d-dc112b2f0341))
(fp_rect (start -0.75 -3.25) (end -0.25 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 74370960-5199-4098-a545-d2c8c7ea1d7b))
(fp_rect (start -3.75 0.75) (end -3.25 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 75025b7f-3cde-49cf-a730-309990611ecc))
(fp_rect (start 3.75 -4.75) (end 4.25 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 750391d2-c18b-44f1-98a1-e9871ef52ca5))
(fp_rect (start -4.75 -3.75) (end -4.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7504e80a-8b24-4e8d-8ce1-9f5dd6761105))
(fp_rect (start -7.75 0.25) (end -7.25 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 758efe82-eeb5-435f-ab0d-5dad146a6cc3))
(fp_rect (start -7.25 0.75) (end -6.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 75b90ed2-8ec1-41ad-ac00-669db66fccda))
(fp_rect (start -2.25 1.25) (end -1.75 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 75dd610c-95d7-41b8-a062-4ac8a5af3458))
(fp_rect (start -0.75 1.25) (end -0.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7613a08e-587a-4048-806b-46562fe43449))
(fp_rect (start -7.75 4.75) (end -7.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 76db87d3-9667-4c6b-a276-35bfe3994f9d))
(fp_rect (start -0.25 -8.25) (end 0.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 77e14af0-40f8-4679-8a30-27fdbab3b747))
(fp_rect (start -8.25 1.75) (end -7.75 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 77f76170-3e48-47fa-86eb-15fcbca9d95c))
(fp_rect (start 3.75 1.25) (end 4.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 781bc047-a326-491a-ac49-2e1ff2477d84))
(fp_rect (start 7.25 2.75) (end 7.75 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 781df42c-c737-47b0-8778-582fea5a4e33))
(fp_rect (start 0.75 -8.25) (end 1.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 78a43262-0f16-48b1-bd0c-439ae2075766))
(fp_rect (start -6.75 1.25) (end -6.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 79034721-68d8-4eed-9e4d-d06f7eb70910))
(fp_rect (start -8.25 1.25) (end -7.75 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 792c41e0-149d-4994-996c-58dd3b9f3d89))
(fp_rect (start -4.75 -1.25) (end -4.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 793c4d42-4b31-4058-bc60-1ab93c64e026))
(fp_rect (start 7.75 -4.25) (end 8.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 79e8cdfb-c9f4-499c-be66-305c51b53f84))
(fp_rect (start -4.75 -2.25) (end -4.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7a0cf2c3-d604-455b-ad89-f2866c0ff9ed))
(fp_rect (start 4.25 2.75) (end 4.75 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7abd1b9c-3baf-4294-9e81-877175d8100f))
(fp_rect (start 6.25 -1.25) (end 6.75 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7b2ac6aa-024c-4c1f-b57a-74263014a59f))
(fp_rect (start 5.75 2.75) (end 6.25 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7b3d57fb-2bb5-4d6d-8e85-420fbee4e91a))
(fp_rect (start -7.25 -6.25) (end -6.75 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7c49f7eb-41fe-4fe1-8f95-acacb61095ec))
(fp_rect (start -0.25 -5.25) (end 0.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7c92f8d1-8c16-4688-b8ab-31ae98339ab5))
(fp_rect (start -3.25 -0.75) (end -2.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7d196a9c-bb02-4ae7-bf2d-5f69a1608a6b))
(fp_rect (start -1.25 -8.25) (end -0.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7d426812-33ea-4551-9451-aa681f6f0198))
(fp_rect (start -5.75 -1.75) (end -5.25 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7d63e89a-e055-4b17-a8dd-592c154ce2c3))
(fp_rect (start 4.75 6.75) (end 5.25 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7de61f70-cdf1-4162-ae46-7ff0878c51ea))
(fp_rect (start -6.25 -6.75) (end -5.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7e74730a-e9f3-4b45-9615-11cca9c3dd83))
(fp_rect (start -4.25 2.25) (end -3.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7eb9405d-bcc0-4a5c-bcf7-aa1ab27ffb35))
(fp_rect (start -7.75 -8.25) (end -7.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7f58b2f5-e8dd-4bb5-a288-0e2cb241eeac))
(fp_rect (start -6.75 1.75) (end -6.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7f6463a0-0d32-4846-81ac-d87a8cd2ef0b))
(fp_rect (start 4.75 -5.25) (end 5.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7f950b85-41b6-4b99-9551-203930d143dc))
(fp_rect (start 5.75 -2.25) (end 6.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 7f96049e-cfc6-45c1-85ff-8f9ef67d166b))
(fp_rect (start -0.25 1.25) (end 0.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 804adc9b-5695-45ac-a019-61e905dbc46a))
(fp_rect (start 3.75 -2.75) (end 4.25 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 806efc17-27e5-4fdc-96e8-3b79466cec2e))
(fp_rect (start -2.25 3.25) (end -1.75 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 808115cf-2c3d-44bb-bf89-156a70f339c6))
(fp_rect (start -1.25 -7.25) (end -0.75 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 80f72bff-e771-4522-8ce6-146cd9112b50))
(fp_rect (start 4.25 -2.25) (end 4.75 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 812e185d-bf33-4406-ae6e-d3e5844527ed))
(fp_rect (start 3.25 -8.25) (end 3.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 81aaa8c8-b715-437f-9424-3eff60e883d2))
(fp_rect (start -6.25 -0.25) (end -5.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 82a70869-da90-4001-a856-3e2307d74a69))
(fp_rect (start -4.25 -5.25) (end -3.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 82ce5fc9-d8a6-44a7-94b9-8a433125689b))
(fp_rect (start -5.75 -2.75) (end -5.25 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8301ac5b-acc3-4ef4-b3e9-87fde72337f8))
(fp_rect (start 6.25 4.75) (end 6.75 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 85fad492-5d83-4d98-bf01-67c80c8f6839))
(fp_rect (start 4.75 5.75) (end 5.25 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 860e52e2-1f53-4b8c-bf23-3b54c7f80e5a))
(fp_rect (start -5.25 0.75) (end -4.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 863d57d8-9a28-4483-861c-688d958c6827))
(fp_rect (start -3.25 4.75) (end -2.75 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 863f29a1-bd62-4062-84e4-0778d1f3ab2b))
(fp_rect (start 3.75 -1.25) (end 4.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8727edf8-d2cb-4edb-8036-5908d696c09b))
(fp_rect (start 0.25 6.25) (end 0.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 88b4c4fa-3298-4b39-ab60-920f9599e2f2))
(fp_rect (start -5.75 -1.25) (end -5.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 89307f4f-c7d0-4f80-86ac-222e338133a5))
(fp_rect (start -3.25 -5.25) (end -2.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 898a9f03-f050-4c3d-bd1d-fd9a417a17f7))
(fp_rect (start -4.25 -5.75) (end -3.75 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 89d864f5-21a8-4647-897b-a98aa9112171))
(fp_rect (start 5.25 6.25) (end 5.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8a50fb45-e7df-4415-b255-0d63fe6dc608))
(fp_rect (start 0.25 -0.75) (end 0.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8a6698c1-85aa-4c42-a3c2-4becbba76a57))
(fp_rect (start -2.75 -8.25) (end -2.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8bab38b8-5978-4b21-8027-a98b65678911))
(fp_rect (start 1.25 -7.25) (end 1.75 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8c1c3c38-c240-4cf1-a59b-0b274117a1b0))
(fp_rect (start 5.25 0.75) (end 5.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8c2dafdb-f11d-4763-abba-65e93d398cca))
(fp_rect (start -7.75 1.25) (end -7.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8c7506a4-774d-4d02-a4c6-4a0021f11fe2))
(fp_rect (start 0.25 7.75) (end 0.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8c9a631e-24a2-4bcd-89fd-f68404375864))
(fp_rect (start -8.25 4.75) (end -7.75 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8cbaa61a-6a27-4b4b-a591-8622cf4c3317))
(fp_rect (start 4.25 3.25) (end 4.75 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8d342013-1edc-4ed2-936c-f9e00fa42914))
(fp_rect (start -1.25 7.25) (end -0.75 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8da3d032-35e5-411b-a898-d0bbc601b014))
(fp_rect (start -7.75 -2.75) (end -7.25 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8dc33c61-8d71-44b3-bcb5-7f4f8b5c7713))
(fp_rect (start -4.25 -8.25) (end -3.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8df53e06-873c-48d5-acb2-1da90266a540))
(fp_rect (start 0.75 4.25) (end 1.25 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8e56aaf9-f4d6-419f-8673-f1fb4702a61f))
(fp_rect (start -8.25 2.25) (end -7.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8e7bc127-e634-48c1-a737-344872642300))
(fp_rect (start -1.75 1.75) (end -1.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8ef5fc10-7bb8-4205-80c0-d9b28da284fd))
(fp_rect (start 4.75 -3.25) (end 5.25 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8f962ec2-549f-4e58-bd4b-7011abf36ae3))
(fp_rect (start -2.25 -6.75) (end -1.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8fe10793-e295-41fc-a4e9-f05f3338b2c6))
(fp_rect (start 1.75 -2.75) (end 2.25 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 8fed0211-77de-4ec1-9b9a-87c1a5a707ae))
(fp_rect (start -8.25 5.25) (end -7.75 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9072ca32-4e7c-47c5-8d48-0f1205ac56ff))
(fp_rect (start -2.75 -1.25) (end -2.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 90ebf125-7efd-4db7-b2dd-78754bd3d4c4))
(fp_rect (start 0.25 3.75) (end 0.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 91586436-e4dc-4481-a9a0-dc784ad73e93))
(fp_rect (start 1.25 2.25) (end 1.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 91904bf6-316a-4901-accf-2b5835ddaf77))
(fp_rect (start -1.25 -0.25) (end -0.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 92177e60-575c-4093-bb56-0bc1b5070e2f))
(fp_rect (start -0.75 5.75) (end -0.25 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 92ef4f66-a67c-4f43-9a6d-54e1590fe91e))
(fp_rect (start -4.25 -4.75) (end -3.75 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 94704d8d-de6f-4668-aa29-14533b0459b3))
(fp_rect (start -3.25 -4.75) (end -2.75 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 94c1bdb6-317a-47d2-9f0f-b2c89b2fc8d1))
(fp_rect (start 1.25 -0.25) (end 1.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 94f8b0ab-db52-47f1-808a-0e3c310de766))
(fp_rect (start -0.25 -6.25) (end 0.25 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 94fed5ed-d811-42f5-850d-157fa8a31c30))
(fp_rect (start -6.25 -2.75) (end -5.75 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 95519427-86d7-4379-81f6-9db8706ef208))
(fp_rect (start 2.25 2.25) (end 2.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 95aa7814-1ef1-444f-8eca-dcd27c90c673))
(fp_rect (start 7.25 6.25) (end 7.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 95d5091c-d096-4a02-8587-022782004379))
(fp_rect (start 0.25 7.25) (end 0.75 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 95d5f5e0-b46a-47cc-92a0-0800b72fc708))
(fp_rect (start -6.25 5.75) (end -5.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 96b90eba-cba0-47a0-8866-70a1ece5ec89))
(fp_rect (start 2.25 -4.75) (end 2.75 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 97406407-cc91-431b-96f4-80f619b7d991))
(fp_rect (start 0.75 1.75) (end 1.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 977bb938-ad3c-453a-abac-a51de1458656))
(fp_rect (start -3.75 -6.75) (end -3.25 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 978a655d-af9a-4c18-b523-e94c2a5761f6))
(fp_rect (start 0.25 -4.25) (end 0.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9795c370-8a31-415a-aff3-b09762b0762b))
(fp_rect (start -2.25 -4.25) (end -1.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 97ad21c3-7352-4226-bf79-f2b43daa27ce))
(fp_rect (start 3.25 1.25) (end 3.75 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 97cab4ec-cc95-4089-956d-87955109eb27))
(fp_rect (start 1.75 3.75) (end 2.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 981651a7-c01e-46e7-ab38-335502dfb891))
(fp_rect (start -5.25 3.75) (end -4.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9845ca06-30b9-4e4c-a9f1-4ee30b1b2fc4))
(fp_rect (start -1.75 7.25) (end -1.25 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9859e2c7-5641-4a6b-b1e4-337558826c74))
(fp_rect (start -2.75 2.75) (end -2.25 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9906dc8a-84f1-4c20-9232-367e9d08bebc))
(fp_rect (start 2.75 -0.75) (end 3.25 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 99493975-ea43-4952-b184-25b1d6e356a8))
(fp_rect (start 0.75 2.75) (end 1.25 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9960b11c-67d5-4708-a051-f689e01e581f))
(fp_rect (start -7.75 2.25) (end -7.25 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 997aa5df-6915-4ea2-97e6-cc7189a5db58))
(fp_rect (start -1.25 0.75) (end -0.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9a9fbbf1-26b1-4817-a2f6-ea67c6982c00))
(fp_rect (start 2.25 7.75) (end 2.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9b760fb4-bff4-4e16-a265-8aba12ef407e))
(fp_rect (start 2.75 5.25) (end 3.25 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9db22f4e-76af-4289-ad92-18f6a1f1b2d3))
(fp_rect (start 1.25 -6.75) (end 1.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9dcf91be-6b06-4988-a5db-ff641f2f0bd3))
(fp_rect (start 0.25 4.25) (end 0.75 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9e0db68b-3504-42cf-ad94-b41264ffd276))
(fp_rect (start -6.25 -7.25) (end -5.75 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp 9ed0e226-c0be-4b62-885c-0aa2ef066257))
(fp_rect (start 3.25 0.75) (end 3.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp a01941a5-0765-4a8b-aa1e-0006048c76cd))
(fp_rect (start -0.75 0.25) (end -0.25 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp a06ddd9a-df75-4c91-9b0e-a67d9e505106))
(fp_rect (start -3.75 5.25) (end -3.25 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp a170f2e0-bf50-45d2-b269-a81a048c3c39))
(fp_rect (start 7.25 2.25) (end 7.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp a38d42dd-41cc-4aee-89e0-32211aa48748))
(fp_rect (start -2.25 2.75) (end -1.75 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp a3d0823f-ee44-496b-b255-c4398b1077a6))
(fp_rect (start -7.25 4.75) (end -6.75 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp a4295caa-be53-459c-8dc9-e0121dec7f4e))
(fp_rect (start 5.75 5.25) (end 6.25 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp a438492d-95c7-44d7-8e57-770179b34509))
(fp_rect (start -4.25 -3.75) (end -3.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp a43ecf55-b0a6-4f4e-b0ab-e309e3ef03db))
(fp_rect (start -1.25 4.75) (end -0.75 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp a45b374d-2cc1-4fdf-99ee-a7eb0ea5201a))
(fp_rect (start 0.25 1.25) (end 0.75 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp a53214a4-8455-404d-bf78-4bfa0f9a2373))
(fp_rect (start 1.75 -7.75) (end 2.25 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp a5e4975f-0105-46be-9259-8828614b67f9))
(fp_rect (start -6.25 7.75) (end -5.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp a6eed99b-9bd9-4fbd-9727-f3041df468a8))
(fp_rect (start 6.75 6.75) (end 7.25 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp a6fdd408-1371-4d68-83af-3beede888ffe))
(fp_rect (start 3.25 -4.25) (end 3.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp a74b628a-534d-4cad-b02a-f81f8354013e))
(fp_rect (start 2.75 5.75) (end 3.25 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp a8ec1b19-0d26-426d-85e4-d0b100d663ec))
(fp_rect (start 5.25 -5.25) (end 5.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp a97a012c-6d7b-486a-a0fd-33de3ecf2767))
(fp_rect (start -1.75 2.75) (end -1.25 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp aa3c9971-edda-47e1-8196-10acd23f6cfc))
(fp_rect (start 1.25 7.75) (end 1.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp aa538663-df9c-4511-9c0d-624110e4617b))
(fp_rect (start 7.25 -8.25) (end 7.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp aa6db01e-d267-4afa-a9ea-98293af89fbd))
(fp_rect (start -8.25 -7.25) (end -7.75 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp ac312b44-343d-4d30-839a-5bcbacae5b73))
(fp_rect (start 7.75 5.25) (end 8.25 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp ad954e65-aaca-4b80-80c3-ef0e215d2780))
(fp_rect (start 7.25 -3.25) (end 7.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp ae63e7e2-15d4-4d29-b1df-c16ee9635820))
(fp_rect (start -5.75 1.75) (end -5.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp aec95684-8999-4838-a7c3-aa4fd568d99a))
(fp_rect (start 1.75 -1.25) (end 2.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp afad10f6-daec-46ea-88b3-a60206ee8f56))
(fp_rect (start 5.25 3.25) (end 5.75 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b06b0c7e-6c88-4778-bbc6-4e2aea6cc37b))
(fp_rect (start 4.75 4.75) (end 5.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b06b42ba-6ad6-4197-9312-2a8d9e456896))
(fp_rect (start -3.25 0.75) (end -2.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b07b25d4-82b6-4544-bbdb-84cc03df99fd))
(fp_rect (start -0.75 4.25) (end -0.25 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b0b20308-d86a-422c-b970-404adf573ff3))
(fp_rect (start 6.75 -8.25) (end 7.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b0da6e55-e61d-48af-8329-4265b4bb9f07))
(fp_rect (start 5.75 6.25) (end 6.25 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b0e2a9c2-3f67-4f98-b96a-64f778fe2ade))
(fp_rect (start -6.75 -0.75) (end -6.25 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b118337e-1ece-446c-8051-b5123e324f97))
(fp_rect (start -8.25 -5.25) (end -7.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b1827de5-43ef-48e4-a235-64a1cec9c511))
(fp_rect (start 4.75 -0.25) (end 5.25 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b1a488a5-4666-4b61-8c74-35ca5afcff3c))
(fp_rect (start 3.75 3.25) (end 4.25 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b1ae15e3-ff51-4091-b899-a9d01d49b5c7))
(fp_rect (start 0.75 1.25) (end 1.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b1bdc5e5-7f42-4e4b-9edf-fa883f2e6c1b))
(fp_rect (start 2.25 -4.25) (end 2.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b1e93d61-5b19-4869-aa82-da8ded0f1028))
(fp_rect (start -1.75 -5.75) (end -1.25 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b2c14216-79e6-42fc-a7fd-7808a9741898))
(fp_rect (start 4.75 3.25) (end 5.25 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b37dbc27-1232-4e87-8ed0-fb2f8ab49d7f))
(fp_rect (start 6.75 0.25) (end 7.25 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b403b4b6-a597-43a4-8220-f1ae7532bff7))
(fp_rect (start -2.25 -1.75) (end -1.75 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b4454f12-81b7-46df-9674-f9641eb0ce05))
(fp_rect (start -2.75 -6.75) (end -2.25 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b47629bf-3660-48d1-bf84-96a9c3ac707f))
(fp_rect (start -4.75 1.75) (end -4.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b4a8ce75-e94e-49ea-b091-a246d37c0d1b))
(fp_rect (start 1.75 -4.25) (end 2.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b4defb14-c623-4bd7-9bd6-fe161e8648c5))
(fp_rect (start -6.25 -2.25) (end -5.75 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b593590d-f257-4635-aaa6-7aba911ff060))
(fp_rect (start -1.25 5.75) (end -0.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b5e5e1ad-9b25-44c9-bace-70faad62ffc0))
(fp_rect (start -6.75 -6.75) (end -6.25 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b5ea7cfc-aca7-44bb-8970-e30ec0e218cc))
(fp_rect (start 2.25 0.75) (end 2.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b6e7c1fa-2098-42a3-96ac-81a49241c233))
(fp_rect (start 0.25 -0.25) (end 0.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b7fa8853-e2ce-433b-8483-dddb91b885d1))
(fp_rect (start -2.75 5.25) (end -2.25 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b8383087-442e-401e-ae46-3c56ee805f14))
(fp_rect (start -2.75 6.75) (end -2.25 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp b8387439-5e1d-4d28-a6cb-0815fc319fb0))
(fp_rect (start -3.75 1.25) (end -3.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp b8bdf770-e10b-4f82-bd42-1bc212ee3c93))
(fp_rect (start -6.75 5.75) (end -6.25 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bae903dd-3666-47c9-99a1-6b1ef68ff86f))
(fp_rect (start 3.25 -3.25) (end 3.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp bb405eaf-1ce9-4177-aff3-b9879fd189f0))
(fp_rect (start 7.75 1.75) (end 8.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bc3d777f-8399-440c-8e10-00694ab26210))
(fp_rect (start -0.25 5.75) (end 0.25 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bc6167c1-15d2-4a56-8711-4a601d3e38e5))
(fp_rect (start -7.25 -6.75) (end -6.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bcbcad00-018d-4666-81b3-e21ddf36f661))
(fp_rect (start -4.25 -3.25) (end -3.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp bd0e3490-c4f4-4abf-9b6e-57721abcdf6f))
(fp_rect (start -5.75 4.75) (end -5.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bd1aa673-2952-4a97-a9d9-4b5b108a5b0f))
(fp_rect (start -3.25 -6.25) (end -2.75 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp bd7bf159-fd0e-44d7-bb42-62093fedbbf6))
(fp_rect (start -0.75 -0.75) (end -0.25 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bda4e16b-9ded-4b60-a2f3-a01e2b06f5cb))
(fp_rect (start -5.75 0.75) (end -5.25 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bdab0f8b-5faa-4138-8a2e-4250f8e5ccf5))
(fp_rect (start -5.75 -2.25) (end -5.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp bdeff5e6-9769-4ccb-96f4-3f500ad06b13))
(fp_rect (start 0.75 6.75) (end 1.25 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp beae6362-13a5-474b-b517-60766133cc6d))
(fp_rect (start 2.75 -2.75) (end 3.25 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bebaa194-8754-4cc1-86e0-4175b30cf2a4))
(fp_rect (start -0.25 0.25) (end 0.25 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp bf3850de-1b85-4bfc-a17f-94fc80a7e719))
(fp_rect (start -0.75 -1.25) (end -0.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp bf522abc-e59e-4969-a70a-2b777a902260))
(fp_rect (start 7.25 3.25) (end 7.75 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp bf5e9b31-07e4-4391-85f6-6bb9676d6e79))
(fp_rect (start 7.25 0.75) (end 7.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bf8fa3f1-7425-449a-96c7-ec965361dd2c))
(fp_rect (start -8.25 -5.75) (end -7.75 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp bff7117d-da01-40a3-adaf-9c988e479c57))
(fp_rect (start 1.75 1.25) (end 2.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c00be96d-d17c-4e2a-83f0-2c238ebbb4e5))
(fp_rect (start -1.75 4.75) (end -1.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c03a4e65-270d-4837-96f6-1030154faece))
(fp_rect (start -5.25 4.75) (end -4.75 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c09ddcc9-a56e-4a7a-9ab0-7f3331386d5c))
(fp_rect (start 5.25 6.75) (end 5.75 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c1180f84-6dec-48c2-bdb9-daef366883bb))
(fp_rect (start -6.75 2.25) (end -6.25 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c16fde56-7b53-4495-a456-b6731065921b))
(fp_rect (start 1.75 3.25) (end 2.25 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c1b8991e-0984-44c1-9957-1aa54e8a25c1))
(fp_rect (start 0.75 -7.75) (end 1.25 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c1dd8ea5-4f46-49a5-9369-3fa5dd0a2cd3))
(fp_rect (start 5.75 6.75) (end 6.25 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c1ee23a2-042e-4ee9-8ad8-c8f3cc0b664b))
(fp_rect (start -7.75 3.75) (end -7.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c2efa809-e985-421e-88a8-e3d10b4e4606))
(fp_rect (start 2.25 6.25) (end 2.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c3b21ec1-00e1-4857-8553-049ebbdc1712))
(fp_rect (start -7.25 -7.25) (end -6.75 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c3bedfe7-e1b3-4c31-9e2c-9d0b14bc7330))
(fp_rect (start 1.75 -5.25) (end 2.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c4104581-087e-4915-9836-e01e0eb9ac46))
(fp_rect (start -4.25 -4.25) (end -3.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c426504e-b324-495d-920d-3d1aea5e74a0))
(fp_rect (start -6.25 0.75) (end -5.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c5373df0-cad6-48e1-92ab-0d87667560bb))
(fp_rect (start -0.25 -2.25) (end 0.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c588cd62-c80a-419a-9396-3238a8efa8e9))
(fp_rect (start -0.75 -7.25) (end -0.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c5fa19c4-9da8-43b1-a92c-3364992e2bea))
(fp_rect (start -8.25 -6.75) (end -7.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c6648b65-3bd8-4b9f-a814-855a66fe4eab))
(fp_rect (start -4.25 -1.25) (end -3.75 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c72b1b8a-bbd7-4893-afd4-acc91cc3edc8))
(fp_rect (start -3.25 5.25) (end -2.75 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c7423721-c7a2-4005-ab25-695bf994131c))
(fp_rect (start -0.25 -7.75) (end 0.25 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c78d9dcb-eed0-44ba-b15e-e6524f2d94e2))
(fp_rect (start 3.75 4.25) (end 4.25 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c7d6e1ca-839e-454d-98be-21e1cb005e8b))
(fp_rect (start 7.25 0.25) (end 7.75 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c80fbbb8-09d2-4404-af5e-7d1c6ec11f8b))
(fp_rect (start 2.25 -7.25) (end 2.75 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c816cf76-aaf9-4833-b199-c6e74faeb047))
(fp_rect (start -7.25 3.75) (end -6.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c81b6a49-70d9-4b5a-a11d-eb6ec667f943))
(fp_rect (start 3.75 6.25) (end 4.25 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c8de6e91-7231-4bcc-9362-60f50c32a237))
(fp_rect (start -7.25 -8.25) (end -6.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c8e675f7-f579-480e-beec-f2c6e9c976c6))
(fp_rect (start 5.25 -1.75) (end 5.75 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c8f5bd6a-c673-4da5-8342-9e01920a2eb7))
(fp_rect (start -5.25 -7.75) (end -4.75 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c9b87070-0548-4b7f-abdf-5933b239bd45))
(fp_rect (start 7.25 4.75) (end 7.75 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp c9c18807-ffd9-4907-accc-83ae6b56f306))
(fp_rect (start 2.25 3.25) (end 2.75 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp c9d612a6-abc2-47e0-9933-80e9ce5bf2a8))
(fp_rect (start -3.25 -6.75) (end -2.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp ca387643-3400-46bf-9120-fa571d8af417))
(fp_rect (start 5.25 -1.25) (end 5.75 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp caa5c6d6-cf03-43ee-9517-0a8a9bc3b898))
(fp_rect (start 3.75 1.75) (end 4.25 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp cb2cf3e1-c7ea-45c0-b377-9ff4be4ce3df))
(fp_rect (start -8.25 -0.25) (end -7.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp cb713b57-c538-485f-8074-2b176117b361))
(fp_rect (start 1.75 -1.75) (end 2.25 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp cb776452-7942-4023-817b-8e1e92c801da))
(fp_rect (start 1.25 5.75) (end 1.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp cb841d40-61b2-4bbb-9aa9-d3c0ad74bdfb))
(fp_rect (start -0.25 2.75) (end 0.25 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp cb90b628-c637-49db-89ad-21c2b74de62e))
(fp_rect (start 0.75 7.25) (end 1.25 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp cbc7fba1-c5b5-4752-8c63-e2cc8523598e))
(fp_rect (start -0.75 -8.25) (end -0.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp cc520eb5-4e67-4b46-b29c-d16bf41fd164))
(fp_rect (start 0.25 -1.75) (end 0.75 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp cd74cee6-0d0d-4d6d-a903-beeb46943746))
(fp_rect (start -6.25 -1.75) (end -5.75 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp ce16ed26-baa6-449b-a952-4b76d2f19bbd))
(fp_rect (start -3.75 -7.25) (end -3.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp ce1774b6-74a4-4807-8a8d-f3f7e9cffbe1))
(fp_rect (start 6.25 -3.75) (end 6.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp ce610cd8-5136-410d-92ff-096ae2c9a3a8))
(fp_rect (start 2.25 3.75) (end 2.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp cea61a52-674d-4849-a781-a234d970aa61))
(fp_rect (start 1.25 1.25) (end 1.75 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp cfc7ebfc-264b-42b9-a168-cd11006351d0))
(fp_rect (start -5.75 -3.75) (end -5.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp cfe7f770-07c2-438c-ba3a-c3fad674f625))
(fp_rect (start -1.25 -7.75) (end -0.75 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d05ae25c-3fbe-42dd-b584-3640122228d7))
(fp_rect (start 6.75 4.25) (end 7.25 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d0a61f34-8522-463f-a5d3-128be0684382))
(fp_rect (start 4.75 -7.75) (end 5.25 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d0c04533-5679-4066-ab09-86204a6b7df3))
(fp_rect (start -0.25 2.25) (end 0.25 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d10cbf54-d85c-4d3a-9fc7-eb4c58d5899b))
(fp_rect (start -0.25 4.25) (end 0.25 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d116c193-d7ce-49db-aaa9-f0f91988eb49))
(fp_rect (start -5.25 -5.75) (end -4.75 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d120ae62-a108-466c-b9fd-7aef8cde0c9a))
(fp_rect (start 5.75 5.75) (end 6.25 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d172ff15-06f4-4472-a88d-6fd24dca3328))
(fp_rect (start -5.25 -3.25) (end -4.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d1bf903e-0aaa-4b3d-8abe-905776b09049))
(fp_rect (start -5.75 3.75) (end -5.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d1d4b91e-8b1f-484a-9411-966efd3e7435))
(fp_rect (start 6.75 -6.25) (end 7.25 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d1e377ec-41f0-4e13-bdf3-582ab00717c7))
(fp_rect (start 3.25 -5.75) (end 3.75 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d1e5675c-46f4-4698-a2b8-ec96e8dac78d))
(fp_rect (start -2.75 -4.25) (end -2.25 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d2480f23-cc3c-4d3f-918c-351b3846811f))
(fp_rect (start -7.25 2.75) (end -6.75 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d24cb340-c14f-4c6f-a49b-c8b6164c1650))
(fp_rect (start -0.75 -2.75) (end -0.25 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d27fd7f4-d272-453b-8f6b-c38ae274f697))
(fp_rect (start 5.75 4.25) (end 6.25 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d36c117f-faf8-4244-baf1-c3ef802e77c0))
(fp_rect (start 1.25 -2.75) (end 1.75 -2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d40adda3-9fa1-49b8-a11b-4856f7f44445))
(fp_rect (start 7.25 -2.25) (end 7.75 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d43fd3da-3d1f-4d52-9908-b66b7fccb97e))
(fp_rect (start -5.75 3.25) (end -5.25 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d4aa88ff-c21d-45ce-a5f8-6fd6cc572af3))
(fp_rect (start 0.75 -3.25) (end 1.25 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d58c7a65-b159-45f2-80f7-5e423717aa33))
(fp_rect (start 4.75 -6.25) (end 5.25 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d59a50d8-8ae2-46d6-8ea5-d638399cb5b1))
(fp_rect (start -8.25 -1.75) (end -7.75 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d61c7a2d-fbab-4d6e-8e27-d47463f1182e))
(fp_rect (start 2.75 -3.75) (end 3.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d6b8bf23-2e32-4dbc-ab40-9d07b7e5b23d))
(fp_rect (start -6.75 6.75) (end -6.25 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d6f128b4-d07b-4043-90fe-a5c388375e77))
(fp_rect (start 3.75 7.75) (end 4.25 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d76b79f1-6bb7-4a9b-9d97-ffd81b5c6300))
(fp_rect (start -6.75 -5.25) (end -6.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp d881244e-f0d9-48e2-98b6-1b31520fd8e3))
(fp_rect (start -4.25 7.75) (end -3.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp d9dc14df-f602-45c8-baee-18f338dde7b0))
(fp_rect (start -1.25 6.25) (end -0.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp da55f8b8-5f4b-4265-a0d8-b4c781fb6a7a))
(fp_rect (start 2.75 -8.25) (end 3.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp db0c505a-5fb0-4d8d-9141-387686733cbe))
(fp_rect (start -1.25 5.25) (end -0.75 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp db4eec97-a50a-4847-9e87-c1796050c32f))
(fp_rect (start 4.75 -0.75) (end 5.25 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp db66d670-69b7-404f-9541-b549dfae36ab))
(fp_rect (start 7.75 7.75) (end 8.25 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp dbaa33cd-353e-478c-a987-3e8866e19ae9))
(fp_rect (start -4.25 -0.75) (end -3.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp dbfd6032-3ba9-4c5e-806a-ce5a5433a665))
(fp_rect (start 7.75 -7.25) (end 8.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp dc5ae963-fe21-456d-b1a4-8eb4c651aae6))
(fp_rect (start -4.25 2.75) (end -3.75 3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp dc6cd7fc-7bd0-4de6-b25d-8358230cc2b3))
(fp_rect (start 4.25 0.75) (end 4.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp ddf5044d-271b-4e01-a609-3ba16fdb7050))
(fp_rect (start 6.25 -6.75) (end 6.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp de7ffa3a-2037-46f6-a7ae-fd836c4cc46c))
(fp_rect (start 3.25 -6.75) (end 3.75 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp df613813-22f2-4bee-b44c-2a2c1633ded3))
(fp_rect (start -3.25 -2.25) (end -2.75 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e054f807-c3ce-4a7e-9d6b-14f0839d4695))
(fp_rect (start 6.25 0.75) (end 6.75 1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e09aafd0-d16e-43e8-a0cb-4a539aade959))
(fp_rect (start -6.75 6.25) (end -6.25 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e0d857ee-7b4f-405d-a83a-91235b8e80f1))
(fp_rect (start -4.25 3.25) (end -3.75 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e105b377-04fd-4739-b42d-70b52bf9043e))
(fp_rect (start -1.75 -2.25) (end -1.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e109faf2-baea-4512-920c-3e2b43ba897c))
(fp_rect (start -7.75 -2.25) (end -7.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e14b6c18-1728-47af-a6a7-e680ece18d44))
(fp_rect (start 0.75 -5.75) (end 1.25 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e14d60e1-db05-4200-8e33-2b635e2d1be9))
(fp_rect (start 5.25 2.25) (end 5.75 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e157f239-db58-48f0-a8c9-8ae6164404f2))
(fp_rect (start 2.75 -6.25) (end 3.25 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e172da6a-bcf5-4396-ad65-991c2042bc50))
(fp_rect (start 2.25 7.25) (end 2.75 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e1d4a68d-c675-4b4c-b2fe-c31bfbc96c82))
(fp_rect (start -8.25 -2.25) (end -7.75 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e1e77345-b3a1-48c5-af6b-dd74d7941265))
(fp_rect (start -5.25 6.75) (end -4.75 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e25367f3-3ba5-4cb0-bbd9-92139eda38e8))
(fp_rect (start -2.25 7.75) (end -1.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e28addd6-9d8e-47f7-abfe-98c30e9ed852))
(fp_rect (start 3.75 5.25) (end 4.25 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e2bc1a90-22ff-4b34-8c57-b9c6016801a8))
(fp_rect (start -6.25 -5.25) (end -5.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e2defa08-2894-4ee2-bfa6-99118626bbf3))
(fp_rect (start 0.25 -3.75) (end 0.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e364a00d-7621-4343-a8d2-d01927959cc0))
(fp_rect (start -3.25 -4.25) (end -2.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e3d9ef7b-de42-4b47-a806-f57b85031b34))
(fp_rect (start -2.25 1.75) (end -1.75 2.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e44bf520-77c3-42b5-bd67-dd6d86635d05))
(fp_rect (start -5.25 -0.25) (end -4.75 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e5d16aea-1454-4b33-a4a4-d62ca305bb7a))
(fp_rect (start -6.75 3.75) (end -6.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e605149f-e0dd-4baf-8a5d-9f30663a8aec))
(fp_rect (start 6.75 -7.25) (end 7.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e63bb130-ad98-4933-863e-58b2216f7f13))
(fp_rect (start -0.25 7.25) (end 0.25 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e63bbbda-fdfe-4e24-9b63-ded53d82a2e9))
(fp_rect (start 6.25 0.25) (end 6.75 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e679d04c-4f61-4486-ab66-608cb7b52661))
(fp_rect (start -3.75 -2.25) (end -3.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e6a033c3-2e7f-4285-bfa7-b3cb094a62db))
(fp_rect (start -2.25 -5.25) (end -1.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e6dfd0e2-0004-4097-9bb5-61cb2463be0e))
(fp_rect (start -1.75 -3.25) (end -1.25 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e6e74239-eb7c-46be-a737-cd6b287fceea))
(fp_rect (start 2.25 4.25) (end 2.75 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e6f0aeee-3ee2-4aa4-9aab-99ad5b2b3b36))
(fp_rect (start -6.75 -8.25) (end -6.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e71066dc-0515-4d49-bc5a-be4459bcd7a6))
(fp_rect (start -5.25 7.25) (end -4.75 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e7183110-ea6d-45c2-9982-cd4f62d1bb39))
(fp_rect (start 5.75 -6.75) (end 6.25 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e7699434-0334-4d1c-bafc-478f02c5e11e))
(fp_rect (start 7.75 3.75) (end 8.25 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e7804ba0-5e09-4c5d-842b-b3eaab38d0af))
(fp_rect (start 0.75 6.25) (end 1.25 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e7dba29f-5d18-4496-9c7e-5d55cef58cd2))
(fp_rect (start -6.75 4.75) (end -6.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp e7fcce1b-eed4-40ef-bedb-01a9dab1ce54))
(fp_rect (start -8.25 0.25) (end -7.75 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e8868ed6-cacd-4e76-8fd3-f8676c9b2994))
(fp_rect (start -7.25 -3.25) (end -6.75 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e88f9db6-02f9-4eeb-91c3-59052e22c8ec))
(fp_rect (start -1.75 1.25) (end -1.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e923fde8-656b-4b3d-a875-e2b66e4cf1f6))
(fp_rect (start -8.25 7.25) (end -7.75 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e9bb58f5-022d-4cc3-87bb-983830e70009))
(fp_rect (start 4.75 2.25) (end 5.25 2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e9c06018-f94a-498d-9af0-97d1bc3f2ae8))
(fp_rect (start -3.25 1.25) (end -2.75 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp e9f01f1a-44b7-49b6-bde1-9ac19a4d1f43))
(fp_rect (start 5.75 -5.25) (end 6.25 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp eaeb1157-d68c-45d2-a9ad-5f263161d840))
(fp_rect (start -6.75 -3.75) (end -6.25 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp eb08a993-7bba-4bd2-b482-c99366b57b56))
(fp_rect (start 7.75 1.25) (end 8.25 1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp eb2ec285-f158-42b4-af03-0376105ccbd2))
(fp_rect (start 4.75 -2.25) (end 5.25 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp eb5e3a90-3b51-43bf-8446-d159dcb28685))
(fp_rect (start -6.25 6.25) (end -5.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp ec75fc9f-f613-4d00-b93f-5bca9920acd3))
(fp_rect (start 4.75 -8.25) (end 5.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp ed0d7b10-214a-4a74-a516-7d89de5d8c11))
(fp_rect (start -3.75 -0.75) (end -3.25 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp ed742886-c808-4131-837f-e0bfb55adae0))
(fp_rect (start 6.25 -8.25) (end 6.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp ee2c1ad7-4a69-4089-a6ee-c2c7128ae42a))
(fp_rect (start -5.25 -6.25) (end -4.75 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp ee37e74f-8e56-41f6-806a-fb8b70af954f))
(fp_rect (start -1.25 -4.75) (end -0.75 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp ee4ca2da-ba87-456f-bf56-676b9192bc5a))
(fp_rect (start 3.25 4.25) (end 3.75 4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp ef660157-609b-4b9f-958b-0906c558d922))
(fp_rect (start -7.25 5.75) (end -6.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp ef772289-828c-46cc-810a-223c4d100a84))
(fp_rect (start -7.75 7.75) (end -7.25 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp efe74f95-0921-495d-92c8-b12b1ae29508))
(fp_rect (start 5.75 -1.25) (end 6.25 -0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f092a3c7-4ab3-457d-a711-8b64578f2301))
(fp_rect (start 7.25 -5.25) (end 7.75 -4.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f1ceebb8-504b-4498-b8db-4b978ef4f285))
(fp_rect (start -5.25 5.25) (end -4.75 5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f215e4f0-056d-476b-b174-abd11377a065))
(fp_rect (start -2.25 -4.75) (end -1.75 -4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp f314431c-6ad5-4baa-94f7-6360e163cebc))
(fp_rect (start -5.25 -8.25) (end -4.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f352260b-3c2a-4664-b125-aaf411f62463))
(fp_rect (start 0.75 -7.25) (end 1.25 -6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f3895704-4c3a-4f63-9cb4-ca8f4be32382))
(fp_rect (start -4.25 3.75) (end -3.75 4.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp f424a655-b30f-41dc-8594-266b44ed0364))
(fp_rect (start 6.25 -4.25) (end 6.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f4359816-c455-49c0-a515-b7ec2740e9ac))
(fp_rect (start 3.75 6.75) (end 4.25 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp f47404b8-d9a2-4237-b106-d475c33e5073))
(fp_rect (start -8.25 -6.25) (end -7.75 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f5c9f831-2ee7-4f7c-a571-fd9be530cc87))
(fp_rect (start 5.25 -8.25) (end 5.75 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f5e5ec6b-cfe1-4049-ad78-fa355d69a5b4))
(fp_rect (start 6.25 -2.25) (end 6.75 -1.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f6b70556-6821-4b6b-8261-7991f08bddb7))
(fp_rect (start -5.75 -8.25) (end -5.25 -7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f7a7f9a9-9428-42be-832a-ab35020d5810))
(fp_rect (start -0.25 -6.75) (end 0.25 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp f7c54b41-69ea-4ee2-ac7e-d21357aee8ed))
(fp_rect (start 2.25 -0.75) (end 2.75 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp f80aea68-781b-42b2-b0f7-ae33342b5e92))
(fp_rect (start -0.75 -5.75) (end -0.25 -5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp f818c8e8-1a30-4868-ae76-7511be1c41e5))
(fp_rect (start -7.25 -3.75) (end -6.75 -3.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp f827c9b7-652b-42aa-90f6-e57b7a58d1b1))
(fp_rect (start 6.75 -6.75) (end 7.25 -6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp f85ebcbe-9a65-40e0-9a71-9d3d5f57805f))
(fp_rect (start 3.25 0.25) (end 3.75 0.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f87f453e-4237-45d3-b736-ff61ff8c9af6))
(fp_rect (start 1.75 6.25) (end 2.25 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f8f5fc47-a957-42a9-8cc4-77aa06248ea6))
(fp_rect (start -6.25 -4.25) (end -5.75 -3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f964a8bb-84dc-42fc-8190-53d869778e1f))
(fp_rect (start 7.75 3.25) (end 8.25 3.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f9b69381-6d0d-4f82-9780-abbe556cdbe0))
(fp_rect (start 1.75 -3.25) (end 2.25 -2.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp f9d56579-4665-4291-8daa-238922297fe9))
(fp_rect (start -4.25 -6.25) (end -3.75 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp fa18aea8-6b0a-4dc9-b1e1-d270f10847ce))
(fp_rect (start -1.75 -0.75) (end -1.25 -0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fa5174ab-1489-4c82-abe8-a3a015638b1b))
(fp_rect (start -2.75 -1.75) (end -2.25 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fa57f43d-2cbf-4c62-a78e-c6fd96a8d752))
(fp_rect (start 0.75 4.75) (end 1.25 5.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fa69521e-0b4a-4a64-8b5a-040f7dde2974))
(fp_rect (start -1.75 -7.75) (end -1.25 -7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fac47c45-0a35-4908-8782-abd14c67d40e))
(fp_rect (start -2.75 -6.25) (end -2.25 -5.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp fbcdbe7d-f0d4-446e-8ac7-9f70271e27bb))
(fp_rect (start 1.75 -0.25) (end 2.25 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fc51550d-c0e8-422d-b3b9-4c0f3cbdaaff))
(fp_rect (start -4.25 5.75) (end -3.75 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fc632d25-fd55-4040-beb6-6efc5fe3122a))
(fp_rect (start -1.25 6.75) (end -0.75 7.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fc69c83e-a8f3-4e18-9070-2949d1c0d605))
(fp_rect (start 4.75 -1.75) (end 5.25 -1.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fd068fec-627f-4786-b55a-3b0f59bc8090))
(fp_rect (start 4.75 7.75) (end 5.25 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fd3c2437-60e6-48de-9221-1e13890bb42e))
(fp_rect (start -1.25 7.75) (end -0.75 8.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fd6da314-2040-40c8-8d51-fbf27d5328a2))
(fp_rect (start 3.75 5.75) (end 4.25 6.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fd7be013-c791-4b26-a4f6-bc756044558c))
(fp_rect (start -8.25 6.25) (end -7.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp fdaf7989-0aca-4b34-8de9-78c0b3ee2a8a))
(fp_rect (start -0.75 7.25) (end -0.25 7.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp fdb34042-4fe1-46d2-96d3-2171b09598e5))
(fp_rect (start 5.75 -0.25) (end 6.25 0.25) (layer "F.SilkS") (width 0) (fill solid) (tstamp fdfa0f5f-f3dc-48ed-8b1b-d0cbce5a317b))
(fp_rect (start -3.25 6.25) (end -2.75 6.75) (layer "F.SilkS") (width 0) (fill solid) (tstamp fe7ad404-1bb3