a5643312c3fd6db330f22ba0623f4bc7b0dff570
[hw/altusmetrum] / packages / AN3111.py
1 #!/usr/bin/python2
2 # Copyright 2007 by Bdale Garbee <bdale@gag.com>.  GPLv2
3 #
4 # Program to emit PCB footprint for 16-lead QFN, 6x6mm 
5 # used by Freescale acceleromters like the MMA6556
6 #
7
8 # dimensions in mm from AN3111.pdf from Freescale, the Wettable Flank variant
9 PinWidth = 0.50
10 PinHeight = 0.85
11 PinSpacing = 1.00
12 Overall = 6.0
13 CoreSquare = 4.00
14 CornerSquare = 0.55
15 MaskAdd = 0.15
16
17 import sys
18
19 # we're going to use the 1/100 of a mil fundamental unit form
20 def mm2mils100( mm ):
21         return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
22
23 print '# author: Bdale Garbee'
24 print '# email: bdale@gag.com'
25 print '# dist-license: GPL 2'
26 print '# use-license: unlimited'
27
28 print 'Element[0x0 "AN3111" "" "" 0 0 0 0 0 100 0x0]'
29 print "("
30 # pad under the chip, no overall paste so we can control subset that gets paste
31 print '   Pad[',\
32         mm2mils100(0), \
33         mm2mils100(0), \
34         mm2mils100(0), \
35         mm2mils100(0), \
36         mm2mils100(CoreSquare), \
37         mm2mils100(0), \
38         mm2mils100(CoreSquare + MaskAdd), \
39         '"17" "17" "square,nopaste"]'
40
41 # copper sub-squares in a grid to set paste area
42 for viarow in range (-1, 2):
43   for viacol in range (-1, 2):
44       print '   Pad[',\
45         mm2mils100(viacol * 1.4), \
46         mm2mils100(viarow * 1.4), \
47         mm2mils100(viacol * 1.4), \
48         mm2mils100(viarow * 1.4), \
49         mm2mils100(1.0), \
50         0, \
51         mm2mils100(1.0), \
52         '"17" "17" "square"]'
53
54
55 # corner mounting squares .. tied to Vss on chip, but don't connect on board
56 print '   Pad[',\
57         mm2mils100(CoreSquare/2 + 0.37 + CornerSquare/2), \
58         mm2mils100(CoreSquare/2 + 0.37 + CornerSquare/2), \
59         mm2mils100(CoreSquare/2 + 0.37 + CornerSquare/2), \
60         mm2mils100(CoreSquare/2 + 0.37 + CornerSquare/2), \
61         mm2mils100(CornerSquare), \
62         mm2mils100(0), \
63         mm2mils100(CornerSquare + MaskAdd), \
64         '"NC" "NC" 0x0100]'
65
66 print '   Pad[',\
67         mm2mils100(CoreSquare/2 + 0.37 + CornerSquare/2), \
68         mm2mils100(-(CoreSquare/2 + 0.37 + CornerSquare/2)), \
69         mm2mils100(CoreSquare/2 + 0.37 + CornerSquare/2), \
70         mm2mils100(-(CoreSquare/2 + 0.37 + CornerSquare/2)), \
71         mm2mils100(CornerSquare), \
72         mm2mils100(0), \
73         mm2mils100(CornerSquare + MaskAdd), \
74         '"NC" "NC" 0x0100]'
75
76 print '   Pad[',\
77         mm2mils100(-(CoreSquare/2 + 0.37 + CornerSquare/2)), \
78         mm2mils100(CoreSquare/2 + 0.37 + CornerSquare/2), \
79         mm2mils100(-(CoreSquare/2 + 0.37 + CornerSquare/2)), \
80         mm2mils100(CoreSquare/2 + 0.37 + CornerSquare/2), \
81         mm2mils100(CornerSquare), \
82         mm2mils100(0), \
83         mm2mils100(CornerSquare + MaskAdd), \
84         '"NC" "NC" 0x0100]'
85
86 print '   Pad[',\
87         mm2mils100(-(CoreSquare/2 + 0.37 + CornerSquare/2)), \
88         mm2mils100(-(CoreSquare/2 + 0.37 + CornerSquare/2)), \
89         mm2mils100(-(CoreSquare/2 + 0.37 + CornerSquare/2)), \
90         mm2mils100(-(CoreSquare/2 + 0.37 + CornerSquare/2)), \
91         mm2mils100(CornerSquare), \
92         mm2mils100(0), \
93         mm2mils100(CornerSquare + MaskAdd), \
94         '"NC" "NC" 0x0100]'
95
96 for pin in range (1,5):
97     print '   Pad[',\
98         mm2mils100(-2.5 + pin * PinSpacing), \
99         mm2mils100(-Overall/2 - 0.30 + PinWidth/2), \
100         mm2mils100(-2.5 + pin * PinSpacing), \
101         mm2mils100(-Overall/2 + 0.55 - PinWidth/2), \
102         mm2mils100(PinWidth), \
103         mm2mils100(0), \
104         mm2mils100(PinWidth + MaskAdd), \
105         '"pin%i"' % (13-pin), '"%i"' % (13-pin), '0x0100]'
106
107     print '   Pad[',\
108         mm2mils100(-2.5 + pin * PinSpacing), \
109         mm2mils100(+Overall/2 - 0.55 + PinWidth/2), \
110         mm2mils100(-2.5 + pin * PinSpacing), \
111         mm2mils100(+Overall/2 + 0.30 - PinWidth/2), \
112         mm2mils100(PinWidth), \
113         mm2mils100(0), \
114         mm2mils100(PinWidth + MaskAdd), \
115         '"pin%i"' % pin, '"%i"' % pin, '0x0100]'
116
117     print '   Pad[',\
118         mm2mils100(Overall/2 - 0.55 + PinWidth/2), \
119         mm2mils100(-2.5 + pin * PinSpacing), \
120         mm2mils100(Overall/2 + 0.30 - PinWidth/2), \
121         mm2mils100(-2.5 + pin * PinSpacing), \
122         mm2mils100(PinWidth), \
123         mm2mils100(0), \
124         mm2mils100(PinWidth + MaskAdd), \
125         '"pin%i"' % (9-pin), '"%i"' % (9-pin), '0x0100]'
126
127     print '   Pad[',\
128         mm2mils100(-Overall/2 - 0.30 + PinWidth/2), \
129         mm2mils100(-2.5 + pin * PinSpacing), \
130         mm2mils100(-Overall/2 + 0.55 - PinWidth/2), \
131         mm2mils100(-2.5 + pin * PinSpacing), \
132         mm2mils100(PinWidth), \
133         mm2mils100(0), \
134         mm2mils100(PinWidth + MaskAdd), \
135         '"pin%i"' % (12+pin), '"%i"' % (12+pin), '0x0100]'
136
137 print '   ElementArc[',\
138         mm2mils100(-3.2), \
139         mm2mils100(3.2), \
140         '500 500 0 360 1000 ]'
141 print ")"