570eb50bc95fc473b232e2b010cd11d396338ac7
[hw/altusmetrum] / packages / TI-QFN32-new.py
1 #!/usr/bin/python2
2 # Copyright 2011 by Bdale Garbee <bdale@gag.com>.  GPLv2
3 #
4 # Program to emit PCB footprint for QFN32 package used by TI CC1120
5 #
6
7 # dimensions in mm from the TI cc1111f32.pdf datasheet
8 PinWidth = 0.3
9 PinResist = PinWidth + (2 * 0.07)
10 PinHeight = (5.8 - 4.1) / 2
11 PinSpacing = 0.50
12 Overall = 5.80
13 GndSquare = 3.40
14 CoreSquare = 3.30               # resist gaps and paste spots over ground tab
15 PinSquare = 4.10
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 "QFN36" "" "" 0 0 0 0 0 100 0x0]'
29 print "("
30
31 # pad under the chip, must be grounded
32 print '   Pad[',\
33         mm2mils100(0), \
34         mm2mils100(0), \
35         mm2mils100(0), \
36         mm2mils100(0), \
37         mm2mils100(GndSquare), \
38         0, \
39         0, \
40         '"pin33" "33" "square,nopaste"]'
41
42 # vias in the ground pad under the chip
43 for viarow in range (-1,2):
44   for viacol in range (-1,2):
45     print '   Pin[',\
46         mm2mils100(2 * viacol * CoreSquare / 5), \
47         mm2mils100(2 * viarow * CoreSquare / 5), \
48         2900, \
49         2500, \
50         0, \
51         1500, \
52         '"pin33" "33" 0x0002]'
53
54 # break pad under chip into a grid to control the resist and paste masks
55 for viarow in range (-2, 3):
56   for viacol in range (-2, 3):
57     if (viarow in (-2, 0, 2)) and (viacol in (-2, 0, 2)):
58       # copper sub-square with resist over vias
59       print '   Pad[',\
60         mm2mils100(viacol * CoreSquare / 5), \
61         mm2mils100(viarow * CoreSquare / 5), \
62         mm2mils100(viacol * CoreSquare / 5), \
63         mm2mils100(viarow * CoreSquare / 5), \
64         mm2mils100((CoreSquare)/5), \
65         0, \
66         0, \
67         '"pin33" "33" "square,nopaste"]'
68     else:
69       # copper sub-square without resist
70       print '   Pad[',\
71         mm2mils100(viacol * CoreSquare / 5), \
72         mm2mils100(viarow * CoreSquare / 5), \
73         mm2mils100(viacol * CoreSquare / 5), \
74         mm2mils100(viarow * CoreSquare / 5), \
75         mm2mils100((CoreSquare)/5), \
76         0, \
77         mm2mils100((CoreSquare)/5), \
78         '"pin33" "33" "square,nopaste"]'
79       # copper spot to control paste mask generation
80       print '   Pad[',\
81         mm2mils100(viacol * CoreSquare / 5), \
82         mm2mils100(viarow * CoreSquare / 5), \
83         mm2mils100(viacol * CoreSquare / 5), \
84         mm2mils100(viarow * CoreSquare / 5), \
85         1500, \
86         0, \
87         mm2mils100((CoreSquare)/5), \
88         '"pin33" "33" "square"]'
89
90 # pins
91 for pin in range (1,9):
92     print '   Pad[',\
93         mm2mils100((-4.5 + pin) * PinSpacing), \
94         mm2mils100(-Overall/2 + PinWidth/2), \
95         mm2mils100((-4.5 + pin) * PinSpacing), \
96         mm2mils100(-Overall/2 + PinHeight - PinWidth/2), \
97         mm2mils100(PinWidth), \
98         mm2mils100(PinSpacing - PinWidth), \
99         mm2mils100(PinResist), \
100         '"pin%i"' % (25-pin), '"%i"' % (25-pin), '"square"]'
101
102     print '   Pad[',\
103         mm2mils100((-4.5 + pin) * PinSpacing), \
104         mm2mils100(+Overall/2 - PinHeight + PinWidth/2), \
105         mm2mils100((-4.5 + pin) * PinSpacing), \
106         mm2mils100(+Overall/2 - PinWidth/2), \
107         mm2mils100(PinWidth), \
108         mm2mils100(PinSpacing - PinWidth), \
109         mm2mils100(PinResist), \
110         '"pin%i"' % pin, '"%i"' % pin, '"square"]'
111
112     print '   Pad[',\
113         mm2mils100(Overall/2 - PinHeight + PinWidth/2), \
114         mm2mils100((-4.5 + pin) * PinSpacing), \
115         mm2mils100(Overall/2 - PinWidth/2), \
116         mm2mils100((-4.5 + pin) * PinSpacing), \
117         mm2mils100(PinWidth), \
118         mm2mils100(PinSpacing - PinWidth), \
119         mm2mils100(PinResist), \
120         '"pin%i"' % (17-pin), '"%i"' % (17-pin), '"square"]'
121
122     print '   Pad[',\
123         mm2mils100(-Overall/2 + PinWidth/2), \
124         mm2mils100((-4.5 + pin) * PinSpacing), \
125         mm2mils100(-Overall/2 + PinHeight - PinWidth/2), \
126         mm2mils100((-4.5 + pin) * PinSpacing), \
127         mm2mils100(PinWidth), \
128         mm2mils100(PinSpacing - PinWidth), \
129         mm2mils100(PinResist), \
130         '"pin%i"' % (24+pin), '"%i"' % (24+pin), '"square"]'
131
132 print '   ElementArc[',\
133         mm2mils100(-2.6), \
134         mm2mils100(2.6), \
135         '500 500 0 360 1000 ]'
136 print ")"