2 * Copyright © 2008 Keith Packard <keithp@keithp.com>
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful, but
10 * WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * General Public License for more details.
14 * You should have received a copy of the GNU General Public License along
15 * with this program; if not, write to the Free Software Foundation, Inc.,
16 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
22 #include "cp-usb-async.h"
27 static uint32_t cc_clock_us = CC_CLOCK_US;
30 ccdbg_set_clock(uint32_t us)
36 ccdbg_half_clock(struct ccdbg *dbg)
38 struct timespec req, rem;
39 req.tv_sec = (cc_clock_us / 2) / 1000000;
40 req.tv_nsec = ((cc_clock_us / 2) % 1000000) * 1000;
41 nanosleep(&req, &rem);
49 dbg = calloc(sizeof (struct ccdbg), 1);
55 dbg->cp_async = cp_usb_async_open();
61 dbg->cp = cp_usb_open ();
71 ccdbg_close(struct ccdbg *dbg)
74 cp_usb_async_close(dbg->cp_async);
76 cp_usb_close(dbg->cp);
82 ccdbg_write(struct ccdbg *dbg, uint8_t mask, uint8_t value)
85 cp_usb_async_write(dbg->cp_async, mask, value);
87 cp_usb_write(dbg->cp, mask, value);
93 ccdbg_read(struct ccdbg *dbg, uint8_t *valuep)
96 cp_usb_async_read(dbg->cp_async, valuep);
98 *valuep = cp_usb_read(dbg->cp);
103 ccdbg_sync_io(struct ccdbg *dbg)
106 cp_usb_async_sync(dbg->cp_async);
111 is_bit(uint8_t get, uint8_t mask, char on, uint8_t bit)
122 ccdbg_print(char *format, uint8_t mask, uint8_t set)
124 ccdbg_debug (CC_DEBUG_BITBANG, format,
125 is_bit(set, mask, 'C', CC_CLOCK),
126 is_bit(set, mask, 'D', CC_DATA),
127 is_bit(set, mask, 'R', CC_RESET_N));
131 ccdbg_send(struct ccdbg *dbg, uint8_t mask, uint8_t set)
133 ccdbg_write(dbg, mask, set);
134 ccdbg_print("%c %c %c\n", mask, set);
135 ccdbg_half_clock(dbg);
139 ccdbg_send_bit(struct ccdbg *dbg, uint8_t bit)
141 if (bit) bit = CC_DATA;
142 ccdbg_send(dbg, CC_CLOCK|CC_DATA|CC_RESET_N, CC_CLOCK|bit|CC_RESET_N);
143 ccdbg_send(dbg, CC_CLOCK|CC_DATA|CC_RESET_N, bit|CC_RESET_N);
147 ccdbg_send_byte(struct ccdbg *dbg, uint8_t byte)
150 ccdbg_debug(CC_DEBUG_BITBANG, "#\n# Send Byte 0x%02x\n#\n", byte);
151 for (bit = 7; bit >= 0; bit--) {
152 ccdbg_send_bit(dbg, (byte >> bit) & 1);
154 ccdbg_debug(CC_DEBUG_BITBANG, "\n");
160 ccdbg_send_bytes(struct ccdbg *dbg, uint8_t *bytes, int nbytes)
163 ccdbg_send_byte(dbg, *bytes++);
167 ccdbg_recv_bit(struct ccdbg *dbg, int first, uint8_t *bit)
169 uint8_t mask = first ? CC_DATA : 0;
171 ccdbg_send(dbg, CC_CLOCK|mask|CC_RESET_N, CC_CLOCK|CC_DATA|CC_RESET_N);
172 ccdbg_read(dbg, bit);
173 ccdbg_send(dbg, CC_CLOCK| CC_RESET_N, CC_RESET_N);
177 ccdbg_recv_byte(struct ccdbg *dbg, int first, uint8_t *bytep)
183 ccdbg_debug(CC_DEBUG_BITBANG, "#\n# Recv byte\n#\n");
184 for (bit = 0; bit < 8; bit++) {
185 ccdbg_recv_bit(dbg, first, &bits[bit]);
189 for (bit = 0; bit < 8; bit++) {
191 byte |= (bits[bit] & CC_DATA) ? 1 : 0;
192 ccdbg_print("#\t%c %c %c\n", CC_DATA, bits[bit]);
194 ccdbg_debug(CC_DEBUG_BITBANG, "\n");
196 ccdbg_debug(CC_DEBUG_BITBANG, "#\n# Recv 0x%02x\n#\n", byte);
201 ccdbg_recv_bytes(struct ccdbg *dbg, uint8_t *bytes, int nbytes)
205 for (i = 0; i < nbytes; i++) {
206 ccdbg_recv_byte(dbg, first, &bytes[i]);
212 ccdbg_cmd_write(struct ccdbg *dbg, uint8_t cmd, uint8_t *data, int len)
215 ccdbg_send_byte(dbg, cmd);
216 for (i = 0; i < len; i++)
217 ccdbg_send_byte(dbg, data[i]);
221 ccdbg_cmd_write_read8(struct ccdbg *dbg, uint8_t cmd, uint8_t *data, int len)
224 ccdbg_cmd_write(dbg, cmd, data, len);
225 ccdbg_recv_bytes(dbg, byte, 1);
230 ccdbg_cmd_write_read16(struct ccdbg *dbg, uint8_t cmd, uint8_t *data, int len)
233 ccdbg_cmd_write(dbg, cmd, data, len);
234 ccdbg_recv_bytes(dbg, byte, 2);
235 return (byte[0] << 8) | byte[1];