snapshot before radical update
[hw/bdale] / pkg / newlib / QFN36.py
1 #!/usr/bin/python
2 # Copyright 2007 by Bdale Garbee <bdale@gag.com>.  GPLv2
3 #
4 # Program to emit PCB footprint for QFN36 package used by TI CC1111
5 #
6
7 # dimensions in mm from the TI cc1111f32.pdf datasheet
8 PinWidth = 0.28
9 PinHeight = 0.75
10 PinSpacing = 0.50
11 Overall = 6.30
12 CoreSquare = 4.40
13 PinSquare = 4.80
14
15 import sys
16
17 # we're going to use the 1/100 of a mil fundamental unit form
18 def mm2mils100( mm ):
19         return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
20
21 print 'Element[0x0 "QFN36" "" "" 0 0 0 0 0 100 0x0]'
22 print "("
23
24 # pad under the chip, must be grounded
25 # making the solder mask opening the recommended size, and the actual copper
26 # pad 6 mils smaller ... hoping this helps us avoid signal pad shorts!
27 print '   Pad[',\
28         mm2mils100(0), \
29         mm2mils100(0), \
30         mm2mils100(0), \
31         mm2mils100(0), \
32         mm2mils100(CoreSquare)-600, \
33         0, \
34         mm2mils100(CoreSquare), \
35         '"pin37" "37" 0x0100]'
36
37 # vias in the ground pad under the chip
38 for via in range (-1,2):
39     print '   Pin[',\
40         mm2mils100(-CoreSquare / 3), \
41         mm2mils100(via * CoreSquare / 3), \
42         2500, \
43         2600, \
44         0, \
45         1700, \
46         '"pin37" "37" 0x0002]'
47     print '   Pin[',\
48         mm2mils100(0), \
49         mm2mils100(via * CoreSquare / 3), \
50         2500, \
51         2600, \
52         0, \
53         1700, \
54         '"pin37" "37" 0x0002]'
55     print '   Pin[',\
56         mm2mils100(CoreSquare / 3), \
57         mm2mils100(via * CoreSquare / 3), \
58         2500, \
59         2600, \
60         0, \
61         1700, \
62         '"pin37" "37" 0x0002]'
63
64 # pins
65 for pin in range (1,10):
66     print '   Pad[',\
67         mm2mils100(-2.5 + pin * PinSpacing), \
68         mm2mils100(-Overall/2 + PinWidth/2), \
69         mm2mils100(-2.5 + pin * PinSpacing), \
70         mm2mils100(-Overall/2 + PinHeight - PinWidth/2), \
71         mm2mils100(PinWidth), \
72         mm2mils100(PinSpacing - PinWidth), \
73         mm2mils100(PinWidth)+600, \
74         '"pin%i"' % (28-pin), '"%i"' % (28-pin), '0x0000]'
75
76     print '   Pad[',\
77         mm2mils100(-2.5 + pin * PinSpacing), \
78         mm2mils100(+Overall/2 - PinHeight + PinWidth/2), \
79         mm2mils100(-2.5 + pin * PinSpacing), \
80         mm2mils100(+Overall/2 - PinWidth/2), \
81         mm2mils100(PinWidth), \
82         mm2mils100(PinSpacing - PinWidth), \
83         mm2mils100(PinWidth)+600, \
84         '"pin%i"' % pin, '"%i"' % pin, '0x0000]'
85
86     print '   Pad[',\
87         mm2mils100(Overall/2 - PinHeight + PinWidth/2), \
88         mm2mils100(-2.5 + pin * PinSpacing), \
89         mm2mils100(Overall/2 - PinWidth/2), \
90         mm2mils100(-2.5 + pin * PinSpacing), \
91         mm2mils100(PinWidth), \
92         mm2mils100(PinSpacing - PinWidth), \
93         mm2mils100(PinWidth)+600, \
94         '"pin%i"' % (19-pin), '"%i"' % (19-pin), '0x0000]'
95
96     print '   Pad[',\
97         mm2mils100(-Overall/2 + PinWidth/2), \
98         mm2mils100(-2.5 + pin * PinSpacing), \
99         mm2mils100(-Overall/2 + PinHeight - PinWidth/2), \
100         mm2mils100(-2.5 + pin * PinSpacing), \
101         mm2mils100(PinWidth), \
102         mm2mils100(PinSpacing - PinWidth), \
103         mm2mils100(PinWidth)+600, \
104         '"pin%i"' % (27+pin), '"%i"' % (27+pin), '0x0000]'
105
106 print '   ElementArc[',\
107         mm2mils100(-2.6), \
108         mm2mils100(2.6), \
109         '500 500 0 360 1000 ]'
110 print ")"