a3033dbf497a1928d0812a10dd4029bc1f03b78a
[slipway.git] / src / edu / berkeley / obits / device / atmel / ChipImpl.java
1 package edu.berkeley.obits.device.atmel;
2 import com.ftdi.usb.*;
3 import java.io.*;
4
5 public class ChipImpl extends FtdiChip implements Chip {
6
7     public ChipImpl() {
8         super();
9         doReset();
10     }
11
12     public void doReset() {
13         dbangmode();
14         clk(false);
15         data(false);
16
17         con(false);
18         flush();
19         buffered(false);
20         reset(false);
21         //avrrst(false);
22         try { Thread.sleep(200); } catch (Exception e) { }
23         reset(true);
24         //avrrst(true);
25         try { Thread.sleep(200); } catch (Exception e) { }
26
27         dmask &= ~(1<<7);
28         dbangmode();
29     }
30
31     int porte = 0;
32     public void porte(int pin, boolean b) {
33         porte = (~(1<<pin)) | (b ? (1<<pin) : 0);
34         if (pin==4) {
35             dbang(2, b);
36             flush();
37         }
38     }
39
40
41     //
42
43     public void buffered() { buffered = true; }
44     public void buffered(boolean buf) { buffered = buf; }
45     public void config(boolean bit) { config(bit?1:0, 1); }
46     public void config(int dat) { config(dat, 8); }
47     public void config(int dat, int numbits) {
48         for(int i=(numbits-1); i>=0; i--) {
49             boolean bit = (dat & (1<<i)) != 0;
50             data(bit);
51             clk(true);
52             clk(false);
53         }
54     }
55
56     public void reset(boolean on) {
57         bits = on ? (1<<1) : 0;
58         cbangmode();
59         //dbang(0, on);
60     }
61     public void avrrst(boolean on) { dbang(7, on); }
62     public boolean initErr()       { return (readPins() & (1<<4))!=0; }
63     public void clk(boolean on)    { dbang(6, on); }
64     public void data(boolean on)   { dbang(5, on); }
65
66     public boolean con() {
67
68         /*
69         mask &= ~(1<<0);
70         cbangmode();
71         boolean ret = (readPins() & (1<<0)) != 0;
72         dbangmode();
73         return ret;
74         */
75
76
77
78         dmask &= ~(1<<0);
79         dbangmode();
80         return (readPins() & (1<<0)) != 0;
81
82     }
83     public void con(boolean on) {
84
85         /*
86         mask |= (1<<0);
87         bits = on ? (1<<0) : 0;
88         cbangmode();
89         */
90
91
92         dmask |= (1<<0);
93         dbangmode();
94         dbang(0, on);
95
96     }
97
98 }