fix permissions
[hw/altusmetrum] / packages / TI-QFN32-new.py
1 #!/usr/bin/python3
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 3')
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(")")