xref: /freebsd/sys/dev/usb/controller/musb_otg.c (revision d91f8db5f1822c43cd256f19aae1d059e4b25a26)
1 /* $FreeBSD$ */
2 /*-
3  * SPDX-License-Identifier: BSD-2-Clause
4  *
5  * Copyright (c) 2008 Hans Petter Selasky. All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26  * SUCH DAMAGE.
27  */
28 
29 /*
30  * Thanks to Mentor Graphics for providing a reference driver for this USB chip
31  * at their homepage.
32  */
33 
34 /*
35  * This file contains the driver for the Mentor Graphics Inventra USB
36  * 2.0 High Speed Dual-Role controller.
37  *
38  */
39 
40 #ifdef USB_GLOBAL_INCLUDE_FILE
41 #include USB_GLOBAL_INCLUDE_FILE
42 #else
43 #include <sys/stdint.h>
44 #include <sys/stddef.h>
45 #include <sys/param.h>
46 #include <sys/queue.h>
47 #include <sys/types.h>
48 #include <sys/systm.h>
49 #include <sys/kernel.h>
50 #include <sys/bus.h>
51 #include <sys/module.h>
52 #include <sys/lock.h>
53 #include <sys/mutex.h>
54 #include <sys/condvar.h>
55 #include <sys/sysctl.h>
56 #include <sys/sx.h>
57 #include <sys/unistd.h>
58 #include <sys/callout.h>
59 #include <sys/malloc.h>
60 #include <sys/priv.h>
61 
62 #include <dev/usb/usb.h>
63 #include <dev/usb/usbdi.h>
64 
65 #define	USB_DEBUG_VAR musbotgdebug
66 
67 #include <dev/usb/usb_core.h>
68 #include <dev/usb/usb_debug.h>
69 #include <dev/usb/usb_busdma.h>
70 #include <dev/usb/usb_process.h>
71 #include <dev/usb/usb_transfer.h>
72 #include <dev/usb/usb_device.h>
73 #include <dev/usb/usb_hub.h>
74 #include <dev/usb/usb_util.h>
75 
76 #include <dev/usb/usb_controller.h>
77 #include <dev/usb/usb_bus.h>
78 #endif			/* USB_GLOBAL_INCLUDE_FILE */
79 
80 #include <dev/usb/controller/musb_otg.h>
81 
82 #define	MUSBOTG_INTR_ENDPT 1
83 
84 #define	MUSBOTG_BUS2SC(bus) \
85     __containerof(bus, struct musbotg_softc, sc_bus)
86 
87 #define	MUSBOTG_PC2SC(pc) \
88    MUSBOTG_BUS2SC(USB_DMATAG_TO_XROOT((pc)->tag_parent)->bus)
89 
90 #ifdef USB_DEBUG
91 static int musbotgdebug = 0;
92 
93 static SYSCTL_NODE(_hw_usb, OID_AUTO, musbotg, CTLFLAG_RW | CTLFLAG_MPSAFE, 0,
94     "USB musbotg");
95 SYSCTL_INT(_hw_usb_musbotg, OID_AUTO, debug, CTLFLAG_RWTUN,
96     &musbotgdebug, 0, "Debug level");
97 #endif
98 
99 #define	MAX_NAK_TO	16
100 
101 /* prototypes */
102 
103 static const struct usb_bus_methods musbotg_bus_methods;
104 static const struct usb_pipe_methods musbotg_device_bulk_methods;
105 static const struct usb_pipe_methods musbotg_device_ctrl_methods;
106 static const struct usb_pipe_methods musbotg_device_intr_methods;
107 static const struct usb_pipe_methods musbotg_device_isoc_methods;
108 
109 /* Control transfers: Device mode */
110 static musbotg_cmd_t musbotg_dev_ctrl_setup_rx;
111 static musbotg_cmd_t musbotg_dev_ctrl_data_rx;
112 static musbotg_cmd_t musbotg_dev_ctrl_data_tx;
113 static musbotg_cmd_t musbotg_dev_ctrl_status;
114 
115 /* Control transfers: Host mode */
116 static musbotg_cmd_t musbotg_host_ctrl_setup_tx;
117 static musbotg_cmd_t musbotg_host_ctrl_data_rx;
118 static musbotg_cmd_t musbotg_host_ctrl_data_tx;
119 static musbotg_cmd_t musbotg_host_ctrl_status_rx;
120 static musbotg_cmd_t musbotg_host_ctrl_status_tx;
121 
122 /* Bulk, Interrupt, Isochronous: Device mode */
123 static musbotg_cmd_t musbotg_dev_data_rx;
124 static musbotg_cmd_t musbotg_dev_data_tx;
125 
126 /* Bulk, Interrupt, Isochronous: Host mode */
127 static musbotg_cmd_t musbotg_host_data_rx;
128 static musbotg_cmd_t musbotg_host_data_tx;
129 
130 static void	musbotg_device_done(struct usb_xfer *, usb_error_t);
131 static void	musbotg_do_poll(struct usb_bus *);
132 static void	musbotg_standard_done(struct usb_xfer *);
133 static void	musbotg_interrupt_poll(struct musbotg_softc *);
134 static void	musbotg_root_intr(struct musbotg_softc *);
135 static int	musbotg_channel_alloc(struct musbotg_softc *, struct musbotg_td *td, uint8_t);
136 static void	musbotg_channel_free(struct musbotg_softc *, struct musbotg_td *td);
137 static void	musbotg_ep_int_set(struct musbotg_softc *sc, int channel, int on);
138 
139 /*
140  * Here is a configuration that the chip supports.
141  */
142 static const struct usb_hw_ep_profile musbotg_ep_profile[1] = {
143 	[0] = {
144 		.max_in_frame_size = 64,/* fixed */
145 		.max_out_frame_size = 64,	/* fixed */
146 		.is_simplex = 1,
147 		.support_control = 1,
148 	}
149 };
150 
151 static const struct musb_otg_ep_cfg musbotg_ep_default[] = {
152 	{
153 		.ep_end = 1,
154 		.ep_fifosz_shift = 12,
155 		.ep_fifosz_reg = MUSB2_VAL_FIFOSZ_4096 | MUSB2_MASK_FIFODB,
156 	},
157 	{
158 		.ep_end = 7,
159 		.ep_fifosz_shift = 10,
160 		.ep_fifosz_reg = MUSB2_VAL_FIFOSZ_512 | MUSB2_MASK_FIFODB,
161 	},
162 	{
163 		.ep_end = 15,
164 		.ep_fifosz_shift = 7,
165 		.ep_fifosz_reg = MUSB2_VAL_FIFOSZ_128,
166 	},
167 	{
168 		.ep_end = -1,
169 	},
170 };
171 
172 static int
173 musbotg_channel_alloc(struct musbotg_softc *sc, struct musbotg_td *td, uint8_t is_tx)
174 {
175 	int ch;
176 	int ep;
177 
178 	ep = td->ep_no;
179 
180 	/* In device mode each EP got its own channel */
181 	if (sc->sc_mode == MUSB2_DEVICE_MODE) {
182 		musbotg_ep_int_set(sc, ep, 1);
183 		return (ep);
184 	}
185 
186 	/*
187 	 * All control transactions go through EP0
188 	 */
189 	if (ep == 0) {
190 		if (sc->sc_channel_mask & (1 << 0))
191 			return (-1);
192 		sc->sc_channel_mask |= (1 << 0);
193 		musbotg_ep_int_set(sc, ep, 1);
194 		return (0);
195 	}
196 
197 	for (ch = sc->sc_ep_max; ch != 0; ch--) {
198 		if (sc->sc_channel_mask & (1 << ch))
199 			continue;
200 
201 		/* check FIFO size requirement */
202 		if (is_tx) {
203 			if (td->max_frame_size >
204 			    sc->sc_hw_ep_profile[ch].max_in_frame_size)
205 				continue;
206 		} else {
207 			if (td->max_frame_size >
208 			    sc->sc_hw_ep_profile[ch].max_out_frame_size)
209 				continue;
210 		}
211 		sc->sc_channel_mask |= (1 << ch);
212 		musbotg_ep_int_set(sc, ch, 1);
213 		return (ch);
214 	}
215 
216 	DPRINTFN(-1, "No available channels. Mask: %04x\n",  sc->sc_channel_mask);
217 
218 	return (-1);
219 }
220 
221 static void
222 musbotg_channel_free(struct musbotg_softc *sc, struct musbotg_td *td)
223 {
224 
225 	DPRINTFN(1, "ep_no=%d\n", td->channel);
226 
227 	if (sc->sc_mode == MUSB2_DEVICE_MODE)
228 		return;
229 
230 	if (td == NULL)
231 		return;
232 	if (td->channel == -1)
233 		return;
234 
235 	musbotg_ep_int_set(sc, td->channel, 0);
236 	sc->sc_channel_mask &= ~(1 << td->channel);
237 
238 	td->channel = -1;
239 }
240 
241 static void
242 musbotg_get_hw_ep_profile(struct usb_device *udev,
243     const struct usb_hw_ep_profile **ppf, uint8_t ep_addr)
244 {
245 	struct musbotg_softc *sc;
246 
247 	sc = MUSBOTG_BUS2SC(udev->bus);
248 
249 	if (ep_addr == 0) {
250 		/* control endpoint */
251 		*ppf = musbotg_ep_profile;
252 	} else if (ep_addr <= sc->sc_ep_max) {
253 		/* other endpoints */
254 		*ppf = sc->sc_hw_ep_profile + ep_addr;
255 	} else {
256 		*ppf = NULL;
257 	}
258 }
259 
260 static void
261 musbotg_clocks_on(struct musbotg_softc *sc)
262 {
263 	if (sc->sc_flags.clocks_off &&
264 	    sc->sc_flags.port_powered) {
265 		DPRINTFN(4, "\n");
266 
267 		if (sc->sc_clocks_on) {
268 			(sc->sc_clocks_on) (sc->sc_clocks_arg);
269 		}
270 		sc->sc_flags.clocks_off = 0;
271 
272 		/* XXX enable Transceiver */
273 	}
274 }
275 
276 static void
277 musbotg_clocks_off(struct musbotg_softc *sc)
278 {
279 	if (!sc->sc_flags.clocks_off) {
280 		DPRINTFN(4, "\n");
281 
282 		/* XXX disable Transceiver */
283 
284 		if (sc->sc_clocks_off) {
285 			(sc->sc_clocks_off) (sc->sc_clocks_arg);
286 		}
287 		sc->sc_flags.clocks_off = 1;
288 	}
289 }
290 
291 static void
292 musbotg_pull_common(struct musbotg_softc *sc, uint8_t on)
293 {
294 	uint8_t temp;
295 
296 	temp = MUSB2_READ_1(sc, MUSB2_REG_POWER);
297 	if (on)
298 		temp |= MUSB2_MASK_SOFTC;
299 	else
300 		temp &= ~MUSB2_MASK_SOFTC;
301 
302 	MUSB2_WRITE_1(sc, MUSB2_REG_POWER, temp);
303 }
304 
305 static void
306 musbotg_pull_up(struct musbotg_softc *sc)
307 {
308 	/* pullup D+, if possible */
309 
310 	if (!sc->sc_flags.d_pulled_up &&
311 	    sc->sc_flags.port_powered) {
312 		sc->sc_flags.d_pulled_up = 1;
313 		musbotg_pull_common(sc, 1);
314 	}
315 }
316 
317 static void
318 musbotg_pull_down(struct musbotg_softc *sc)
319 {
320 	/* pulldown D+, if possible */
321 
322 	if (sc->sc_flags.d_pulled_up) {
323 		sc->sc_flags.d_pulled_up = 0;
324 		musbotg_pull_common(sc, 0);
325 	}
326 }
327 
328 static void
329 musbotg_suspend_host(struct musbotg_softc *sc)
330 {
331 	uint8_t temp;
332 
333 	if (sc->sc_flags.status_suspend) {
334 		return;
335 	}
336 
337 	temp = MUSB2_READ_1(sc, MUSB2_REG_POWER);
338 	temp |= MUSB2_MASK_SUSPMODE;
339 	MUSB2_WRITE_1(sc, MUSB2_REG_POWER, temp);
340 	sc->sc_flags.status_suspend = 1;
341 }
342 
343 static void
344 musbotg_wakeup_host(struct musbotg_softc *sc)
345 {
346 	uint8_t temp;
347 
348 	if (!(sc->sc_flags.status_suspend)) {
349 		return;
350 	}
351 
352 	temp = MUSB2_READ_1(sc, MUSB2_REG_POWER);
353 	temp &= ~MUSB2_MASK_SUSPMODE;
354 	temp |= MUSB2_MASK_RESUME;
355 	MUSB2_WRITE_1(sc, MUSB2_REG_POWER, temp);
356 
357 	/* wait 20 milliseconds */
358 	/* Wait for reset to complete. */
359 	usb_pause_mtx(&sc->sc_bus.bus_mtx, hz / 50);
360 
361 	temp = MUSB2_READ_1(sc, MUSB2_REG_POWER);
362 	temp &= ~MUSB2_MASK_RESUME;
363 	MUSB2_WRITE_1(sc, MUSB2_REG_POWER, temp);
364 
365 	sc->sc_flags.status_suspend = 0;
366 }
367 
368 static void
369 musbotg_wakeup_peer(struct musbotg_softc *sc)
370 {
371 	uint8_t temp;
372 
373 	if (!(sc->sc_flags.status_suspend)) {
374 		return;
375 	}
376 
377 	temp = MUSB2_READ_1(sc, MUSB2_REG_POWER);
378 	temp |= MUSB2_MASK_RESUME;
379 	MUSB2_WRITE_1(sc, MUSB2_REG_POWER, temp);
380 
381 	/* wait 8 milliseconds */
382 	/* Wait for reset to complete. */
383 	usb_pause_mtx(&sc->sc_bus.bus_mtx, hz / 125);
384 
385 	temp = MUSB2_READ_1(sc, MUSB2_REG_POWER);
386 	temp &= ~MUSB2_MASK_RESUME;
387 	MUSB2_WRITE_1(sc, MUSB2_REG_POWER, temp);
388 }
389 
390 static void
391 musbotg_set_address(struct musbotg_softc *sc, uint8_t addr)
392 {
393 	DPRINTFN(4, "addr=%d\n", addr);
394 	addr &= 0x7F;
395 	MUSB2_WRITE_1(sc, MUSB2_REG_FADDR, addr);
396 }
397 
398 static uint8_t
399 musbotg_dev_ctrl_setup_rx(struct musbotg_td *td)
400 {
401 	struct musbotg_softc *sc;
402 	struct usb_device_request req;
403 	uint16_t count;
404 	uint8_t csr;
405 
406 	/* get pointer to softc */
407 	sc = MUSBOTG_PC2SC(td->pc);
408 
409 	if (td->channel == -1)
410 		td->channel = musbotg_channel_alloc(sc, td, 0);
411 
412 	/* EP0 is busy, wait */
413 	if (td->channel == -1)
414 		return (1);
415 
416 	DPRINTFN(1, "ep_no=%d\n", td->channel);
417 
418 	/* select endpoint 0 */
419 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
420 
421 	/* read out FIFO status */
422 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
423 
424 	DPRINTFN(4, "csr=0x%02x\n", csr);
425 
426 	/*
427 	 * NOTE: If DATAEND is set we should not call the
428 	 * callback, hence the status stage is not complete.
429 	 */
430 	if (csr & MUSB2_MASK_CSR0L_DATAEND) {
431 		/* do not stall at this point */
432 		td->did_stall = 1;
433 		/* wait for interrupt */
434 		DPRINTFN(1, "CSR0 DATAEND\n");
435 		goto not_complete;
436 	}
437 
438 	if (csr & MUSB2_MASK_CSR0L_SENTSTALL) {
439 		/* clear SENTSTALL */
440 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
441 		/* get latest status */
442 		csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
443 		/* update EP0 state */
444 		sc->sc_ep0_busy = 0;
445 	}
446 	if (csr & MUSB2_MASK_CSR0L_SETUPEND) {
447 		/* clear SETUPEND */
448 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
449 		    MUSB2_MASK_CSR0L_SETUPEND_CLR);
450 		/* get latest status */
451 		csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
452 		/* update EP0 state */
453 		sc->sc_ep0_busy = 0;
454 	}
455 	if (sc->sc_ep0_busy) {
456 		DPRINTFN(1, "EP0 BUSY\n");
457 		goto not_complete;
458 	}
459 	if (!(csr & MUSB2_MASK_CSR0L_RXPKTRDY)) {
460 		goto not_complete;
461 	}
462 	/* get the packet byte count */
463 	count = MUSB2_READ_2(sc, MUSB2_REG_RXCOUNT);
464 
465 	/* verify data length */
466 	if (count != td->remainder) {
467 		DPRINTFN(1, "Invalid SETUP packet "
468 		    "length, %d bytes\n", count);
469 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
470 		      MUSB2_MASK_CSR0L_RXPKTRDY_CLR);
471 		/* don't clear stall */
472 		td->did_stall = 1;
473 		goto not_complete;
474 	}
475 	if (count != sizeof(req)) {
476 		DPRINTFN(1, "Unsupported SETUP packet "
477 		    "length, %d bytes\n", count);
478 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
479 		      MUSB2_MASK_CSR0L_RXPKTRDY_CLR);
480 		/* don't clear stall */
481 		td->did_stall = 1;
482 		goto not_complete;
483 	}
484 	/* clear did stall flag */
485 	td->did_stall = 0;
486 
487 	/* receive data */
488 	bus_space_read_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
489 	    MUSB2_REG_EPFIFO(0), (void *)&req, sizeof(req));
490 
491 	/* copy data into real buffer */
492 	usbd_copy_in(td->pc, 0, &req, sizeof(req));
493 
494 	td->offset = sizeof(req);
495 	td->remainder = 0;
496 
497 	/* set pending command */
498 	sc->sc_ep0_cmd = MUSB2_MASK_CSR0L_RXPKTRDY_CLR;
499 
500 	/* we need set stall or dataend after this */
501 	sc->sc_ep0_busy = 1;
502 
503 	/* sneak peek the set address */
504 	if ((req.bmRequestType == UT_WRITE_DEVICE) &&
505 	    (req.bRequest == UR_SET_ADDRESS)) {
506 		sc->sc_dv_addr = req.wValue[0] & 0x7F;
507 	} else {
508 		sc->sc_dv_addr = 0xFF;
509 	}
510 
511 	musbotg_channel_free(sc, td);
512 	return (0);			/* complete */
513 
514 not_complete:
515 	/* abort any ongoing transfer */
516 	if (!td->did_stall) {
517 		DPRINTFN(4, "stalling\n");
518 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
519 		    MUSB2_MASK_CSR0L_SENDSTALL);
520 		td->did_stall = 1;
521 	}
522 	return (1);			/* not complete */
523 }
524 
525 static uint8_t
526 musbotg_host_ctrl_setup_tx(struct musbotg_td *td)
527 {
528 	struct musbotg_softc *sc;
529 	struct usb_device_request req;
530 	uint8_t csr, csrh;
531 
532 	/* get pointer to softc */
533 	sc = MUSBOTG_PC2SC(td->pc);
534 
535 	if (td->channel == -1)
536 		td->channel = musbotg_channel_alloc(sc, td, 1);
537 
538 	/* EP0 is busy, wait */
539 	if (td->channel == -1)
540 		return (1);
541 
542 	DPRINTFN(1, "ep_no=%d\n", td->channel);
543 
544 	/* select endpoint 0 */
545 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
546 
547 	/* read out FIFO status */
548 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
549 	DPRINTFN(4, "csr=0x%02x\n", csr);
550 
551 	/* Not ready yet yet */
552 	if (csr & MUSB2_MASK_CSR0L_TXPKTRDY)
553 		return (1);
554 
555 	/* Failed */
556 	if (csr & (MUSB2_MASK_CSR0L_RXSTALL |
557 	    MUSB2_MASK_CSR0L_ERROR))
558 	{
559 		/* Clear status bit */
560 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
561 		DPRINTFN(1, "error bit set, csr=0x%02x\n", csr);
562 		td->error = 1;
563 	}
564 
565 	if (csr & MUSB2_MASK_CSR0L_NAKTIMO) {
566 		DPRINTFN(1, "NAK timeout\n");
567 
568 		if (csr & MUSB2_MASK_CSR0L_TXFIFONEMPTY) {
569 			csrh = MUSB2_READ_1(sc, MUSB2_REG_TXCSRH);
570 			csrh |= MUSB2_MASK_CSR0H_FFLUSH;
571 			MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH, csrh);
572 			csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
573 			if (csr & MUSB2_MASK_CSR0L_TXFIFONEMPTY) {
574 				csrh = MUSB2_READ_1(sc, MUSB2_REG_TXCSRH);
575 				csrh |= MUSB2_MASK_CSR0H_FFLUSH;
576 				MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH, csrh);
577 				csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
578 			}
579 		}
580 
581 		csr &= ~MUSB2_MASK_CSR0L_NAKTIMO;
582 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
583 
584 		td->error = 1;
585 	}
586 
587 	if (td->error) {
588 		musbotg_channel_free(sc, td);
589 		return (0);
590 	}
591 
592 	/* Fifo is not empty and there is no NAK timeout */
593 	if (csr & MUSB2_MASK_CSR0L_TXPKTRDY)
594 		return (1);
595 
596 	/* check if we are complete */
597 	if (td->remainder == 0) {
598 		/* we are complete */
599 		musbotg_channel_free(sc, td);
600 		return (0);
601 	}
602 
603 	/* copy data into real buffer */
604 	usbd_copy_out(td->pc, 0, &req, sizeof(req));
605 
606 	/* send data */
607 	bus_space_write_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
608 	    MUSB2_REG_EPFIFO(0), (void *)&req, sizeof(req));
609 
610 	/* update offset and remainder */
611 	td->offset += sizeof(req);
612 	td->remainder -= sizeof(req);
613 
614 	MUSB2_WRITE_1(sc, MUSB2_REG_TXNAKLIMIT, MAX_NAK_TO);
615 	MUSB2_WRITE_1(sc, MUSB2_REG_TXFADDR(0), td->dev_addr);
616 	MUSB2_WRITE_1(sc, MUSB2_REG_TXHADDR(0), td->haddr);
617 	MUSB2_WRITE_1(sc, MUSB2_REG_TXHUBPORT(0), td->hport);
618 	MUSB2_WRITE_1(sc, MUSB2_REG_TXTI, td->transfer_type);
619 
620 	/* write command */
621 	MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
622 	    MUSB2_MASK_CSR0L_TXPKTRDY |
623 	    MUSB2_MASK_CSR0L_SETUPPKT);
624 
625 	/* Just to be consistent, not used above */
626 	td->transaction_started = 1;
627 
628 	return (1);			/* in progress */
629 }
630 
631 /* Control endpoint only data handling functions (RX/TX/SYNC) */
632 
633 static uint8_t
634 musbotg_dev_ctrl_data_rx(struct musbotg_td *td)
635 {
636 	struct usb_page_search buf_res;
637 	struct musbotg_softc *sc;
638 	uint16_t count;
639 	uint8_t csr;
640 	uint8_t got_short;
641 
642 	/* get pointer to softc */
643 	sc = MUSBOTG_PC2SC(td->pc);
644 
645 	/* select endpoint 0 */
646 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
647 
648 	/* check if a command is pending */
649 	if (sc->sc_ep0_cmd) {
650 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, sc->sc_ep0_cmd);
651 		sc->sc_ep0_cmd = 0;
652 	}
653 	/* read out FIFO status */
654 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
655 
656 	DPRINTFN(4, "csr=0x%02x\n", csr);
657 
658 	got_short = 0;
659 
660 	if (csr & (MUSB2_MASK_CSR0L_SETUPEND |
661 	    MUSB2_MASK_CSR0L_SENTSTALL)) {
662 		if (td->remainder == 0) {
663 			/*
664 			 * We are actually complete and have
665 			 * received the next SETUP
666 			 */
667 			DPRINTFN(4, "faking complete\n");
668 			return (0);	/* complete */
669 		}
670 		/*
671 	         * USB Host Aborted the transfer.
672 	         */
673 		td->error = 1;
674 		return (0);		/* complete */
675 	}
676 	if (!(csr & MUSB2_MASK_CSR0L_RXPKTRDY)) {
677 		return (1);		/* not complete */
678 	}
679 	/* get the packet byte count */
680 	count = MUSB2_READ_2(sc, MUSB2_REG_RXCOUNT);
681 
682 	/* verify the packet byte count */
683 	if (count != td->max_frame_size) {
684 		if (count < td->max_frame_size) {
685 			/* we have a short packet */
686 			td->short_pkt = 1;
687 			got_short = 1;
688 		} else {
689 			/* invalid USB packet */
690 			td->error = 1;
691 			return (0);	/* we are complete */
692 		}
693 	}
694 	/* verify the packet byte count */
695 	if (count > td->remainder) {
696 		/* invalid USB packet */
697 		td->error = 1;
698 		return (0);		/* we are complete */
699 	}
700 	while (count > 0) {
701 		uint32_t temp;
702 
703 		usbd_get_page(td->pc, td->offset, &buf_res);
704 
705 		/* get correct length */
706 		if (buf_res.length > count) {
707 			buf_res.length = count;
708 		}
709 		/* check for unaligned memory address */
710 		if (USB_P2U(buf_res.buffer) & 3) {
711 			temp = count & ~3;
712 
713 			if (temp) {
714 				/* receive data 4 bytes at a time */
715 				bus_space_read_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
716 				    MUSB2_REG_EPFIFO(0), sc->sc_bounce_buf,
717 				    temp / 4);
718 			}
719 			temp = count & 3;
720 			if (temp) {
721 				/* receive data 1 byte at a time */
722 				bus_space_read_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
723 				    MUSB2_REG_EPFIFO(0),
724 				    (void *)(&sc->sc_bounce_buf[count / 4]), temp);
725 			}
726 			usbd_copy_in(td->pc, td->offset,
727 			    sc->sc_bounce_buf, count);
728 
729 			/* update offset and remainder */
730 			td->offset += count;
731 			td->remainder -= count;
732 			break;
733 		}
734 		/* check if we can optimise */
735 		if (buf_res.length >= 4) {
736 			/* receive data 4 bytes at a time */
737 			bus_space_read_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
738 			    MUSB2_REG_EPFIFO(0), buf_res.buffer,
739 			    buf_res.length / 4);
740 
741 			temp = buf_res.length & ~3;
742 
743 			/* update counters */
744 			count -= temp;
745 			td->offset += temp;
746 			td->remainder -= temp;
747 			continue;
748 		}
749 		/* receive data */
750 		bus_space_read_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
751 		    MUSB2_REG_EPFIFO(0), buf_res.buffer, buf_res.length);
752 
753 		/* update counters */
754 		count -= buf_res.length;
755 		td->offset += buf_res.length;
756 		td->remainder -= buf_res.length;
757 	}
758 
759 	/* check if we are complete */
760 	if ((td->remainder == 0) || got_short) {
761 		if (td->short_pkt) {
762 			/* we are complete */
763 			sc->sc_ep0_cmd = MUSB2_MASK_CSR0L_RXPKTRDY_CLR;
764 			return (0);
765 		}
766 		/* else need to receive a zero length packet */
767 	}
768 	/* write command - need more data */
769 	MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
770 	    MUSB2_MASK_CSR0L_RXPKTRDY_CLR);
771 	return (1);			/* not complete */
772 }
773 
774 static uint8_t
775 musbotg_dev_ctrl_data_tx(struct musbotg_td *td)
776 {
777 	struct usb_page_search buf_res;
778 	struct musbotg_softc *sc;
779 	uint16_t count;
780 	uint8_t csr;
781 
782 	/* get pointer to softc */
783 	sc = MUSBOTG_PC2SC(td->pc);
784 
785 	/* select endpoint 0 */
786 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
787 
788 	/* check if a command is pending */
789 	if (sc->sc_ep0_cmd) {
790 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, sc->sc_ep0_cmd);
791 		sc->sc_ep0_cmd = 0;
792 	}
793 	/* read out FIFO status */
794 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
795 
796 	DPRINTFN(4, "csr=0x%02x\n", csr);
797 
798 	if (csr & (MUSB2_MASK_CSR0L_SETUPEND |
799 	    MUSB2_MASK_CSR0L_SENTSTALL)) {
800 		/*
801 	         * The current transfer was aborted
802 	         * by the USB Host
803 	         */
804 		td->error = 1;
805 		return (0);		/* complete */
806 	}
807 	if (csr & MUSB2_MASK_CSR0L_TXPKTRDY) {
808 		return (1);		/* not complete */
809 	}
810 	count = td->max_frame_size;
811 	if (td->remainder < count) {
812 		/* we have a short packet */
813 		td->short_pkt = 1;
814 		count = td->remainder;
815 	}
816 	while (count > 0) {
817 		uint32_t temp;
818 
819 		usbd_get_page(td->pc, td->offset, &buf_res);
820 
821 		/* get correct length */
822 		if (buf_res.length > count) {
823 			buf_res.length = count;
824 		}
825 		/* check for unaligned memory address */
826 		if (USB_P2U(buf_res.buffer) & 3) {
827 			usbd_copy_out(td->pc, td->offset,
828 			    sc->sc_bounce_buf, count);
829 
830 			temp = count & ~3;
831 
832 			if (temp) {
833 				/* transmit data 4 bytes at a time */
834 				bus_space_write_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
835 				    MUSB2_REG_EPFIFO(0), sc->sc_bounce_buf,
836 				    temp / 4);
837 			}
838 			temp = count & 3;
839 			if (temp) {
840 				/* receive data 1 byte at a time */
841 				bus_space_write_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
842 				    MUSB2_REG_EPFIFO(0),
843 				    ((void *)&sc->sc_bounce_buf[count / 4]), temp);
844 			}
845 			/* update offset and remainder */
846 			td->offset += count;
847 			td->remainder -= count;
848 			break;
849 		}
850 		/* check if we can optimise */
851 		if (buf_res.length >= 4) {
852 			/* transmit data 4 bytes at a time */
853 			bus_space_write_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
854 			    MUSB2_REG_EPFIFO(0), buf_res.buffer,
855 			    buf_res.length / 4);
856 
857 			temp = buf_res.length & ~3;
858 
859 			/* update counters */
860 			count -= temp;
861 			td->offset += temp;
862 			td->remainder -= temp;
863 			continue;
864 		}
865 		/* transmit data */
866 		bus_space_write_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
867 		    MUSB2_REG_EPFIFO(0), buf_res.buffer, buf_res.length);
868 
869 		/* update counters */
870 		count -= buf_res.length;
871 		td->offset += buf_res.length;
872 		td->remainder -= buf_res.length;
873 	}
874 
875 	/* check remainder */
876 	if (td->remainder == 0) {
877 		if (td->short_pkt) {
878 			sc->sc_ep0_cmd = MUSB2_MASK_CSR0L_TXPKTRDY;
879 			return (0);	/* complete */
880 		}
881 		/* else we need to transmit a short packet */
882 	}
883 	/* write command */
884 	MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
885 	    MUSB2_MASK_CSR0L_TXPKTRDY);
886 
887 	return (1);			/* not complete */
888 }
889 
890 static uint8_t
891 musbotg_host_ctrl_data_rx(struct musbotg_td *td)
892 {
893 	struct usb_page_search buf_res;
894 	struct musbotg_softc *sc;
895 	uint16_t count;
896 	uint8_t csr;
897 	uint8_t got_short;
898 
899 	/* get pointer to softc */
900 	sc = MUSBOTG_PC2SC(td->pc);
901 
902 	if (td->channel == -1)
903 		td->channel = musbotg_channel_alloc(sc, td, 0);
904 
905 	/* EP0 is busy, wait */
906 	if (td->channel == -1)
907 		return (1);
908 
909 	DPRINTFN(1, "ep_no=%d\n", td->channel);
910 
911 	/* select endpoint 0 */
912 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
913 
914 	/* read out FIFO status */
915 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
916 
917 	DPRINTFN(4, "csr=0x%02x\n", csr);
918 
919 	got_short = 0;
920 	if (!td->transaction_started) {
921 		td->transaction_started = 1;
922 
923 		MUSB2_WRITE_1(sc, MUSB2_REG_RXNAKLIMIT, MAX_NAK_TO);
924 
925 		MUSB2_WRITE_1(sc, MUSB2_REG_RXFADDR(0),
926 		    td->dev_addr);
927 		MUSB2_WRITE_1(sc, MUSB2_REG_RXHADDR(0), td->haddr);
928 		MUSB2_WRITE_1(sc, MUSB2_REG_RXHUBPORT(0), td->hport);
929 		MUSB2_WRITE_1(sc, MUSB2_REG_RXTI, td->transfer_type);
930 
931 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
932 		    MUSB2_MASK_CSR0L_REQPKT);
933 
934 		return (1);
935 	}
936 
937 	if (csr & MUSB2_MASK_CSR0L_NAKTIMO) {
938 		csr &= ~MUSB2_MASK_CSR0L_REQPKT;
939 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
940 
941 		csr &= ~MUSB2_MASK_CSR0L_NAKTIMO;
942 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
943 
944 		td->error = 1;
945 	}
946 
947 	/* Failed */
948 	if (csr & (MUSB2_MASK_CSR0L_RXSTALL |
949 	    MUSB2_MASK_CSR0L_ERROR))
950 	{
951 		/* Clear status bit */
952 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
953 		DPRINTFN(1, "error bit set, csr=0x%02x\n", csr);
954 		td->error = 1;
955 	}
956 
957 	if (td->error) {
958 		musbotg_channel_free(sc, td);
959 		return (0);	/* we are complete */
960 	}
961 
962 	if (!(csr & MUSB2_MASK_CSR0L_RXPKTRDY))
963 		return (1); /* not yet */
964 
965 	/* get the packet byte count */
966 	count = MUSB2_READ_2(sc, MUSB2_REG_RXCOUNT);
967 
968 	/* verify the packet byte count */
969 	if (count != td->max_frame_size) {
970 		if (count < td->max_frame_size) {
971 			/* we have a short packet */
972 			td->short_pkt = 1;
973 			got_short = 1;
974 		} else {
975 			/* invalid USB packet */
976 			td->error = 1;
977 			musbotg_channel_free(sc, td);
978 			return (0);	/* we are complete */
979 		}
980 	}
981 	/* verify the packet byte count */
982 	if (count > td->remainder) {
983 		/* invalid USB packet */
984 		td->error = 1;
985 		musbotg_channel_free(sc, td);
986 		return (0);		/* we are complete */
987 	}
988 	while (count > 0) {
989 		uint32_t temp;
990 
991 		usbd_get_page(td->pc, td->offset, &buf_res);
992 
993 		/* get correct length */
994 		if (buf_res.length > count) {
995 			buf_res.length = count;
996 		}
997 		/* check for unaligned memory address */
998 		if (USB_P2U(buf_res.buffer) & 3) {
999 			temp = count & ~3;
1000 
1001 			if (temp) {
1002 				/* receive data 4 bytes at a time */
1003 				bus_space_read_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
1004 				    MUSB2_REG_EPFIFO(0), sc->sc_bounce_buf,
1005 				    temp / 4);
1006 			}
1007 			temp = count & 3;
1008 			if (temp) {
1009 				/* receive data 1 byte at a time */
1010 				bus_space_read_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
1011 				    MUSB2_REG_EPFIFO(0),
1012 				    (void *)(&sc->sc_bounce_buf[count / 4]), temp);
1013 			}
1014 			usbd_copy_in(td->pc, td->offset,
1015 			    sc->sc_bounce_buf, count);
1016 
1017 			/* update offset and remainder */
1018 			td->offset += count;
1019 			td->remainder -= count;
1020 			break;
1021 		}
1022 		/* check if we can optimise */
1023 		if (buf_res.length >= 4) {
1024 			/* receive data 4 bytes at a time */
1025 			bus_space_read_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
1026 			    MUSB2_REG_EPFIFO(0), buf_res.buffer,
1027 			    buf_res.length / 4);
1028 
1029 			temp = buf_res.length & ~3;
1030 
1031 			/* update counters */
1032 			count -= temp;
1033 			td->offset += temp;
1034 			td->remainder -= temp;
1035 			continue;
1036 		}
1037 		/* receive data */
1038 		bus_space_read_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
1039 		    MUSB2_REG_EPFIFO(0), buf_res.buffer, buf_res.length);
1040 
1041 		/* update counters */
1042 		count -= buf_res.length;
1043 		td->offset += buf_res.length;
1044 		td->remainder -= buf_res.length;
1045 	}
1046 
1047 	csr &= ~MUSB2_MASK_CSR0L_RXPKTRDY;
1048 	MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
1049 
1050 	/* check if we are complete */
1051 	if ((td->remainder == 0) || got_short) {
1052 		if (td->short_pkt) {
1053 			/* we are complete */
1054 
1055 			musbotg_channel_free(sc, td);
1056 			return (0);
1057 		}
1058 		/* else need to receive a zero length packet */
1059 	}
1060 
1061 	td->transaction_started = 1;
1062 	MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
1063 	    MUSB2_MASK_CSR0L_REQPKT);
1064 
1065 	return (1);			/* not complete */
1066 }
1067 
1068 static uint8_t
1069 musbotg_host_ctrl_data_tx(struct musbotg_td *td)
1070 {
1071 	struct usb_page_search buf_res;
1072 	struct musbotg_softc *sc;
1073 	uint16_t count;
1074 	uint8_t csr, csrh;
1075 
1076 	/* get pointer to softc */
1077 	sc = MUSBOTG_PC2SC(td->pc);
1078 
1079 	if (td->channel == -1)
1080 		td->channel = musbotg_channel_alloc(sc, td, 1);
1081 
1082 	/* No free EPs */
1083 	if (td->channel == -1)
1084 		return (1);
1085 
1086 	DPRINTFN(1, "ep_no=%d\n", td->channel);
1087 
1088 	/* select endpoint */
1089 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
1090 
1091 	/* read out FIFO status */
1092 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1093 	DPRINTFN(4, "csr=0x%02x\n", csr);
1094 
1095 	if (csr & (MUSB2_MASK_CSR0L_RXSTALL |
1096 	    MUSB2_MASK_CSR0L_ERROR)) {
1097 		/* clear status bits */
1098 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
1099 		td->error = 1;
1100 	}
1101 
1102 	if (csr & MUSB2_MASK_CSR0L_NAKTIMO ) {
1103 		if (csr & MUSB2_MASK_CSR0L_TXFIFONEMPTY) {
1104 			csrh = MUSB2_READ_1(sc, MUSB2_REG_TXCSRH);
1105 			csrh |= MUSB2_MASK_CSR0H_FFLUSH;
1106 			MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH, csrh);
1107 			csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1108 			if (csr & MUSB2_MASK_CSR0L_TXFIFONEMPTY) {
1109 				csrh = MUSB2_READ_1(sc, MUSB2_REG_TXCSRH);
1110 				csrh |= MUSB2_MASK_CSR0H_FFLUSH;
1111 				MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH, csrh);
1112 				csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1113 			}
1114 		}
1115 
1116 		csr &= ~MUSB2_MASK_CSR0L_NAKTIMO;
1117 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
1118 
1119 		td->error = 1;
1120 	}
1121 
1122 	if (td->error) {
1123 		musbotg_channel_free(sc, td);
1124 		return (0);	/* complete */
1125 	}
1126 
1127 	/*
1128 	 * Wait while FIFO is empty.
1129 	 * Do not flush it because it will cause transactions
1130 	 * with size more then packet size. It might upset
1131 	 * some devices
1132 	 */
1133 	if (csr & MUSB2_MASK_CSR0L_TXFIFONEMPTY)
1134 		return (1);
1135 
1136 	/* Packet still being processed */
1137 	if (csr & MUSB2_MASK_CSR0L_TXPKTRDY)
1138 		return (1);
1139 
1140 	if (td->transaction_started) {
1141 		/* check remainder */
1142 		if (td->remainder == 0) {
1143 			if (td->short_pkt) {
1144 				musbotg_channel_free(sc, td);
1145 				return (0);	/* complete */
1146 			}
1147 			/* else we need to transmit a short packet */
1148 		}
1149 
1150 		/* We're not complete - more transactions required */
1151 		td->transaction_started = 0;
1152 	}
1153 
1154 	/* check for short packet */
1155 	count = td->max_frame_size;
1156 	if (td->remainder < count) {
1157 		/* we have a short packet */
1158 		td->short_pkt = 1;
1159 		count = td->remainder;
1160 	}
1161 
1162 	while (count > 0) {
1163 		uint32_t temp;
1164 
1165 		usbd_get_page(td->pc, td->offset, &buf_res);
1166 
1167 		/* get correct length */
1168 		if (buf_res.length > count) {
1169 			buf_res.length = count;
1170 		}
1171 		/* check for unaligned memory address */
1172 		if (USB_P2U(buf_res.buffer) & 3) {
1173 			usbd_copy_out(td->pc, td->offset,
1174 			    sc->sc_bounce_buf, count);
1175 
1176 			temp = count & ~3;
1177 
1178 			if (temp) {
1179 				/* transmit data 4 bytes at a time */
1180 				bus_space_write_multi_4(sc->sc_io_tag,
1181 				    sc->sc_io_hdl, MUSB2_REG_EPFIFO(0),
1182 				    sc->sc_bounce_buf, temp / 4);
1183 			}
1184 			temp = count & 3;
1185 			if (temp) {
1186 				/* receive data 1 byte at a time */
1187 				bus_space_write_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
1188 				    MUSB2_REG_EPFIFO(0),
1189 				    ((void *)&sc->sc_bounce_buf[count / 4]), temp);
1190 			}
1191 			/* update offset and remainder */
1192 			td->offset += count;
1193 			td->remainder -= count;
1194 			break;
1195 		}
1196 		/* check if we can optimise */
1197 		if (buf_res.length >= 4) {
1198 			/* transmit data 4 bytes at a time */
1199 			bus_space_write_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
1200 			    MUSB2_REG_EPFIFO(0), buf_res.buffer,
1201 			    buf_res.length / 4);
1202 
1203 			temp = buf_res.length & ~3;
1204 
1205 			/* update counters */
1206 			count -= temp;
1207 			td->offset += temp;
1208 			td->remainder -= temp;
1209 			continue;
1210 		}
1211 		/* transmit data */
1212 		bus_space_write_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
1213 		    MUSB2_REG_EPFIFO(0), buf_res.buffer,
1214 		    buf_res.length);
1215 
1216 		/* update counters */
1217 		count -= buf_res.length;
1218 		td->offset += buf_res.length;
1219 		td->remainder -= buf_res.length;
1220 	}
1221 
1222 	/* Function address */
1223 	MUSB2_WRITE_1(sc, MUSB2_REG_TXFADDR(0), td->dev_addr);
1224 	MUSB2_WRITE_1(sc, MUSB2_REG_TXHADDR(0), td->haddr);
1225 	MUSB2_WRITE_1(sc, MUSB2_REG_TXHUBPORT(0), td->hport);
1226 	MUSB2_WRITE_1(sc, MUSB2_REG_TXTI, td->transfer_type);
1227 
1228 	/* TX NAK timeout */
1229 	MUSB2_WRITE_1(sc, MUSB2_REG_TXNAKLIMIT, MAX_NAK_TO);
1230 
1231 	/* write command */
1232 	MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
1233 	    MUSB2_MASK_CSR0L_TXPKTRDY);
1234 
1235 	td->transaction_started = 1;
1236 
1237 	return (1);			/* not complete */
1238 }
1239 
1240 static uint8_t
1241 musbotg_dev_ctrl_status(struct musbotg_td *td)
1242 {
1243 	struct musbotg_softc *sc;
1244 	uint8_t csr;
1245 
1246 	/* get pointer to softc */
1247 	sc = MUSBOTG_PC2SC(td->pc);
1248 
1249 	/* select endpoint 0 */
1250 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
1251 
1252 	if (sc->sc_ep0_busy) {
1253 		sc->sc_ep0_busy = 0;
1254 		sc->sc_ep0_cmd |= MUSB2_MASK_CSR0L_DATAEND;
1255 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, sc->sc_ep0_cmd);
1256 		sc->sc_ep0_cmd = 0;
1257 	}
1258 	/* read out FIFO status */
1259 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1260 
1261 	DPRINTFN(4, "csr=0x%02x\n", csr);
1262 
1263 	if (csr & MUSB2_MASK_CSR0L_DATAEND) {
1264 		/* wait for interrupt */
1265 		return (1);		/* not complete */
1266 	}
1267 	if (sc->sc_dv_addr != 0xFF) {
1268 		/* write function address */
1269 		musbotg_set_address(sc, sc->sc_dv_addr);
1270 	}
1271 
1272 	musbotg_channel_free(sc, td);
1273 	return (0);			/* complete */
1274 }
1275 
1276 static uint8_t
1277 musbotg_host_ctrl_status_rx(struct musbotg_td *td)
1278 {
1279 	struct musbotg_softc *sc;
1280 	uint8_t csr, csrh;
1281 
1282 	/* get pointer to softc */
1283 	sc = MUSBOTG_PC2SC(td->pc);
1284 
1285 	if (td->channel == -1)
1286 		td->channel = musbotg_channel_alloc(sc, td, 0);
1287 
1288 	/* EP0 is busy, wait */
1289 	if (td->channel == -1)
1290 		return (1);
1291 
1292 	DPRINTFN(1, "ep_no=%d\n", td->channel);
1293 
1294 	/* select endpoint 0 */
1295 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
1296 
1297 	if (!td->transaction_started) {
1298 		MUSB2_WRITE_1(sc, MUSB2_REG_RXFADDR(0),
1299 		    td->dev_addr);
1300 
1301 		MUSB2_WRITE_1(sc, MUSB2_REG_RXHADDR(0), td->haddr);
1302 		MUSB2_WRITE_1(sc, MUSB2_REG_RXHUBPORT(0), td->hport);
1303 		MUSB2_WRITE_1(sc, MUSB2_REG_RXTI, td->transfer_type);
1304 
1305 		/* RX NAK timeout */
1306 		MUSB2_WRITE_1(sc, MUSB2_REG_RXNAKLIMIT, MAX_NAK_TO);
1307 
1308 		td->transaction_started = 1;
1309 
1310 		/* Disable PING */
1311 		csrh = MUSB2_READ_1(sc, MUSB2_REG_RXCSRH);
1312 		csrh |= MUSB2_MASK_CSR0H_PING_DIS;
1313 		MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH, csrh);
1314 
1315 		/* write command */
1316 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
1317 		    MUSB2_MASK_CSR0L_STATUSPKT |
1318 		    MUSB2_MASK_CSR0L_REQPKT);
1319 
1320 		return (1); /* Just started */
1321 	}
1322 
1323 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1324 
1325 	DPRINTFN(4, "IN STATUS csr=0x%02x\n", csr);
1326 
1327 	if (csr & MUSB2_MASK_CSR0L_RXPKTRDY) {
1328 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
1329 		    MUSB2_MASK_CSR0L_RXPKTRDY_CLR);
1330 		musbotg_channel_free(sc, td);
1331 		return (0); /* complete */
1332 	}
1333 
1334 	if (csr & MUSB2_MASK_CSR0L_NAKTIMO) {
1335 		csr &= ~ (MUSB2_MASK_CSR0L_STATUSPKT |
1336 		    MUSB2_MASK_CSR0L_REQPKT);
1337 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
1338 
1339 		csr &= ~MUSB2_MASK_CSR0L_NAKTIMO;
1340 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
1341 		td->error = 1;
1342 	}
1343 
1344 	/* Failed */
1345 	if (csr & (MUSB2_MASK_CSR0L_RXSTALL |
1346 	    MUSB2_MASK_CSR0L_ERROR))
1347 	{
1348 		/* Clear status bit */
1349 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
1350 		DPRINTFN(1, "error bit set, csr=0x%02x\n", csr);
1351 		td->error = 1;
1352 	}
1353 
1354 	if (td->error) {
1355 		musbotg_channel_free(sc, td);
1356 		return (0);
1357 	}
1358 
1359 	return (1);			/* Not ready yet */
1360 }
1361 
1362 static uint8_t
1363 musbotg_host_ctrl_status_tx(struct musbotg_td *td)
1364 {
1365 	struct musbotg_softc *sc;
1366 	uint8_t csr;
1367 
1368 	/* get pointer to softc */
1369 	sc = MUSBOTG_PC2SC(td->pc);
1370 
1371 	if (td->channel == -1)
1372 		td->channel = musbotg_channel_alloc(sc, td, 1);
1373 
1374 	/* EP0 is busy, wait */
1375 	if (td->channel == -1)
1376 		return (1);
1377 
1378 	DPRINTFN(1, "ep_no=%d/%d [%d@%d.%d/%02x]\n", td->channel, td->transaction_started,
1379 			td->dev_addr,td->haddr,td->hport, td->transfer_type);
1380 
1381 	/* select endpoint 0 */
1382 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
1383 
1384 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1385 	DPRINTFN(4, "csr=0x%02x\n", csr);
1386 
1387 	/* Not yet */
1388 	if (csr & MUSB2_MASK_CSR0L_TXPKTRDY)
1389 		return (1);
1390 
1391 	/* Failed */
1392 	if (csr & (MUSB2_MASK_CSR0L_RXSTALL |
1393 	    MUSB2_MASK_CSR0L_ERROR))
1394 	{
1395 		/* Clear status bit */
1396 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
1397 		DPRINTFN(1, "error bit set, csr=0x%02x\n", csr);
1398 		td->error = 1;
1399 		musbotg_channel_free(sc, td);
1400 		return (0); /* complete */
1401 	}
1402 
1403 	if (td->transaction_started) {
1404 		musbotg_channel_free(sc, td);
1405 		return (0); /* complete */
1406 	}
1407 
1408 	MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH, MUSB2_MASK_CSR0H_PING_DIS);
1409 
1410 	MUSB2_WRITE_1(sc, MUSB2_REG_TXFADDR(0), td->dev_addr);
1411 	MUSB2_WRITE_1(sc, MUSB2_REG_TXHADDR(0), td->haddr);
1412 	MUSB2_WRITE_1(sc, MUSB2_REG_TXHUBPORT(0), td->hport);
1413 	MUSB2_WRITE_1(sc, MUSB2_REG_TXTI, td->transfer_type);
1414 
1415 	/* TX NAK timeout */
1416 	MUSB2_WRITE_1(sc, MUSB2_REG_TXNAKLIMIT, MAX_NAK_TO);
1417 
1418 	td->transaction_started = 1;
1419 
1420 	/* write command */
1421 	MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
1422 	    MUSB2_MASK_CSR0L_STATUSPKT |
1423 	    MUSB2_MASK_CSR0L_TXPKTRDY);
1424 
1425 	return (1);			/* wait for interrupt */
1426 }
1427 
1428 static uint8_t
1429 musbotg_dev_data_rx(struct musbotg_td *td)
1430 {
1431 	struct usb_page_search buf_res;
1432 	struct musbotg_softc *sc;
1433 	uint16_t count;
1434 	uint8_t csr;
1435 	uint8_t to;
1436 	uint8_t got_short;
1437 
1438 	to = 8;				/* don't loop forever! */
1439 	got_short = 0;
1440 
1441 	/* get pointer to softc */
1442 	sc = MUSBOTG_PC2SC(td->pc);
1443 
1444 	if (td->channel == -1)
1445 		td->channel = musbotg_channel_alloc(sc, td, 0);
1446 
1447 	/* EP0 is busy, wait */
1448 	if (td->channel == -1)
1449 		return (1);
1450 
1451 	/* select endpoint */
1452 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, td->channel);
1453 
1454 repeat:
1455 	/* read out FIFO status */
1456 	csr = MUSB2_READ_1(sc, MUSB2_REG_RXCSRL);
1457 
1458 	DPRINTFN(4, "csr=0x%02x\n", csr);
1459 
1460 	/* clear overrun */
1461 	if (csr & MUSB2_MASK_CSRL_RXOVERRUN) {
1462 		/* make sure we don't clear "RXPKTRDY" */
1463 		MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL,
1464 		    MUSB2_MASK_CSRL_RXPKTRDY);
1465 	}
1466 
1467 	/* check status */
1468 	if (!(csr & MUSB2_MASK_CSRL_RXPKTRDY))
1469 		return (1); /* not complete */
1470 
1471 	/* get the packet byte count */
1472 	count = MUSB2_READ_2(sc, MUSB2_REG_RXCOUNT);
1473 
1474 	DPRINTFN(4, "count=0x%04x\n", count);
1475 
1476 	/*
1477 	 * Check for short or invalid packet:
1478 	 */
1479 	if (count != td->max_frame_size) {
1480 		if (count < td->max_frame_size) {
1481 			/* we have a short packet */
1482 			td->short_pkt = 1;
1483 			got_short = 1;
1484 		} else {
1485 			/* invalid USB packet */
1486 			td->error = 1;
1487 			musbotg_channel_free(sc, td);
1488 			return (0);	/* we are complete */
1489 		}
1490 	}
1491 	/* verify the packet byte count */
1492 	if (count > td->remainder) {
1493 		/* invalid USB packet */
1494 		td->error = 1;
1495 		musbotg_channel_free(sc, td);
1496 		return (0);		/* we are complete */
1497 	}
1498 	while (count > 0) {
1499 		uint32_t temp;
1500 
1501 		usbd_get_page(td->pc, td->offset, &buf_res);
1502 
1503 		/* get correct length */
1504 		if (buf_res.length > count) {
1505 			buf_res.length = count;
1506 		}
1507 		/* check for unaligned memory address */
1508 		if (USB_P2U(buf_res.buffer) & 3) {
1509 			temp = count & ~3;
1510 
1511 			if (temp) {
1512 				/* receive data 4 bytes at a time */
1513 				bus_space_read_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
1514 				    MUSB2_REG_EPFIFO(td->channel), sc->sc_bounce_buf,
1515 				    temp / 4);
1516 			}
1517 			temp = count & 3;
1518 			if (temp) {
1519 				/* receive data 1 byte at a time */
1520 				bus_space_read_multi_1(sc->sc_io_tag,
1521 				    sc->sc_io_hdl, MUSB2_REG_EPFIFO(td->channel),
1522 				    ((void *)&sc->sc_bounce_buf[count / 4]), temp);
1523 			}
1524 			usbd_copy_in(td->pc, td->offset,
1525 			    sc->sc_bounce_buf, count);
1526 
1527 			/* update offset and remainder */
1528 			td->offset += count;
1529 			td->remainder -= count;
1530 			break;
1531 		}
1532 		/* check if we can optimise */
1533 		if (buf_res.length >= 4) {
1534 			/* receive data 4 bytes at a time */
1535 			bus_space_read_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
1536 			    MUSB2_REG_EPFIFO(td->channel), buf_res.buffer,
1537 			    buf_res.length / 4);
1538 
1539 			temp = buf_res.length & ~3;
1540 
1541 			/* update counters */
1542 			count -= temp;
1543 			td->offset += temp;
1544 			td->remainder -= temp;
1545 			continue;
1546 		}
1547 		/* receive data */
1548 		bus_space_read_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
1549 		    MUSB2_REG_EPFIFO(td->channel), buf_res.buffer,
1550 		    buf_res.length);
1551 
1552 		/* update counters */
1553 		count -= buf_res.length;
1554 		td->offset += buf_res.length;
1555 		td->remainder -= buf_res.length;
1556 	}
1557 
1558 	/* clear status bits */
1559 	MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL, 0);
1560 
1561 	/* check if we are complete */
1562 	if ((td->remainder == 0) || got_short) {
1563 		if (td->short_pkt) {
1564 			/* we are complete */
1565 			musbotg_channel_free(sc, td);
1566 			return (0);
1567 		}
1568 		/* else need to receive a zero length packet */
1569 	}
1570 	if (--to) {
1571 		goto repeat;
1572 	}
1573 	return (1);			/* not complete */
1574 }
1575 
1576 static uint8_t
1577 musbotg_dev_data_tx(struct musbotg_td *td)
1578 {
1579 	struct usb_page_search buf_res;
1580 	struct musbotg_softc *sc;
1581 	uint16_t count;
1582 	uint8_t csr;
1583 	uint8_t to;
1584 
1585 	to = 8;				/* don't loop forever! */
1586 
1587 	/* get pointer to softc */
1588 	sc = MUSBOTG_PC2SC(td->pc);
1589 
1590 	if (td->channel == -1)
1591 		td->channel = musbotg_channel_alloc(sc, td, 1);
1592 
1593 	/* EP0 is busy, wait */
1594 	if (td->channel == -1)
1595 		return (1);
1596 
1597 	/* select endpoint */
1598 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, td->channel);
1599 
1600 repeat:
1601 
1602 	/* read out FIFO status */
1603 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1604 
1605 	DPRINTFN(4, "csr=0x%02x\n", csr);
1606 
1607 	if (csr & (MUSB2_MASK_CSRL_TXINCOMP |
1608 	    MUSB2_MASK_CSRL_TXUNDERRUN)) {
1609 		/* clear status bits */
1610 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
1611 	}
1612 	if (csr & MUSB2_MASK_CSRL_TXPKTRDY) {
1613 		return (1);		/* not complete */
1614 	}
1615 	/* check for short packet */
1616 	count = td->max_frame_size;
1617 	if (td->remainder < count) {
1618 		/* we have a short packet */
1619 		td->short_pkt = 1;
1620 		count = td->remainder;
1621 	}
1622 	while (count > 0) {
1623 		uint32_t temp;
1624 
1625 		usbd_get_page(td->pc, td->offset, &buf_res);
1626 
1627 		/* get correct length */
1628 		if (buf_res.length > count) {
1629 			buf_res.length = count;
1630 		}
1631 		/* check for unaligned memory address */
1632 		if (USB_P2U(buf_res.buffer) & 3) {
1633 			usbd_copy_out(td->pc, td->offset,
1634 			    sc->sc_bounce_buf, count);
1635 
1636 			temp = count & ~3;
1637 
1638 			if (temp) {
1639 				/* transmit data 4 bytes at a time */
1640 				bus_space_write_multi_4(sc->sc_io_tag,
1641 				    sc->sc_io_hdl, MUSB2_REG_EPFIFO(td->channel),
1642 				    sc->sc_bounce_buf, temp / 4);
1643 			}
1644 			temp = count & 3;
1645 			if (temp) {
1646 				/* receive data 1 byte at a time */
1647 				bus_space_write_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
1648 				    MUSB2_REG_EPFIFO(td->channel),
1649 				    ((void *)&sc->sc_bounce_buf[count / 4]), temp);
1650 			}
1651 			/* update offset and remainder */
1652 			td->offset += count;
1653 			td->remainder -= count;
1654 			break;
1655 		}
1656 		/* check if we can optimise */
1657 		if (buf_res.length >= 4) {
1658 			/* transmit data 4 bytes at a time */
1659 			bus_space_write_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
1660 			    MUSB2_REG_EPFIFO(td->channel), buf_res.buffer,
1661 			    buf_res.length / 4);
1662 
1663 			temp = buf_res.length & ~3;
1664 
1665 			/* update counters */
1666 			count -= temp;
1667 			td->offset += temp;
1668 			td->remainder -= temp;
1669 			continue;
1670 		}
1671 		/* transmit data */
1672 		bus_space_write_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
1673 		    MUSB2_REG_EPFIFO(td->channel), buf_res.buffer,
1674 		    buf_res.length);
1675 
1676 		/* update counters */
1677 		count -= buf_res.length;
1678 		td->offset += buf_res.length;
1679 		td->remainder -= buf_res.length;
1680 	}
1681 
1682 	/* Max packet size */
1683 	MUSB2_WRITE_2(sc, MUSB2_REG_TXMAXP, td->reg_max_packet);
1684 
1685 	/* write command */
1686 	MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
1687 	    MUSB2_MASK_CSRL_TXPKTRDY);
1688 
1689 	/* check remainder */
1690 	if (td->remainder == 0) {
1691 		if (td->short_pkt) {
1692 			musbotg_channel_free(sc, td);
1693 			return (0);	/* complete */
1694 		}
1695 		/* else we need to transmit a short packet */
1696 	}
1697 	if (--to) {
1698 		goto repeat;
1699 	}
1700 	return (1);			/* not complete */
1701 }
1702 
1703 static uint8_t
1704 musbotg_host_data_rx(struct musbotg_td *td)
1705 {
1706 	struct usb_page_search buf_res;
1707 	struct musbotg_softc *sc;
1708 	uint16_t count;
1709 	uint8_t csr, csrh;
1710 	uint8_t to;
1711 	uint8_t got_short;
1712 
1713 	/* get pointer to softc */
1714 	sc = MUSBOTG_PC2SC(td->pc);
1715 
1716 	if (td->channel == -1)
1717 		td->channel = musbotg_channel_alloc(sc, td, 0);
1718 
1719 	/* No free EPs */
1720 	if (td->channel == -1)
1721 		return (1);
1722 
1723 	DPRINTFN(1, "ep_no=%d\n", td->channel);
1724 
1725 	to = 8;				/* don't loop forever! */
1726 	got_short = 0;
1727 
1728 	/* select endpoint */
1729 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, td->channel);
1730 
1731 repeat:
1732 	/* read out FIFO status */
1733 	csr = MUSB2_READ_1(sc, MUSB2_REG_RXCSRL);
1734 	DPRINTFN(4, "csr=0x%02x\n", csr);
1735 
1736 	if (!td->transaction_started) {
1737 		/* Function address */
1738 		MUSB2_WRITE_1(sc, MUSB2_REG_RXFADDR(td->channel),
1739 		    td->dev_addr);
1740 
1741 		/* SPLIT transaction */
1742 		MUSB2_WRITE_1(sc, MUSB2_REG_RXHADDR(td->channel),
1743 		    td->haddr);
1744 		MUSB2_WRITE_1(sc, MUSB2_REG_RXHUBPORT(td->channel),
1745 		    td->hport);
1746 
1747 		/* RX NAK timeout */
1748 		if (td->transfer_type & MUSB2_MASK_TI_PROTO_ISOC)
1749 			MUSB2_WRITE_1(sc, MUSB2_REG_RXNAKLIMIT, 0);
1750 		else
1751 			MUSB2_WRITE_1(sc, MUSB2_REG_RXNAKLIMIT, MAX_NAK_TO);
1752 
1753 		/* Protocol, speed, device endpoint */
1754 		MUSB2_WRITE_1(sc, MUSB2_REG_RXTI, td->transfer_type);
1755 
1756 		/* Max packet size */
1757 		MUSB2_WRITE_2(sc, MUSB2_REG_RXMAXP, td->reg_max_packet);
1758 
1759 		/* Data Toggle */
1760 		csrh = MUSB2_READ_1(sc, MUSB2_REG_RXCSRH);
1761 		DPRINTFN(4, "csrh=0x%02x\n", csrh);
1762 
1763 		csrh |= MUSB2_MASK_CSRH_RXDT_WREN;
1764 		if (td->toggle)
1765 			csrh |= MUSB2_MASK_CSRH_RXDT_VAL;
1766 		else
1767 			csrh &= ~MUSB2_MASK_CSRH_RXDT_VAL;
1768 
1769 		/* Set data toggle */
1770 		MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH, csrh);
1771 
1772 		/* write command */
1773 		MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL,
1774 		    MUSB2_MASK_CSRL_RXREQPKT);
1775 
1776 		td->transaction_started = 1;
1777 		return (1);
1778 	}
1779 
1780 	/* clear NAK timeout */
1781 	if (csr & MUSB2_MASK_CSRL_RXNAKTO) {
1782 		DPRINTFN(4, "NAK Timeout\n");
1783 		if (csr & MUSB2_MASK_CSRL_RXREQPKT) {
1784 			csr &= ~MUSB2_MASK_CSRL_RXREQPKT;
1785 			MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL, csr);
1786 
1787 			csr &= ~MUSB2_MASK_CSRL_RXNAKTO;
1788 			MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL, csr);
1789 		}
1790 
1791 		td->error = 1;
1792 	}
1793 
1794 	if (csr & MUSB2_MASK_CSRL_RXERROR) {
1795 		DPRINTFN(4, "RXERROR\n");
1796 		td->error = 1;
1797 	}
1798 
1799 	if (csr & MUSB2_MASK_CSRL_RXSTALL) {
1800 		DPRINTFN(4, "RXSTALL\n");
1801 		td->error = 1;
1802 	}
1803 
1804 	if (td->error) {
1805 		musbotg_channel_free(sc, td);
1806 		return (0);	/* we are complete */
1807 	}
1808 
1809 	if (!(csr & MUSB2_MASK_CSRL_RXPKTRDY)) {
1810 		/* No data available yet */
1811 		return (1);
1812 	}
1813 
1814 	td->toggle ^= 1;
1815 	/* get the packet byte count */
1816 	count = MUSB2_READ_2(sc, MUSB2_REG_RXCOUNT);
1817 	DPRINTFN(4, "count=0x%04x\n", count);
1818 
1819 	/*
1820 	 * Check for short or invalid packet:
1821 	 */
1822 	if (count != td->max_frame_size) {
1823 		if (count < td->max_frame_size) {
1824 			/* we have a short packet */
1825 			td->short_pkt = 1;
1826 			got_short = 1;
1827 		} else {
1828 			/* invalid USB packet */
1829 			td->error = 1;
1830 			musbotg_channel_free(sc, td);
1831 			return (0);	/* we are complete */
1832 		}
1833 	}
1834 
1835 	/* verify the packet byte count */
1836 	if (count > td->remainder) {
1837 		/* invalid USB packet */
1838 		td->error = 1;
1839 		musbotg_channel_free(sc, td);
1840 		return (0);		/* we are complete */
1841 	}
1842 
1843 	while (count > 0) {
1844 		uint32_t temp;
1845 
1846 		usbd_get_page(td->pc, td->offset, &buf_res);
1847 
1848 		/* get correct length */
1849 		if (buf_res.length > count) {
1850 			buf_res.length = count;
1851 		}
1852 		/* check for unaligned memory address */
1853 		if (USB_P2U(buf_res.buffer) & 3) {
1854 			temp = count & ~3;
1855 
1856 			if (temp) {
1857 				/* receive data 4 bytes at a time */
1858 				bus_space_read_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
1859 				    MUSB2_REG_EPFIFO(td->channel), sc->sc_bounce_buf,
1860 				    temp / 4);
1861 			}
1862 			temp = count & 3;
1863 			if (temp) {
1864 				/* receive data 1 byte at a time */
1865 				bus_space_read_multi_1(sc->sc_io_tag,
1866 				    sc->sc_io_hdl, MUSB2_REG_EPFIFO(td->channel),
1867 				    ((void *)&sc->sc_bounce_buf[count / 4]), temp);
1868 			}
1869 			usbd_copy_in(td->pc, td->offset,
1870 			    sc->sc_bounce_buf, count);
1871 
1872 			/* update offset and remainder */
1873 			td->offset += count;
1874 			td->remainder -= count;
1875 			break;
1876 		}
1877 		/* check if we can optimise */
1878 		if (buf_res.length >= 4) {
1879 			/* receive data 4 bytes at a time */
1880 			bus_space_read_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
1881 			    MUSB2_REG_EPFIFO(td->channel), buf_res.buffer,
1882 			    buf_res.length / 4);
1883 
1884 			temp = buf_res.length & ~3;
1885 
1886 			/* update counters */
1887 			count -= temp;
1888 			td->offset += temp;
1889 			td->remainder -= temp;
1890 			continue;
1891 		}
1892 		/* receive data */
1893 		bus_space_read_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
1894 		    MUSB2_REG_EPFIFO(td->channel), buf_res.buffer,
1895 		    buf_res.length);
1896 
1897 		/* update counters */
1898 		count -= buf_res.length;
1899 		td->offset += buf_res.length;
1900 		td->remainder -= buf_res.length;
1901 	}
1902 
1903 	/* clear status bits */
1904 	MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL, 0);
1905 
1906 	/* check if we are complete */
1907 	if ((td->remainder == 0) || got_short) {
1908 		if (td->short_pkt) {
1909 			/* we are complete */
1910 			musbotg_channel_free(sc, td);
1911 			return (0);
1912 		}
1913 		/* else need to receive a zero length packet */
1914 	}
1915 
1916 	/* Reset transaction state and restart */
1917 	td->transaction_started = 0;
1918 
1919 	if (--to)
1920 		goto repeat;
1921 
1922 	return (1);			/* not complete */
1923 }
1924 
1925 static uint8_t
1926 musbotg_host_data_tx(struct musbotg_td *td)
1927 {
1928 	struct usb_page_search buf_res;
1929 	struct musbotg_softc *sc;
1930 	uint16_t count;
1931 	uint8_t csr, csrh;
1932 
1933 	/* get pointer to softc */
1934 	sc = MUSBOTG_PC2SC(td->pc);
1935 
1936 	if (td->channel == -1)
1937 		td->channel = musbotg_channel_alloc(sc, td, 1);
1938 
1939 	/* No free EPs */
1940 	if (td->channel == -1)
1941 		return (1);
1942 
1943 	DPRINTFN(1, "ep_no=%d\n", td->channel);
1944 
1945 	/* select endpoint */
1946 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, td->channel);
1947 
1948 	/* read out FIFO status */
1949 	csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1950 	DPRINTFN(4, "csr=0x%02x\n", csr);
1951 
1952 	if (csr & (MUSB2_MASK_CSRL_TXSTALLED |
1953 	    MUSB2_MASK_CSRL_TXERROR)) {
1954 		/* clear status bits */
1955 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
1956 		td->error = 1;
1957 		musbotg_channel_free(sc, td);
1958 		return (0);	/* complete */
1959 	}
1960 
1961 	if (csr & MUSB2_MASK_CSRL_TXNAKTO) {
1962 		/*
1963 		 * Flush TX FIFO before clearing NAK TO
1964 		 */
1965 		if (csr & MUSB2_MASK_CSRL_TXFIFONEMPTY) {
1966 			csr |= MUSB2_MASK_CSRL_TXFFLUSH;
1967 			MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
1968 			csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1969 			if (csr & MUSB2_MASK_CSRL_TXFIFONEMPTY) {
1970 				csr |= MUSB2_MASK_CSRL_TXFFLUSH;
1971 				MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
1972 				csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
1973 			}
1974 		}
1975 
1976 		csr &= ~MUSB2_MASK_CSRL_TXNAKTO;
1977 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, csr);
1978 
1979 		td->error = 1;
1980 		musbotg_channel_free(sc, td);
1981 		return (0);	/* complete */
1982 	}
1983 
1984 	/*
1985 	 * Wait while FIFO is empty.
1986 	 * Do not flush it because it will cause transactions
1987 	 * with size more then packet size. It might upset
1988 	 * some devices
1989 	 */
1990 	if (csr & MUSB2_MASK_CSRL_TXFIFONEMPTY)
1991 		return (1);
1992 
1993 	/* Packet still being processed */
1994 	if (csr & MUSB2_MASK_CSRL_TXPKTRDY)
1995 		return (1);
1996 
1997 	if (td->transaction_started) {
1998 		/* check remainder */
1999 		if (td->remainder == 0) {
2000 			if (td->short_pkt) {
2001 				musbotg_channel_free(sc, td);
2002 				return (0);	/* complete */
2003 			}
2004 			/* else we need to transmit a short packet */
2005 		}
2006 
2007 		/* We're not complete - more transactions required */
2008 		td->transaction_started = 0;
2009 	}
2010 
2011 	/* check for short packet */
2012 	count = td->max_frame_size;
2013 	if (td->remainder < count) {
2014 		/* we have a short packet */
2015 		td->short_pkt = 1;
2016 		count = td->remainder;
2017 	}
2018 
2019 	while (count > 0) {
2020 		uint32_t temp;
2021 
2022 		usbd_get_page(td->pc, td->offset, &buf_res);
2023 
2024 		/* get correct length */
2025 		if (buf_res.length > count) {
2026 			buf_res.length = count;
2027 		}
2028 		/* check for unaligned memory address */
2029 		if (USB_P2U(buf_res.buffer) & 3) {
2030 			usbd_copy_out(td->pc, td->offset,
2031 			    sc->sc_bounce_buf, count);
2032 
2033 			temp = count & ~3;
2034 
2035 			if (temp) {
2036 				/* transmit data 4 bytes at a time */
2037 				bus_space_write_multi_4(sc->sc_io_tag,
2038 				    sc->sc_io_hdl, MUSB2_REG_EPFIFO(td->channel),
2039 				    sc->sc_bounce_buf, temp / 4);
2040 			}
2041 			temp = count & 3;
2042 			if (temp) {
2043 				/* receive data 1 byte at a time */
2044 				bus_space_write_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
2045 				    MUSB2_REG_EPFIFO(td->channel),
2046 				    ((void *)&sc->sc_bounce_buf[count / 4]), temp);
2047 			}
2048 			/* update offset and remainder */
2049 			td->offset += count;
2050 			td->remainder -= count;
2051 			break;
2052 		}
2053 		/* check if we can optimise */
2054 		if (buf_res.length >= 4) {
2055 			/* transmit data 4 bytes at a time */
2056 			bus_space_write_multi_4(sc->sc_io_tag, sc->sc_io_hdl,
2057 			    MUSB2_REG_EPFIFO(td->channel), buf_res.buffer,
2058 			    buf_res.length / 4);
2059 
2060 			temp = buf_res.length & ~3;
2061 
2062 			/* update counters */
2063 			count -= temp;
2064 			td->offset += temp;
2065 			td->remainder -= temp;
2066 			continue;
2067 		}
2068 		/* transmit data */
2069 		bus_space_write_multi_1(sc->sc_io_tag, sc->sc_io_hdl,
2070 		    MUSB2_REG_EPFIFO(td->channel), buf_res.buffer,
2071 		    buf_res.length);
2072 
2073 		/* update counters */
2074 		count -= buf_res.length;
2075 		td->offset += buf_res.length;
2076 		td->remainder -= buf_res.length;
2077 	}
2078 
2079 	/* Function address */
2080 	MUSB2_WRITE_1(sc, MUSB2_REG_TXFADDR(td->channel),
2081 	    td->dev_addr);
2082 
2083 	/* SPLIT transaction */
2084 	MUSB2_WRITE_1(sc, MUSB2_REG_TXHADDR(td->channel),
2085 	    td->haddr);
2086 	MUSB2_WRITE_1(sc, MUSB2_REG_TXHUBPORT(td->channel),
2087 	    td->hport);
2088 
2089 	/* TX NAK timeout */
2090 	if (td->transfer_type & MUSB2_MASK_TI_PROTO_ISOC)
2091 		MUSB2_WRITE_1(sc, MUSB2_REG_TXNAKLIMIT, 0);
2092 	else
2093 		MUSB2_WRITE_1(sc, MUSB2_REG_TXNAKLIMIT, MAX_NAK_TO);
2094 
2095 	/* Protocol, speed, device endpoint */
2096 	MUSB2_WRITE_1(sc, MUSB2_REG_TXTI, td->transfer_type);
2097 
2098 	/* Max packet size */
2099 	MUSB2_WRITE_2(sc, MUSB2_REG_TXMAXP, td->reg_max_packet);
2100 
2101 	if (!td->transaction_started) {
2102 		csrh = MUSB2_READ_1(sc, MUSB2_REG_TXCSRH);
2103 		DPRINTFN(4, "csrh=0x%02x\n", csrh);
2104 
2105 		csrh |= MUSB2_MASK_CSRH_TXDT_WREN;
2106 		if (td->toggle)
2107 			csrh |= MUSB2_MASK_CSRH_TXDT_VAL;
2108 		else
2109 			csrh &= ~MUSB2_MASK_CSRH_TXDT_VAL;
2110 
2111 		/* Set data toggle */
2112 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH, csrh);
2113 	}
2114 
2115 	/* write command */
2116 	MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
2117 	    MUSB2_MASK_CSRL_TXPKTRDY);
2118 
2119 	/* Update Data Toggle */
2120 	td->toggle ^= 1;
2121 	td->transaction_started = 1;
2122 
2123 	return (1);			/* not complete */
2124 }
2125 
2126 static uint8_t
2127 musbotg_xfer_do_fifo(struct usb_xfer *xfer)
2128 {
2129 	struct musbotg_td *td;
2130 
2131 	DPRINTFN(8, "\n");
2132 	td = xfer->td_transfer_cache;
2133 	while (1) {
2134 		if ((td->func) (td)) {
2135 			/* operation in progress */
2136 			break;
2137 		}
2138 
2139 		if (((void *)td) == xfer->td_transfer_last) {
2140 			goto done;
2141 		}
2142 		if (td->error) {
2143 			goto done;
2144 		} else if (td->remainder > 0) {
2145 			/*
2146 			 * We had a short transfer. If there is no alternate
2147 			 * next, stop processing !
2148 			 */
2149 			if (!td->alt_next) {
2150 				goto done;
2151 			}
2152 		}
2153 		/*
2154 		 * Fetch the next transfer descriptor and transfer
2155 		 * some flags to the next transfer descriptor
2156 		 */
2157 		td = td->obj_next;
2158 		xfer->td_transfer_cache = td;
2159 	}
2160 
2161 	return (1);			/* not complete */
2162 done:
2163 	/* compute all actual lengths */
2164 	musbotg_standard_done(xfer);
2165 
2166 	return (0);			/* complete */
2167 }
2168 
2169 static void
2170 musbotg_interrupt_poll(struct musbotg_softc *sc)
2171 {
2172 	struct usb_xfer *xfer;
2173 
2174 repeat:
2175 	TAILQ_FOREACH(xfer, &sc->sc_bus.intr_q.head, wait_entry) {
2176 		if (!musbotg_xfer_do_fifo(xfer)) {
2177 			/* queue has been modified */
2178 			goto repeat;
2179 		}
2180 	}
2181 }
2182 
2183 void
2184 musbotg_vbus_interrupt(struct musbotg_softc *sc, uint8_t is_on)
2185 {
2186 	DPRINTFN(4, "vbus = %u\n", is_on);
2187 
2188 	USB_BUS_LOCK(&sc->sc_bus);
2189 	if (is_on) {
2190 		if (!sc->sc_flags.status_vbus) {
2191 			sc->sc_flags.status_vbus = 1;
2192 
2193 			/* complete root HUB interrupt endpoint */
2194 			musbotg_root_intr(sc);
2195 		}
2196 	} else {
2197 		if (sc->sc_flags.status_vbus) {
2198 			sc->sc_flags.status_vbus = 0;
2199 			sc->sc_flags.status_bus_reset = 0;
2200 			sc->sc_flags.status_suspend = 0;
2201 			sc->sc_flags.change_suspend = 0;
2202 			sc->sc_flags.change_connect = 1;
2203 
2204 			/* complete root HUB interrupt endpoint */
2205 			musbotg_root_intr(sc);
2206 		}
2207 	}
2208 
2209 	USB_BUS_UNLOCK(&sc->sc_bus);
2210 }
2211 
2212 void
2213 musbotg_connect_interrupt(struct musbotg_softc *sc)
2214 {
2215 	USB_BUS_LOCK(&sc->sc_bus);
2216 	sc->sc_flags.change_connect = 1;
2217 
2218 	/* complete root HUB interrupt endpoint */
2219 	musbotg_root_intr(sc);
2220 	USB_BUS_UNLOCK(&sc->sc_bus);
2221 }
2222 
2223 void
2224 musbotg_interrupt(struct musbotg_softc *sc,
2225     uint16_t rxstat, uint16_t txstat, uint8_t stat)
2226 {
2227 	uint16_t rx_status;
2228 	uint16_t tx_status;
2229 	uint8_t usb_status;
2230 	uint8_t temp;
2231 	uint8_t to = 2;
2232 
2233 	USB_BUS_LOCK(&sc->sc_bus);
2234 
2235 repeat:
2236 
2237 	/* read all interrupt registers */
2238 	usb_status = MUSB2_READ_1(sc, MUSB2_REG_INTUSB);
2239 
2240 	/* read all FIFO interrupts */
2241 	rx_status = MUSB2_READ_2(sc, MUSB2_REG_INTRX);
2242 	tx_status = MUSB2_READ_2(sc, MUSB2_REG_INTTX);
2243 	rx_status |= rxstat;
2244 	tx_status |= txstat;
2245 	usb_status |= stat;
2246 
2247 	/* Clear platform flags after first time */
2248 	rxstat = 0;
2249 	txstat = 0;
2250 	stat = 0;
2251 
2252 	/* check for any bus state change interrupts */
2253 
2254 	if (usb_status & (MUSB2_MASK_IRESET |
2255 	    MUSB2_MASK_IRESUME | MUSB2_MASK_ISUSP |
2256 	    MUSB2_MASK_ICONN | MUSB2_MASK_IDISC |
2257 	    MUSB2_MASK_IVBUSERR)) {
2258 		DPRINTFN(4, "real bus interrupt 0x%08x\n", usb_status);
2259 
2260 		if (usb_status & MUSB2_MASK_IRESET) {
2261 			/* set correct state */
2262 			sc->sc_flags.status_bus_reset = 1;
2263 			sc->sc_flags.status_suspend = 0;
2264 			sc->sc_flags.change_suspend = 0;
2265 			sc->sc_flags.change_connect = 1;
2266 
2267 			/* determine line speed */
2268 			temp = MUSB2_READ_1(sc, MUSB2_REG_POWER);
2269 			if (temp & MUSB2_MASK_HSMODE)
2270 				sc->sc_flags.status_high_speed = 1;
2271 			else
2272 				sc->sc_flags.status_high_speed = 0;
2273 
2274 			/*
2275 			 * After reset all interrupts are on and we need to
2276 			 * turn them off!
2277 			 */
2278 			temp = MUSB2_MASK_IRESET;
2279 			/* disable resume interrupt */
2280 			temp &= ~MUSB2_MASK_IRESUME;
2281 			/* enable suspend interrupt */
2282 			temp |= MUSB2_MASK_ISUSP;
2283 			MUSB2_WRITE_1(sc, MUSB2_REG_INTUSBE, temp);
2284 			/* disable TX and RX interrupts */
2285 			MUSB2_WRITE_2(sc, MUSB2_REG_INTTXE, 0);
2286 			MUSB2_WRITE_2(sc, MUSB2_REG_INTRXE, 0);
2287 		}
2288 		/*
2289 	         * If RXRSM and RXSUSP is set at the same time we interpret
2290 	         * that like RESUME. Resume is set when there is at least 3
2291 	         * milliseconds of inactivity on the USB BUS.
2292 	         */
2293 		if (usb_status & MUSB2_MASK_IRESUME) {
2294 			if (sc->sc_flags.status_suspend) {
2295 				sc->sc_flags.status_suspend = 0;
2296 				sc->sc_flags.change_suspend = 1;
2297 
2298 				temp = MUSB2_READ_1(sc, MUSB2_REG_INTUSBE);
2299 				/* disable resume interrupt */
2300 				temp &= ~MUSB2_MASK_IRESUME;
2301 				/* enable suspend interrupt */
2302 				temp |= MUSB2_MASK_ISUSP;
2303 				MUSB2_WRITE_1(sc, MUSB2_REG_INTUSBE, temp);
2304 			}
2305 		} else if (usb_status & MUSB2_MASK_ISUSP) {
2306 			if (!sc->sc_flags.status_suspend) {
2307 				sc->sc_flags.status_suspend = 1;
2308 				sc->sc_flags.change_suspend = 1;
2309 
2310 				temp = MUSB2_READ_1(sc, MUSB2_REG_INTUSBE);
2311 				/* disable suspend interrupt */
2312 				temp &= ~MUSB2_MASK_ISUSP;
2313 				/* enable resume interrupt */
2314 				temp |= MUSB2_MASK_IRESUME;
2315 				MUSB2_WRITE_1(sc, MUSB2_REG_INTUSBE, temp);
2316 			}
2317 		}
2318 		if (usb_status &
2319 		    (MUSB2_MASK_ICONN | MUSB2_MASK_IDISC))
2320 			sc->sc_flags.change_connect = 1;
2321 
2322 		/*
2323 		 * Host Mode: There is no IRESET so assume bus is
2324 		 * always in reset state once device is connected.
2325 		 */
2326 		if (sc->sc_mode == MUSB2_HOST_MODE) {
2327 		    /* check for VBUS error in USB host mode */
2328 		    if (usb_status & MUSB2_MASK_IVBUSERR) {
2329 			temp = MUSB2_READ_1(sc, MUSB2_REG_DEVCTL);
2330 			temp |= MUSB2_MASK_SESS;
2331 			MUSB2_WRITE_1(sc, MUSB2_REG_DEVCTL, temp);
2332 		    }
2333 		    if (usb_status & MUSB2_MASK_ICONN)
2334 			sc->sc_flags.status_bus_reset = 1;
2335 		    if (usb_status & MUSB2_MASK_IDISC)
2336 			sc->sc_flags.status_bus_reset = 0;
2337 		}
2338 
2339 		/* complete root HUB interrupt endpoint */
2340 		musbotg_root_intr(sc);
2341 	}
2342 	/* check for any endpoint interrupts */
2343 
2344 	if (rx_status || tx_status) {
2345 		DPRINTFN(4, "real endpoint interrupt "
2346 		    "rx=0x%04x, tx=0x%04x\n", rx_status, tx_status);
2347 	}
2348 	/* poll one time regardless of FIFO status */
2349 
2350 	musbotg_interrupt_poll(sc);
2351 
2352 	if (--to)
2353 		goto repeat;
2354 
2355 	USB_BUS_UNLOCK(&sc->sc_bus);
2356 }
2357 
2358 static void
2359 musbotg_setup_standard_chain_sub(struct musbotg_std_temp *temp)
2360 {
2361 	struct musbotg_td *td;
2362 
2363 	/* get current Transfer Descriptor */
2364 	td = temp->td_next;
2365 	temp->td = td;
2366 
2367 	/* prepare for next TD */
2368 	temp->td_next = td->obj_next;
2369 
2370 	/* fill out the Transfer Descriptor */
2371 	td->func = temp->func;
2372 	td->pc = temp->pc;
2373 	td->offset = temp->offset;
2374 	td->remainder = temp->len;
2375 	td->error = 0;
2376 	td->transaction_started = 0;
2377 	td->did_stall = temp->did_stall;
2378 	td->short_pkt = temp->short_pkt;
2379 	td->alt_next = temp->setup_alt_next;
2380 	td->channel = temp->channel;
2381 	td->dev_addr = temp->dev_addr;
2382 	td->haddr = temp->haddr;
2383 	td->hport = temp->hport;
2384 	td->transfer_type = temp->transfer_type;
2385 }
2386 
2387 static void
2388 musbotg_setup_standard_chain(struct usb_xfer *xfer)
2389 {
2390 	struct musbotg_std_temp temp;
2391 	struct musbotg_softc *sc;
2392 	struct musbotg_td *td;
2393 	uint32_t x;
2394 	uint8_t ep_no;
2395 	uint8_t xfer_type;
2396 	enum usb_dev_speed speed;
2397 	int tx;
2398 	int dev_addr;
2399 
2400 	DPRINTFN(8, "addr=%d endpt=%d sumlen=%d speed=%d\n",
2401 	    xfer->address, UE_GET_ADDR(xfer->endpointno),
2402 	    xfer->sumlen, usbd_get_speed(xfer->xroot->udev));
2403 
2404 	sc = MUSBOTG_BUS2SC(xfer->xroot->bus);
2405 	ep_no = (xfer->endpointno & UE_ADDR);
2406 
2407 	temp.max_frame_size = xfer->max_frame_size;
2408 
2409 	td = xfer->td_start[0];
2410 	xfer->td_transfer_first = td;
2411 	xfer->td_transfer_cache = td;
2412 
2413 	/* setup temp */
2414 	dev_addr = xfer->address;
2415 
2416 	xfer_type = xfer->endpoint->edesc->bmAttributes & UE_XFERTYPE;
2417 
2418 	temp.pc = NULL;
2419 	temp.td = NULL;
2420 	temp.td_next = xfer->td_start[0];
2421 	temp.offset = 0;
2422 	temp.setup_alt_next = xfer->flags_int.short_frames_ok ||
2423 	    xfer->flags_int.isochronous_xfr;
2424 	temp.did_stall = !xfer->flags_int.control_stall;
2425 	temp.channel = -1;
2426 	temp.dev_addr = dev_addr;
2427 	temp.haddr = xfer->xroot->udev->hs_hub_addr;
2428 	temp.hport = xfer->xroot->udev->hs_port_no;
2429 
2430 	if (xfer->flags_int.usb_mode == USB_MODE_HOST) {
2431 		speed =  usbd_get_speed(xfer->xroot->udev);
2432 
2433 		switch (speed) {
2434 			case USB_SPEED_LOW:
2435 				temp.transfer_type = MUSB2_MASK_TI_SPEED_LO;
2436 				break;
2437 			case USB_SPEED_FULL:
2438 				temp.transfer_type = MUSB2_MASK_TI_SPEED_FS;
2439 				break;
2440 			case USB_SPEED_HIGH:
2441 				temp.transfer_type = MUSB2_MASK_TI_SPEED_HS;
2442 				break;
2443 			default:
2444 				temp.transfer_type = 0;
2445 				DPRINTFN(-1, "Invalid USB speed: %d\n", speed);
2446 				break;
2447 		}
2448 
2449 		switch (xfer_type) {
2450 			case UE_CONTROL:
2451 				temp.transfer_type |= MUSB2_MASK_TI_PROTO_CTRL;
2452 				break;
2453 			case UE_ISOCHRONOUS:
2454 				temp.transfer_type |= MUSB2_MASK_TI_PROTO_ISOC;
2455 				break;
2456 			case UE_BULK:
2457 				temp.transfer_type |= MUSB2_MASK_TI_PROTO_BULK;
2458 				break;
2459 			case UE_INTERRUPT:
2460 				temp.transfer_type |= MUSB2_MASK_TI_PROTO_INTR;
2461 				break;
2462 			default:
2463 				DPRINTFN(-1, "Invalid USB transfer type: %d\n",
2464 						xfer_type);
2465 				break;
2466 		}
2467 
2468 		temp.transfer_type |= ep_no;
2469 		td->toggle = xfer->endpoint->toggle_next;
2470 	}
2471 
2472 	/* check if we should prepend a setup message */
2473 
2474 	if (xfer->flags_int.control_xfr) {
2475 		if (xfer->flags_int.control_hdr) {
2476 			if (xfer->flags_int.usb_mode == USB_MODE_DEVICE)
2477 				temp.func = &musbotg_dev_ctrl_setup_rx;
2478 			else
2479 				temp.func = &musbotg_host_ctrl_setup_tx;
2480 
2481 			temp.len = xfer->frlengths[0];
2482 			temp.pc = xfer->frbuffers + 0;
2483 			temp.short_pkt = temp.len ? 1 : 0;
2484 
2485 			musbotg_setup_standard_chain_sub(&temp);
2486 		}
2487 		x = 1;
2488 	} else {
2489 		x = 0;
2490 	}
2491 
2492 	tx = 0;
2493 
2494 	if (x != xfer->nframes) {
2495 		if (xfer->endpointno & UE_DIR_IN)
2496 		    	tx = 1;
2497 
2498 		if (xfer->flags_int.usb_mode == USB_MODE_HOST) {
2499 			tx = !tx;
2500 
2501 			if (tx) {
2502 				if (xfer->flags_int.control_xfr)
2503 					temp.func = &musbotg_host_ctrl_data_tx;
2504 				else
2505 					temp.func = &musbotg_host_data_tx;
2506 			} else {
2507 				if (xfer->flags_int.control_xfr)
2508 					temp.func = &musbotg_host_ctrl_data_rx;
2509 				else
2510 					temp.func = &musbotg_host_data_rx;
2511 			}
2512 
2513 		} else {
2514 			if (tx) {
2515 				if (xfer->flags_int.control_xfr)
2516 					temp.func = &musbotg_dev_ctrl_data_tx;
2517 				else
2518 					temp.func = &musbotg_dev_data_tx;
2519 			} else {
2520 				if (xfer->flags_int.control_xfr)
2521 					temp.func = &musbotg_dev_ctrl_data_rx;
2522 				else
2523 					temp.func = &musbotg_dev_data_rx;
2524 			}
2525 		}
2526 
2527 		/* setup "pc" pointer */
2528 		temp.pc = xfer->frbuffers + x;
2529 	}
2530 	while (x != xfer->nframes) {
2531 		/* DATA0 / DATA1 message */
2532 
2533 		temp.len = xfer->frlengths[x];
2534 
2535 		x++;
2536 
2537 		if (x == xfer->nframes) {
2538 			if (xfer->flags_int.control_xfr) {
2539 				if (xfer->flags_int.control_act) {
2540 					temp.setup_alt_next = 0;
2541 				}
2542 			} else {
2543 				temp.setup_alt_next = 0;
2544 			}
2545 		}
2546 		if (temp.len == 0) {
2547 			/* make sure that we send an USB packet */
2548 
2549 			temp.short_pkt = 0;
2550 
2551 		} else {
2552 			if (xfer->flags_int.isochronous_xfr) {
2553 				/* isochronous data transfer */
2554 				/* don't force short */
2555 				temp.short_pkt = 1;
2556 			} else {
2557 				/* regular data transfer */
2558 				temp.short_pkt = (xfer->flags.force_short_xfer ? 0 : 1);
2559 			}
2560 		}
2561 
2562 		musbotg_setup_standard_chain_sub(&temp);
2563 
2564 		if (xfer->flags_int.isochronous_xfr) {
2565 			temp.offset += temp.len;
2566 		} else {
2567 			/* get next Page Cache pointer */
2568 			temp.pc = xfer->frbuffers + x;
2569 		}
2570 	}
2571 
2572 	/* check for control transfer */
2573 	if (xfer->flags_int.control_xfr) {
2574 		/* always setup a valid "pc" pointer for status and sync */
2575 		temp.pc = xfer->frbuffers + 0;
2576 		temp.len = 0;
2577 		temp.short_pkt = 0;
2578 		temp.setup_alt_next = 0;
2579 
2580 		/* check if we should append a status stage */
2581 		if (!xfer->flags_int.control_act) {
2582 			/*
2583 			 * Send a DATA1 message and invert the current
2584 			 * endpoint direction.
2585 			 */
2586 			if (sc->sc_mode == MUSB2_DEVICE_MODE)
2587 				temp.func = &musbotg_dev_ctrl_status;
2588 			else {
2589 				if (xfer->endpointno & UE_DIR_IN)
2590 					temp.func = musbotg_host_ctrl_status_tx;
2591 				else
2592 					temp.func = musbotg_host_ctrl_status_rx;
2593 			}
2594 			musbotg_setup_standard_chain_sub(&temp);
2595 		}
2596 	}
2597 	/* must have at least one frame! */
2598 	td = temp.td;
2599 	xfer->td_transfer_last = td;
2600 }
2601 
2602 static void
2603 musbotg_timeout(void *arg)
2604 {
2605 	struct usb_xfer *xfer = arg;
2606 
2607 	DPRINTFN(1, "xfer=%p\n", xfer);
2608 
2609 	USB_BUS_LOCK_ASSERT(xfer->xroot->bus, MA_OWNED);
2610 
2611 	/* transfer is transferred */
2612 	musbotg_device_done(xfer, USB_ERR_TIMEOUT);
2613 }
2614 
2615 static void
2616 musbotg_ep_int_set(struct musbotg_softc *sc, int channel, int on)
2617 {
2618 	uint16_t temp;
2619 
2620 	/*
2621 	 * Only enable the endpoint interrupt when we are
2622 	 * actually waiting for data, hence we are dealing
2623 	 * with level triggered interrupts !
2624 	 */
2625 	DPRINTFN(1, "ep_no=%d, on=%d\n", channel, on);
2626 
2627 	if (channel == -1)
2628 		return;
2629 
2630 	if (channel == 0) {
2631 		temp = MUSB2_READ_2(sc, MUSB2_REG_INTTXE);
2632 		if (on)
2633 			temp |= MUSB2_MASK_EPINT(0);
2634 		else
2635 			temp &= ~MUSB2_MASK_EPINT(0);
2636 
2637 		MUSB2_WRITE_2(sc, MUSB2_REG_INTTXE, temp);
2638 	} else {
2639 		temp = MUSB2_READ_2(sc, MUSB2_REG_INTRXE);
2640 		if (on)
2641 			temp |= MUSB2_MASK_EPINT(channel);
2642 		else
2643 			temp &= ~MUSB2_MASK_EPINT(channel);
2644 		MUSB2_WRITE_2(sc, MUSB2_REG_INTRXE, temp);
2645 
2646 		temp = MUSB2_READ_2(sc, MUSB2_REG_INTTXE);
2647 		if (on)
2648 			temp |= MUSB2_MASK_EPINT(channel);
2649 		else
2650 			temp &= ~MUSB2_MASK_EPINT(channel);
2651 		MUSB2_WRITE_2(sc, MUSB2_REG_INTTXE, temp);
2652 	}
2653 
2654 	if (sc->sc_ep_int_set)
2655 		sc->sc_ep_int_set(sc, channel, on);
2656 }
2657 
2658 static void
2659 musbotg_start_standard_chain(struct usb_xfer *xfer)
2660 {
2661 	DPRINTFN(8, "\n");
2662 
2663 	/* poll one time */
2664 	if (musbotg_xfer_do_fifo(xfer)) {
2665 		DPRINTFN(14, "enabled interrupts on endpoint\n");
2666 
2667 		/* put transfer on interrupt queue */
2668 		usbd_transfer_enqueue(&xfer->xroot->bus->intr_q, xfer);
2669 
2670 		/* start timeout, if any */
2671 		if (xfer->timeout != 0) {
2672 			usbd_transfer_timeout_ms(xfer,
2673 			    &musbotg_timeout, xfer->timeout);
2674 		}
2675 	}
2676 }
2677 
2678 static void
2679 musbotg_root_intr(struct musbotg_softc *sc)
2680 {
2681 	DPRINTFN(8, "\n");
2682 
2683 	USB_BUS_LOCK_ASSERT(&sc->sc_bus, MA_OWNED);
2684 
2685 	/* set port bit */
2686 	sc->sc_hub_idata[0] = 0x02;	/* we only have one port */
2687 
2688 	uhub_root_intr(&sc->sc_bus, sc->sc_hub_idata,
2689 	    sizeof(sc->sc_hub_idata));
2690 }
2691 
2692 static usb_error_t
2693 musbotg_standard_done_sub(struct usb_xfer *xfer)
2694 {
2695 	struct musbotg_td *td;
2696 	uint32_t len;
2697 	uint8_t error;
2698 
2699 	DPRINTFN(8, "\n");
2700 
2701 	td = xfer->td_transfer_cache;
2702 
2703 	do {
2704 		len = td->remainder;
2705 
2706 		xfer->endpoint->toggle_next = td->toggle;
2707 
2708 		if (xfer->aframes != xfer->nframes) {
2709 			/*
2710 		         * Verify the length and subtract
2711 		         * the remainder from "frlengths[]":
2712 		         */
2713 			if (len > xfer->frlengths[xfer->aframes]) {
2714 				td->error = 1;
2715 			} else {
2716 				xfer->frlengths[xfer->aframes] -= len;
2717 			}
2718 		}
2719 		/* Check for transfer error */
2720 		if (td->error) {
2721 			/* the transfer is finished */
2722 			error = 1;
2723 			td = NULL;
2724 			break;
2725 		}
2726 		/* Check for short transfer */
2727 		if (len > 0) {
2728 			if (xfer->flags_int.short_frames_ok ||
2729 			    xfer->flags_int.isochronous_xfr) {
2730 				/* follow alt next */
2731 				if (td->alt_next) {
2732 					td = td->obj_next;
2733 				} else {
2734 					td = NULL;
2735 				}
2736 			} else {
2737 				/* the transfer is finished */
2738 				td = NULL;
2739 			}
2740 			error = 0;
2741 			break;
2742 		}
2743 		td = td->obj_next;
2744 
2745 		/* this USB frame is complete */
2746 		error = 0;
2747 		break;
2748 
2749 	} while (0);
2750 
2751 	/* update transfer cache */
2752 
2753 	xfer->td_transfer_cache = td;
2754 
2755 	return (error ?
2756 	    USB_ERR_STALLED : USB_ERR_NORMAL_COMPLETION);
2757 }
2758 
2759 static void
2760 musbotg_standard_done(struct usb_xfer *xfer)
2761 {
2762 	usb_error_t err = 0;
2763 
2764 	DPRINTFN(12, "xfer=%p endpoint=%p transfer done\n",
2765 	    xfer, xfer->endpoint);
2766 
2767 	/* reset scanner */
2768 
2769 	xfer->td_transfer_cache = xfer->td_transfer_first;
2770 
2771 	if (xfer->flags_int.control_xfr) {
2772 		if (xfer->flags_int.control_hdr) {
2773 			err = musbotg_standard_done_sub(xfer);
2774 		}
2775 		xfer->aframes = 1;
2776 
2777 		if (xfer->td_transfer_cache == NULL) {
2778 			goto done;
2779 		}
2780 	}
2781 	while (xfer->aframes != xfer->nframes) {
2782 		err = musbotg_standard_done_sub(xfer);
2783 		xfer->aframes++;
2784 
2785 		if (xfer->td_transfer_cache == NULL) {
2786 			goto done;
2787 		}
2788 	}
2789 
2790 	if (xfer->flags_int.control_xfr &&
2791 	    !xfer->flags_int.control_act) {
2792 		err = musbotg_standard_done_sub(xfer);
2793 	}
2794 done:
2795 	musbotg_device_done(xfer, err);
2796 }
2797 
2798 /*------------------------------------------------------------------------*
2799  *	musbotg_device_done
2800  *
2801  * NOTE: this function can be called more than one time on the
2802  * same USB transfer!
2803  *------------------------------------------------------------------------*/
2804 static void
2805 musbotg_device_done(struct usb_xfer *xfer, usb_error_t error)
2806 {
2807 	struct musbotg_td *td;
2808 	struct musbotg_softc *sc;
2809 
2810 	USB_BUS_LOCK_ASSERT(xfer->xroot->bus, MA_OWNED);
2811 
2812 	DPRINTFN(1, "xfer=%p, endpoint=%p, error=%d\n",
2813 	    xfer, xfer->endpoint, error);
2814 
2815 	DPRINTFN(14, "disabled interrupts on endpoint\n");
2816 
2817 	sc = MUSBOTG_BUS2SC(xfer->xroot->bus);
2818 	td = xfer->td_transfer_cache;
2819 
2820 	if (td && (td->channel != -1))
2821 		musbotg_channel_free(sc, td);
2822 
2823 	/* dequeue transfer and start next transfer */
2824 	usbd_transfer_done(xfer, error);
2825 }
2826 
2827 static void
2828 musbotg_xfer_stall(struct usb_xfer *xfer)
2829 {
2830 	musbotg_device_done(xfer, USB_ERR_STALLED);
2831 }
2832 
2833 static void
2834 musbotg_set_stall(struct usb_device *udev,
2835     struct usb_endpoint *ep, uint8_t *did_stall)
2836 {
2837 	struct musbotg_softc *sc;
2838 	uint8_t ep_no;
2839 
2840 	USB_BUS_LOCK_ASSERT(udev->bus, MA_OWNED);
2841 
2842 	DPRINTFN(4, "endpoint=%p\n", ep);
2843 
2844 	/* set FORCESTALL */
2845 	sc = MUSBOTG_BUS2SC(udev->bus);
2846 
2847 	ep_no = (ep->edesc->bEndpointAddress & UE_ADDR);
2848 
2849 	/* select endpoint */
2850 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, ep_no);
2851 
2852 	if (ep->edesc->bEndpointAddress & UE_DIR_IN) {
2853 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
2854 		    MUSB2_MASK_CSRL_TXSENDSTALL);
2855 	} else {
2856 		MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL,
2857 		    MUSB2_MASK_CSRL_RXSENDSTALL);
2858 	}
2859 }
2860 
2861 static void
2862 musbotg_clear_stall_sub(struct musbotg_softc *sc, uint16_t wMaxPacket,
2863     uint8_t ep_no, uint8_t ep_type, uint8_t ep_dir)
2864 {
2865 	uint16_t mps;
2866 	uint16_t temp;
2867 	uint8_t csr;
2868 
2869 	if (ep_type == UE_CONTROL) {
2870 		/* clearing stall is not needed */
2871 		return;
2872 	}
2873 	/* select endpoint */
2874 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, ep_no);
2875 
2876 	/* compute max frame size */
2877 	mps = wMaxPacket & 0x7FF;
2878 	switch ((wMaxPacket >> 11) & 3) {
2879 	case 1:
2880 		mps *= 2;
2881 		break;
2882 	case 2:
2883 		mps *= 3;
2884 		break;
2885 	default:
2886 		break;
2887 	}
2888 
2889 	if (ep_dir == UE_DIR_IN) {
2890 		temp = 0;
2891 
2892 		/* Configure endpoint */
2893 		switch (ep_type) {
2894 		case UE_INTERRUPT:
2895 			MUSB2_WRITE_2(sc, MUSB2_REG_TXMAXP, wMaxPacket);
2896 			MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH,
2897 			    MUSB2_MASK_CSRH_TXMODE | temp);
2898 			break;
2899 		case UE_ISOCHRONOUS:
2900 			MUSB2_WRITE_2(sc, MUSB2_REG_TXMAXP, wMaxPacket);
2901 			MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH,
2902 			    MUSB2_MASK_CSRH_TXMODE |
2903 			    MUSB2_MASK_CSRH_TXISO | temp);
2904 			break;
2905 		case UE_BULK:
2906 			MUSB2_WRITE_2(sc, MUSB2_REG_TXMAXP, wMaxPacket);
2907 			MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH,
2908 			    MUSB2_MASK_CSRH_TXMODE | temp);
2909 			break;
2910 		default:
2911 			break;
2912 		}
2913 
2914 		/* Need to flush twice in case of double bufring */
2915 		csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
2916 		if (csr & MUSB2_MASK_CSRL_TXFIFONEMPTY) {
2917 			MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
2918 			    MUSB2_MASK_CSRL_TXFFLUSH);
2919 			csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
2920 			if (csr & MUSB2_MASK_CSRL_TXFIFONEMPTY) {
2921 				MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
2922 				    MUSB2_MASK_CSRL_TXFFLUSH);
2923 				csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
2924 			}
2925 		}
2926 		/* reset data toggle */
2927 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL,
2928 		    MUSB2_MASK_CSRL_TXDT_CLR);
2929 		MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
2930 		csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
2931 
2932 		/* set double/single buffering */
2933 		temp = MUSB2_READ_2(sc, MUSB2_REG_TXDBDIS);
2934 		if (mps <= (sc->sc_hw_ep_profile[ep_no].
2935 		    max_in_frame_size / 2)) {
2936 			/* double buffer */
2937 			temp &= ~(1 << ep_no);
2938 		} else {
2939 			/* single buffer */
2940 			temp |= (1 << ep_no);
2941 		}
2942 		MUSB2_WRITE_2(sc, MUSB2_REG_TXDBDIS, temp);
2943 
2944 		/* clear sent stall */
2945 		if (csr & MUSB2_MASK_CSRL_TXSENTSTALL) {
2946 			MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRL, 0);
2947 			csr = MUSB2_READ_1(sc, MUSB2_REG_TXCSRL);
2948 		}
2949 	} else {
2950 		temp = 0;
2951 
2952 		/* Configure endpoint */
2953 		switch (ep_type) {
2954 		case UE_INTERRUPT:
2955 			MUSB2_WRITE_2(sc, MUSB2_REG_RXMAXP, wMaxPacket);
2956 			MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH,
2957 			    MUSB2_MASK_CSRH_RXNYET | temp);
2958 			break;
2959 		case UE_ISOCHRONOUS:
2960 			MUSB2_WRITE_2(sc, MUSB2_REG_RXMAXP, wMaxPacket);
2961 			MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH,
2962 			    MUSB2_MASK_CSRH_RXNYET |
2963 			    MUSB2_MASK_CSRH_RXISO | temp);
2964 			break;
2965 		case UE_BULK:
2966 			MUSB2_WRITE_2(sc, MUSB2_REG_RXMAXP, wMaxPacket);
2967 			MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH, temp);
2968 			break;
2969 		default:
2970 			break;
2971 		}
2972 
2973 		/* Need to flush twice in case of double bufring */
2974 		csr = MUSB2_READ_1(sc, MUSB2_REG_RXCSRL);
2975 		if (csr & MUSB2_MASK_CSRL_RXPKTRDY) {
2976 			MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL,
2977 			    MUSB2_MASK_CSRL_RXFFLUSH);
2978 			csr = MUSB2_READ_1(sc, MUSB2_REG_RXCSRL);
2979 			if (csr & MUSB2_MASK_CSRL_RXPKTRDY) {
2980 				MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL,
2981 				    MUSB2_MASK_CSRL_RXFFLUSH);
2982 				csr = MUSB2_READ_1(sc, MUSB2_REG_RXCSRL);
2983 			}
2984 		}
2985 		/* reset data toggle */
2986 		MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL,
2987 		    MUSB2_MASK_CSRL_RXDT_CLR);
2988 		MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL, 0);
2989 		csr = MUSB2_READ_1(sc, MUSB2_REG_RXCSRL);
2990 
2991 		/* set double/single buffering */
2992 		temp = MUSB2_READ_2(sc, MUSB2_REG_RXDBDIS);
2993 		if (mps <= (sc->sc_hw_ep_profile[ep_no].
2994 		    max_out_frame_size / 2)) {
2995 			/* double buffer */
2996 			temp &= ~(1 << ep_no);
2997 		} else {
2998 			/* single buffer */
2999 			temp |= (1 << ep_no);
3000 		}
3001 		MUSB2_WRITE_2(sc, MUSB2_REG_RXDBDIS, temp);
3002 
3003 		/* clear sent stall */
3004 		if (csr & MUSB2_MASK_CSRL_RXSENTSTALL) {
3005 			MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRL, 0);
3006 		}
3007 	}
3008 }
3009 
3010 static void
3011 musbotg_clear_stall(struct usb_device *udev, struct usb_endpoint *ep)
3012 {
3013 	struct musbotg_softc *sc;
3014 	struct usb_endpoint_descriptor *ed;
3015 
3016 	DPRINTFN(4, "endpoint=%p\n", ep);
3017 
3018 	USB_BUS_LOCK_ASSERT(udev->bus, MA_OWNED);
3019 
3020 	/* check mode */
3021 	if (udev->flags.usb_mode != USB_MODE_DEVICE) {
3022 		/* not supported */
3023 		return;
3024 	}
3025 	/* get softc */
3026 	sc = MUSBOTG_BUS2SC(udev->bus);
3027 
3028 	/* get endpoint descriptor */
3029 	ed = ep->edesc;
3030 
3031 	/* reset endpoint */
3032 	musbotg_clear_stall_sub(sc,
3033 	    UGETW(ed->wMaxPacketSize),
3034 	    (ed->bEndpointAddress & UE_ADDR),
3035 	    (ed->bmAttributes & UE_XFERTYPE),
3036 	    (ed->bEndpointAddress & (UE_DIR_IN | UE_DIR_OUT)));
3037 }
3038 
3039 usb_error_t
3040 musbotg_init(struct musbotg_softc *sc)
3041 {
3042 	const struct musb_otg_ep_cfg *cfg;
3043 	struct usb_hw_ep_profile *pf;
3044 	int i;
3045 	uint16_t offset;
3046 	uint8_t nrx;
3047 	uint8_t ntx;
3048 	uint8_t temp;
3049 	uint8_t fsize;
3050 	uint8_t frx;
3051 	uint8_t ftx;
3052 	uint8_t dynfifo;
3053 
3054 	DPRINTFN(1, "start\n");
3055 
3056 	/* set up the bus structure */
3057 	sc->sc_bus.usbrev = USB_REV_2_0;
3058 	sc->sc_bus.methods = &musbotg_bus_methods;
3059 
3060 	/* Set a default endpoint configuration */
3061 	if (sc->sc_ep_cfg == NULL)
3062 		sc->sc_ep_cfg = musbotg_ep_default;
3063 
3064 	USB_BUS_LOCK(&sc->sc_bus);
3065 
3066 	/* turn on clocks */
3067 
3068 	if (sc->sc_clocks_on) {
3069 		(sc->sc_clocks_on) (sc->sc_clocks_arg);
3070 	}
3071 
3072 	/* wait a little for things to stabilise */
3073 	usb_pause_mtx(&sc->sc_bus.bus_mtx, hz / 1000);
3074 
3075 	/* disable all interrupts */
3076 
3077 	temp = MUSB2_READ_1(sc, MUSB2_REG_DEVCTL);
3078 	DPRINTF("pre-DEVCTL=0x%02x\n", temp);
3079 
3080 	MUSB2_WRITE_1(sc, MUSB2_REG_INTUSBE, 0);
3081 	MUSB2_WRITE_2(sc, MUSB2_REG_INTTXE, 0);
3082 	MUSB2_WRITE_2(sc, MUSB2_REG_INTRXE, 0);
3083 
3084 	/* disable pullup */
3085 
3086 	musbotg_pull_common(sc, 0);
3087 
3088 	/* wait a little bit (10ms) */
3089 	usb_pause_mtx(&sc->sc_bus.bus_mtx, hz / 100);
3090 
3091 	/* disable double packet buffering */
3092 	MUSB2_WRITE_2(sc, MUSB2_REG_RXDBDIS, 0xFFFF);
3093 	MUSB2_WRITE_2(sc, MUSB2_REG_TXDBDIS, 0xFFFF);
3094 
3095 	/* enable HighSpeed and ISO Update flags */
3096 
3097 	MUSB2_WRITE_1(sc, MUSB2_REG_POWER,
3098 	    MUSB2_MASK_HSENAB | MUSB2_MASK_ISOUPD);
3099 
3100 	if (sc->sc_mode == MUSB2_DEVICE_MODE) {
3101 		/* clear Session bit, if set */
3102 		temp = MUSB2_READ_1(sc, MUSB2_REG_DEVCTL);
3103 		temp &= ~MUSB2_MASK_SESS;
3104 		MUSB2_WRITE_1(sc, MUSB2_REG_DEVCTL, temp);
3105 	} else {
3106 		/* Enter session for Host mode */
3107 		temp = MUSB2_READ_1(sc, MUSB2_REG_DEVCTL);
3108 		temp |= MUSB2_MASK_SESS;
3109 		MUSB2_WRITE_1(sc, MUSB2_REG_DEVCTL, temp);
3110 	}
3111 
3112 	/* wait a little for things to stabilise */
3113 	usb_pause_mtx(&sc->sc_bus.bus_mtx, hz / 10);
3114 
3115 	DPRINTF("DEVCTL=0x%02x\n", temp);
3116 
3117 	/* disable testmode */
3118 
3119 	MUSB2_WRITE_1(sc, MUSB2_REG_TESTMODE, 0);
3120 
3121 	/* set default value */
3122 
3123 	MUSB2_WRITE_1(sc, MUSB2_REG_MISC, 0);
3124 
3125 	/* select endpoint index 0 */
3126 
3127 	MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, 0);
3128 
3129 	if (sc->sc_ep_max == 0) {
3130 		/* read out number of endpoints */
3131 
3132 		nrx =
3133 		    (MUSB2_READ_1(sc, MUSB2_REG_EPINFO) / 16);
3134 
3135 		ntx =
3136 		    (MUSB2_READ_1(sc, MUSB2_REG_EPINFO) % 16);
3137 
3138 		sc->sc_ep_max = (nrx > ntx) ? nrx : ntx;
3139 	} else {
3140 		nrx = ntx = sc->sc_ep_max;
3141 	}
3142 
3143 	/* these numbers exclude the control endpoint */
3144 
3145 	DPRINTFN(2, "RX/TX endpoints: %u/%u\n", nrx, ntx);
3146 
3147 	if (sc->sc_ep_max == 0) {
3148 		DPRINTFN(2, "ERROR: Looks like the clocks are off!\n");
3149 	}
3150 	/* read out configuration data */
3151 
3152 	sc->sc_conf_data = MUSB2_READ_1(sc, MUSB2_REG_CONFDATA);
3153 
3154 	DPRINTFN(2, "Config Data: 0x%02x\n",
3155 	    sc->sc_conf_data);
3156 
3157 	dynfifo = (sc->sc_conf_data & MUSB2_MASK_CD_DYNFIFOSZ) ? 1 : 0;
3158 
3159 	if (dynfifo) {
3160 		device_printf(sc->sc_bus.bdev, "Dynamic FIFO sizing detected, "
3161 		    "assuming 16Kbytes of FIFO RAM\n");
3162 	}
3163 
3164 	DPRINTFN(2, "HW version: 0x%04x\n",
3165 	    MUSB2_READ_1(sc, MUSB2_REG_HWVERS));
3166 
3167 	/* initialise endpoint profiles */
3168 
3169 	offset = 0;
3170 
3171 	for (temp = 1; temp <= sc->sc_ep_max; temp++) {
3172 		pf = sc->sc_hw_ep_profile + temp;
3173 
3174 		/* select endpoint */
3175 		MUSB2_WRITE_1(sc, MUSB2_REG_EPINDEX, temp);
3176 
3177 		fsize = MUSB2_READ_1(sc, MUSB2_REG_FSIZE);
3178 		frx = (fsize & MUSB2_MASK_RX_FSIZE) / 16;
3179 		ftx = (fsize & MUSB2_MASK_TX_FSIZE);
3180 
3181 		DPRINTF("Endpoint %u FIFO size: IN=%u, OUT=%u, DYN=%d\n",
3182 		    temp, ftx, frx, dynfifo);
3183 
3184 		if (dynfifo) {
3185 			if (frx && (temp <= nrx)) {
3186 				for (i = 0; sc->sc_ep_cfg[i].ep_end >= 0; i++) {
3187 					cfg = &sc->sc_ep_cfg[i];
3188 					if (temp <= cfg->ep_end) {
3189 						frx = cfg->ep_fifosz_shift;
3190 						MUSB2_WRITE_1(sc,
3191 						    MUSB2_REG_RXFIFOSZ,
3192 						    cfg->ep_fifosz_reg);
3193 						break;
3194 					}
3195 				}
3196 
3197 				MUSB2_WRITE_2(sc, MUSB2_REG_RXFIFOADD,
3198 				    offset >> 3);
3199 
3200 				offset += (1 << frx);
3201 			}
3202 			if (ftx && (temp <= ntx)) {
3203 				for (i = 0; sc->sc_ep_cfg[i].ep_end >= 0; i++) {
3204 					cfg = &sc->sc_ep_cfg[i];
3205 					if (temp <= cfg->ep_end) {
3206 						ftx = cfg->ep_fifosz_shift;
3207 						MUSB2_WRITE_1(sc,
3208 						    MUSB2_REG_TXFIFOSZ,
3209 						    cfg->ep_fifosz_reg);
3210 						break;
3211 					}
3212 				}
3213 
3214 				MUSB2_WRITE_2(sc, MUSB2_REG_TXFIFOADD,
3215 				    offset >> 3);
3216 
3217 				offset += (1 << ftx);
3218 			}
3219 		}
3220 
3221 		if (frx && ftx && (temp <= nrx) && (temp <= ntx)) {
3222 			pf->max_in_frame_size = 1 << ftx;
3223 			pf->max_out_frame_size = 1 << frx;
3224 			pf->is_simplex = 0;	/* duplex */
3225 			pf->support_multi_buffer = 1;
3226 			pf->support_bulk = 1;
3227 			pf->support_interrupt = 1;
3228 			pf->support_isochronous = 1;
3229 			pf->support_in = 1;
3230 			pf->support_out = 1;
3231 		} else if (frx && (temp <= nrx)) {
3232 			pf->max_out_frame_size = 1 << frx;
3233 			pf->max_in_frame_size = 0;
3234 			pf->is_simplex = 1;	/* simplex */
3235 			pf->support_multi_buffer = 1;
3236 			pf->support_bulk = 1;
3237 			pf->support_interrupt = 1;
3238 			pf->support_isochronous = 1;
3239 			pf->support_out = 1;
3240 		} else if (ftx && (temp <= ntx)) {
3241 			pf->max_in_frame_size = 1 << ftx;
3242 			pf->max_out_frame_size = 0;
3243 			pf->is_simplex = 1;	/* simplex */
3244 			pf->support_multi_buffer = 1;
3245 			pf->support_bulk = 1;
3246 			pf->support_interrupt = 1;
3247 			pf->support_isochronous = 1;
3248 			pf->support_in = 1;
3249 		}
3250 	}
3251 
3252 	DPRINTFN(2, "Dynamic FIFO size = %d bytes\n", offset);
3253 
3254 	/* turn on default interrupts */
3255 
3256 	if (sc->sc_mode == MUSB2_HOST_MODE)
3257 		MUSB2_WRITE_1(sc, MUSB2_REG_INTUSBE, 0xff);
3258 	else
3259 		MUSB2_WRITE_1(sc, MUSB2_REG_INTUSBE,
3260 		    MUSB2_MASK_IRESET);
3261 
3262 	musbotg_clocks_off(sc);
3263 
3264 	USB_BUS_UNLOCK(&sc->sc_bus);
3265 
3266 	/* catch any lost interrupts */
3267 
3268 	musbotg_do_poll(&sc->sc_bus);
3269 
3270 	return (0);			/* success */
3271 }
3272 
3273 void
3274 musbotg_uninit(struct musbotg_softc *sc)
3275 {
3276 	USB_BUS_LOCK(&sc->sc_bus);
3277 
3278 	/* disable all interrupts */
3279 	MUSB2_WRITE_1(sc, MUSB2_REG_INTUSBE, 0);
3280 	MUSB2_WRITE_2(sc, MUSB2_REG_INTTXE, 0);
3281 	MUSB2_WRITE_2(sc, MUSB2_REG_INTRXE, 0);
3282 
3283 	sc->sc_flags.port_powered = 0;
3284 	sc->sc_flags.status_vbus = 0;
3285 	sc->sc_flags.status_bus_reset = 0;
3286 	sc->sc_flags.status_suspend = 0;
3287 	sc->sc_flags.change_suspend = 0;
3288 	sc->sc_flags.change_connect = 1;
3289 
3290 	musbotg_pull_down(sc);
3291 	musbotg_clocks_off(sc);
3292 	USB_BUS_UNLOCK(&sc->sc_bus);
3293 }
3294 
3295 static void
3296 musbotg_do_poll(struct usb_bus *bus)
3297 {
3298 	struct musbotg_softc *sc = MUSBOTG_BUS2SC(bus);
3299 
3300 	USB_BUS_LOCK(&sc->sc_bus);
3301 	musbotg_interrupt_poll(sc);
3302 	USB_BUS_UNLOCK(&sc->sc_bus);
3303 }
3304 
3305 /*------------------------------------------------------------------------*
3306  * musbotg bulk support
3307  *------------------------------------------------------------------------*/
3308 static void
3309 musbotg_device_bulk_open(struct usb_xfer *xfer)
3310 {
3311 	return;
3312 }
3313 
3314 static void
3315 musbotg_device_bulk_close(struct usb_xfer *xfer)
3316 {
3317 	musbotg_device_done(xfer, USB_ERR_CANCELLED);
3318 }
3319 
3320 static void
3321 musbotg_device_bulk_enter(struct usb_xfer *xfer)
3322 {
3323 	return;
3324 }
3325 
3326 static void
3327 musbotg_device_bulk_start(struct usb_xfer *xfer)
3328 {
3329 	/* setup TDs */
3330 	musbotg_setup_standard_chain(xfer);
3331 	musbotg_start_standard_chain(xfer);
3332 }
3333 
3334 static const struct usb_pipe_methods musbotg_device_bulk_methods =
3335 {
3336 	.open = musbotg_device_bulk_open,
3337 	.close = musbotg_device_bulk_close,
3338 	.enter = musbotg_device_bulk_enter,
3339 	.start = musbotg_device_bulk_start,
3340 };
3341 
3342 /*------------------------------------------------------------------------*
3343  * musbotg control support
3344  *------------------------------------------------------------------------*/
3345 static void
3346 musbotg_device_ctrl_open(struct usb_xfer *xfer)
3347 {
3348 	return;
3349 }
3350 
3351 static void
3352 musbotg_device_ctrl_close(struct usb_xfer *xfer)
3353 {
3354 	musbotg_device_done(xfer, USB_ERR_CANCELLED);
3355 }
3356 
3357 static void
3358 musbotg_device_ctrl_enter(struct usb_xfer *xfer)
3359 {
3360 	return;
3361 }
3362 
3363 static void
3364 musbotg_device_ctrl_start(struct usb_xfer *xfer)
3365 {
3366 	/* setup TDs */
3367 	musbotg_setup_standard_chain(xfer);
3368 	musbotg_start_standard_chain(xfer);
3369 }
3370 
3371 static const struct usb_pipe_methods musbotg_device_ctrl_methods =
3372 {
3373 	.open = musbotg_device_ctrl_open,
3374 	.close = musbotg_device_ctrl_close,
3375 	.enter = musbotg_device_ctrl_enter,
3376 	.start = musbotg_device_ctrl_start,
3377 };
3378 
3379 /*------------------------------------------------------------------------*
3380  * musbotg interrupt support
3381  *------------------------------------------------------------------------*/
3382 static void
3383 musbotg_device_intr_open(struct usb_xfer *xfer)
3384 {
3385 	return;
3386 }
3387 
3388 static void
3389 musbotg_device_intr_close(struct usb_xfer *xfer)
3390 {
3391 	musbotg_device_done(xfer, USB_ERR_CANCELLED);
3392 }
3393 
3394 static void
3395 musbotg_device_intr_enter(struct usb_xfer *xfer)
3396 {
3397 	return;
3398 }
3399 
3400 static void
3401 musbotg_device_intr_start(struct usb_xfer *xfer)
3402 {
3403 	/* setup TDs */
3404 	musbotg_setup_standard_chain(xfer);
3405 	musbotg_start_standard_chain(xfer);
3406 }
3407 
3408 static const struct usb_pipe_methods musbotg_device_intr_methods =
3409 {
3410 	.open = musbotg_device_intr_open,
3411 	.close = musbotg_device_intr_close,
3412 	.enter = musbotg_device_intr_enter,
3413 	.start = musbotg_device_intr_start,
3414 };
3415 
3416 /*------------------------------------------------------------------------*
3417  * musbotg full speed isochronous support
3418  *------------------------------------------------------------------------*/
3419 static void
3420 musbotg_device_isoc_open(struct usb_xfer *xfer)
3421 {
3422 	return;
3423 }
3424 
3425 static void
3426 musbotg_device_isoc_close(struct usb_xfer *xfer)
3427 {
3428 	musbotg_device_done(xfer, USB_ERR_CANCELLED);
3429 }
3430 
3431 static void
3432 musbotg_device_isoc_enter(struct usb_xfer *xfer)
3433 {
3434 	struct musbotg_softc *sc = MUSBOTG_BUS2SC(xfer->xroot->bus);
3435 	uint32_t nframes;
3436 
3437 	DPRINTFN(5, "xfer=%p next=%d nframes=%d\n",
3438 	    xfer, xfer->endpoint->isoc_next, xfer->nframes);
3439 
3440 	/* get the current frame index */
3441 
3442 	nframes = MUSB2_READ_2(sc, MUSB2_REG_FRAME);
3443 
3444 	if (usbd_xfer_get_isochronous_start_frame(
3445 	    xfer, nframes, 0, 1, MUSB2_MASK_FRAME, NULL))
3446 		DPRINTFN(2, "start next=%d\n", xfer->endpoint->isoc_next);
3447 
3448 	/* setup TDs */
3449 	musbotg_setup_standard_chain(xfer);
3450 }
3451 
3452 static void
3453 musbotg_device_isoc_start(struct usb_xfer *xfer)
3454 {
3455 	/* start TD chain */
3456 	musbotg_start_standard_chain(xfer);
3457 }
3458 
3459 static const struct usb_pipe_methods musbotg_device_isoc_methods =
3460 {
3461 	.open = musbotg_device_isoc_open,
3462 	.close = musbotg_device_isoc_close,
3463 	.enter = musbotg_device_isoc_enter,
3464 	.start = musbotg_device_isoc_start,
3465 };
3466 
3467 /*------------------------------------------------------------------------*
3468  * musbotg root control support
3469  *------------------------------------------------------------------------*
3470  * Simulate a hardware HUB by handling all the necessary requests.
3471  *------------------------------------------------------------------------*/
3472 
3473 static const struct usb_device_descriptor musbotg_devd = {
3474 	.bLength = sizeof(struct usb_device_descriptor),
3475 	.bDescriptorType = UDESC_DEVICE,
3476 	.bcdUSB = {0x00, 0x02},
3477 	.bDeviceClass = UDCLASS_HUB,
3478 	.bDeviceSubClass = UDSUBCLASS_HUB,
3479 	.bDeviceProtocol = UDPROTO_HSHUBSTT,
3480 	.bMaxPacketSize = 64,
3481 	.bcdDevice = {0x00, 0x01},
3482 	.iManufacturer = 1,
3483 	.iProduct = 2,
3484 	.bNumConfigurations = 1,
3485 };
3486 
3487 static const struct usb_device_qualifier musbotg_odevd = {
3488 	.bLength = sizeof(struct usb_device_qualifier),
3489 	.bDescriptorType = UDESC_DEVICE_QUALIFIER,
3490 	.bcdUSB = {0x00, 0x02},
3491 	.bDeviceClass = UDCLASS_HUB,
3492 	.bDeviceSubClass = UDSUBCLASS_HUB,
3493 	.bDeviceProtocol = UDPROTO_FSHUB,
3494 	.bMaxPacketSize0 = 0,
3495 	.bNumConfigurations = 0,
3496 };
3497 
3498 static const struct musbotg_config_desc musbotg_confd = {
3499 	.confd = {
3500 		.bLength = sizeof(struct usb_config_descriptor),
3501 		.bDescriptorType = UDESC_CONFIG,
3502 		.wTotalLength[0] = sizeof(musbotg_confd),
3503 		.bNumInterface = 1,
3504 		.bConfigurationValue = 1,
3505 		.iConfiguration = 0,
3506 		.bmAttributes = UC_SELF_POWERED,
3507 		.bMaxPower = 0,
3508 	},
3509 	.ifcd = {
3510 		.bLength = sizeof(struct usb_interface_descriptor),
3511 		.bDescriptorType = UDESC_INTERFACE,
3512 		.bNumEndpoints = 1,
3513 		.bInterfaceClass = UICLASS_HUB,
3514 		.bInterfaceSubClass = UISUBCLASS_HUB,
3515 		.bInterfaceProtocol = 0,
3516 	},
3517 	.endpd = {
3518 		.bLength = sizeof(struct usb_endpoint_descriptor),
3519 		.bDescriptorType = UDESC_ENDPOINT,
3520 		.bEndpointAddress = (UE_DIR_IN | MUSBOTG_INTR_ENDPT),
3521 		.bmAttributes = UE_INTERRUPT,
3522 		.wMaxPacketSize[0] = 8,
3523 		.bInterval = 255,
3524 	},
3525 };
3526 #define	HSETW(ptr, val) ptr = { (uint8_t)(val), (uint8_t)((val) >> 8) }
3527 
3528 static const struct usb_hub_descriptor_min musbotg_hubd = {
3529 	.bDescLength = sizeof(musbotg_hubd),
3530 	.bDescriptorType = UDESC_HUB,
3531 	.bNbrPorts = 1,
3532 	HSETW(.wHubCharacteristics, (UHD_PWR_NO_SWITCH | UHD_OC_INDIVIDUAL)),
3533 	.bPwrOn2PwrGood = 50,
3534 	.bHubContrCurrent = 0,
3535 	.DeviceRemovable = {0},		/* port is removable */
3536 };
3537 
3538 #define	STRING_VENDOR \
3539   "M\0e\0n\0t\0o\0r\0 \0G\0r\0a\0p\0h\0i\0c\0s"
3540 
3541 #define	STRING_PRODUCT \
3542   "O\0T\0G\0 \0R\0o\0o\0t\0 \0H\0U\0B"
3543 
3544 USB_MAKE_STRING_DESC(STRING_VENDOR, musbotg_vendor);
3545 USB_MAKE_STRING_DESC(STRING_PRODUCT, musbotg_product);
3546 
3547 static usb_error_t
3548 musbotg_roothub_exec(struct usb_device *udev,
3549     struct usb_device_request *req, const void **pptr, uint16_t *plength)
3550 {
3551 	struct musbotg_softc *sc = MUSBOTG_BUS2SC(udev->bus);
3552 	const void *ptr;
3553 	uint16_t len;
3554 	uint16_t value;
3555 	uint16_t index;
3556 	uint8_t reg;
3557 	usb_error_t err;
3558 
3559 	USB_BUS_LOCK_ASSERT(&sc->sc_bus, MA_OWNED);
3560 
3561 	/* buffer reset */
3562 	ptr = (const void *)&sc->sc_hub_temp;
3563 	len = 0;
3564 	err = 0;
3565 
3566 	value = UGETW(req->wValue);
3567 	index = UGETW(req->wIndex);
3568 
3569 	/* demultiplex the control request */
3570 
3571 	switch (req->bmRequestType) {
3572 	case UT_READ_DEVICE:
3573 		switch (req->bRequest) {
3574 		case UR_GET_DESCRIPTOR:
3575 			goto tr_handle_get_descriptor;
3576 		case UR_GET_CONFIG:
3577 			goto tr_handle_get_config;
3578 		case UR_GET_STATUS:
3579 			goto tr_handle_get_status;
3580 		default:
3581 			goto tr_stalled;
3582 		}
3583 		break;
3584 
3585 	case UT_WRITE_DEVICE:
3586 		switch (req->bRequest) {
3587 		case UR_SET_ADDRESS:
3588 			goto tr_handle_set_address;
3589 		case UR_SET_CONFIG:
3590 			goto tr_handle_set_config;
3591 		case UR_CLEAR_FEATURE:
3592 			goto tr_valid;	/* nop */
3593 		case UR_SET_DESCRIPTOR:
3594 			goto tr_valid;	/* nop */
3595 		case UR_SET_FEATURE:
3596 		default:
3597 			goto tr_stalled;
3598 		}
3599 		break;
3600 
3601 	case UT_WRITE_ENDPOINT:
3602 		switch (req->bRequest) {
3603 		case UR_CLEAR_FEATURE:
3604 			switch (UGETW(req->wValue)) {
3605 			case UF_ENDPOINT_HALT:
3606 				goto tr_handle_clear_halt;
3607 			case UF_DEVICE_REMOTE_WAKEUP:
3608 				goto tr_handle_clear_wakeup;
3609 			default:
3610 				goto tr_stalled;
3611 			}
3612 			break;
3613 		case UR_SET_FEATURE:
3614 			switch (UGETW(req->wValue)) {
3615 			case UF_ENDPOINT_HALT:
3616 				goto tr_handle_set_halt;
3617 			case UF_DEVICE_REMOTE_WAKEUP:
3618 				goto tr_handle_set_wakeup;
3619 			default:
3620 				goto tr_stalled;
3621 			}
3622 			break;
3623 		case UR_SYNCH_FRAME:
3624 			goto tr_valid;	/* nop */
3625 		default:
3626 			goto tr_stalled;
3627 		}
3628 		break;
3629 
3630 	case UT_READ_ENDPOINT:
3631 		switch (req->bRequest) {
3632 		case UR_GET_STATUS:
3633 			goto tr_handle_get_ep_status;
3634 		default:
3635 			goto tr_stalled;
3636 		}
3637 		break;
3638 
3639 	case UT_WRITE_INTERFACE:
3640 		switch (req->bRequest) {
3641 		case UR_SET_INTERFACE:
3642 			goto tr_handle_set_interface;
3643 		case UR_CLEAR_FEATURE:
3644 			goto tr_valid;	/* nop */
3645 		case UR_SET_FEATURE:
3646 		default:
3647 			goto tr_stalled;
3648 		}
3649 		break;
3650 
3651 	case UT_READ_INTERFACE:
3652 		switch (req->bRequest) {
3653 		case UR_GET_INTERFACE:
3654 			goto tr_handle_get_interface;
3655 		case UR_GET_STATUS:
3656 			goto tr_handle_get_iface_status;
3657 		default:
3658 			goto tr_stalled;
3659 		}
3660 		break;
3661 
3662 	case UT_WRITE_CLASS_INTERFACE:
3663 	case UT_WRITE_VENDOR_INTERFACE:
3664 		/* XXX forward */
3665 		break;
3666 
3667 	case UT_READ_CLASS_INTERFACE:
3668 	case UT_READ_VENDOR_INTERFACE:
3669 		/* XXX forward */
3670 		break;
3671 
3672 	case UT_WRITE_CLASS_DEVICE:
3673 		switch (req->bRequest) {
3674 		case UR_CLEAR_FEATURE:
3675 			goto tr_valid;
3676 		case UR_SET_DESCRIPTOR:
3677 		case UR_SET_FEATURE:
3678 			break;
3679 		default:
3680 			goto tr_stalled;
3681 		}
3682 		break;
3683 
3684 	case UT_WRITE_CLASS_OTHER:
3685 		switch (req->bRequest) {
3686 		case UR_CLEAR_FEATURE:
3687 			goto tr_handle_clear_port_feature;
3688 		case UR_SET_FEATURE:
3689 			goto tr_handle_set_port_feature;
3690 		case UR_CLEAR_TT_BUFFER:
3691 		case UR_RESET_TT:
3692 		case UR_STOP_TT:
3693 			goto tr_valid;
3694 
3695 		default:
3696 			goto tr_stalled;
3697 		}
3698 		break;
3699 
3700 	case UT_READ_CLASS_OTHER:
3701 		switch (req->bRequest) {
3702 		case UR_GET_TT_STATE:
3703 			goto tr_handle_get_tt_state;
3704 		case UR_GET_STATUS:
3705 			goto tr_handle_get_port_status;
3706 		default:
3707 			goto tr_stalled;
3708 		}
3709 		break;
3710 
3711 	case UT_READ_CLASS_DEVICE:
3712 		switch (req->bRequest) {
3713 		case UR_GET_DESCRIPTOR:
3714 			goto tr_handle_get_class_descriptor;
3715 		case UR_GET_STATUS:
3716 			goto tr_handle_get_class_status;
3717 
3718 		default:
3719 			goto tr_stalled;
3720 		}
3721 		break;
3722 	default:
3723 		goto tr_stalled;
3724 	}
3725 	goto tr_valid;
3726 
3727 tr_handle_get_descriptor:
3728 	switch (value >> 8) {
3729 	case UDESC_DEVICE:
3730 		if (value & 0xff) {
3731 			goto tr_stalled;
3732 		}
3733 		len = sizeof(musbotg_devd);
3734 		ptr = (const void *)&musbotg_devd;
3735 		goto tr_valid;
3736 	case UDESC_DEVICE_QUALIFIER:
3737 		if (value & 0xff) {
3738 			goto tr_stalled;
3739 		}
3740 		len = sizeof(musbotg_odevd);
3741 		ptr = (const void *)&musbotg_odevd;
3742 		goto tr_valid;
3743 	case UDESC_CONFIG:
3744 		if (value & 0xff) {
3745 			goto tr_stalled;
3746 		}
3747 		len = sizeof(musbotg_confd);
3748 		ptr = (const void *)&musbotg_confd;
3749 		goto tr_valid;
3750 	case UDESC_STRING:
3751 		switch (value & 0xff) {
3752 		case 0:		/* Language table */
3753 			len = sizeof(usb_string_lang_en);
3754 			ptr = (const void *)&usb_string_lang_en;
3755 			goto tr_valid;
3756 
3757 		case 1:		/* Vendor */
3758 			len = sizeof(musbotg_vendor);
3759 			ptr = (const void *)&musbotg_vendor;
3760 			goto tr_valid;
3761 
3762 		case 2:		/* Product */
3763 			len = sizeof(musbotg_product);
3764 			ptr = (const void *)&musbotg_product;
3765 			goto tr_valid;
3766 		default:
3767 			break;
3768 		}
3769 		break;
3770 	default:
3771 		goto tr_stalled;
3772 	}
3773 	goto tr_stalled;
3774 
3775 tr_handle_get_config:
3776 	len = 1;
3777 	sc->sc_hub_temp.wValue[0] = sc->sc_conf;
3778 	goto tr_valid;
3779 
3780 tr_handle_get_status:
3781 	len = 2;
3782 	USETW(sc->sc_hub_temp.wValue, UDS_SELF_POWERED);
3783 	goto tr_valid;
3784 
3785 tr_handle_set_address:
3786 	if (value & 0xFF00) {
3787 		goto tr_stalled;
3788 	}
3789 	sc->sc_rt_addr = value;
3790 	goto tr_valid;
3791 
3792 tr_handle_set_config:
3793 	if (value >= 2) {
3794 		goto tr_stalled;
3795 	}
3796 	sc->sc_conf = value;
3797 	goto tr_valid;
3798 
3799 tr_handle_get_interface:
3800 	len = 1;
3801 	sc->sc_hub_temp.wValue[0] = 0;
3802 	goto tr_valid;
3803 
3804 tr_handle_get_tt_state:
3805 tr_handle_get_class_status:
3806 tr_handle_get_iface_status:
3807 tr_handle_get_ep_status:
3808 	len = 2;
3809 	USETW(sc->sc_hub_temp.wValue, 0);
3810 	goto tr_valid;
3811 
3812 tr_handle_set_halt:
3813 tr_handle_set_interface:
3814 tr_handle_set_wakeup:
3815 tr_handle_clear_wakeup:
3816 tr_handle_clear_halt:
3817 	goto tr_valid;
3818 
3819 tr_handle_clear_port_feature:
3820 	if (index != 1) {
3821 		goto tr_stalled;
3822 	}
3823 	DPRINTFN(8, "UR_CLEAR_PORT_FEATURE on port %d\n", index);
3824 
3825 	switch (value) {
3826 	case UHF_PORT_SUSPEND:
3827 		if (sc->sc_mode == MUSB2_HOST_MODE)
3828 			musbotg_wakeup_host(sc);
3829 		else
3830 			musbotg_wakeup_peer(sc);
3831 		break;
3832 
3833 	case UHF_PORT_ENABLE:
3834 		sc->sc_flags.port_enabled = 0;
3835 		break;
3836 
3837 	case UHF_C_PORT_ENABLE:
3838 		sc->sc_flags.change_enabled = 0;
3839 		break;
3840 
3841 	case UHF_C_PORT_OVER_CURRENT:
3842 		sc->sc_flags.change_over_current = 0;
3843 		break;
3844 
3845 	case UHF_C_PORT_RESET:
3846 		sc->sc_flags.change_reset = 0;
3847 		break;
3848 
3849 	case UHF_PORT_TEST:
3850 	case UHF_PORT_INDICATOR:
3851 		/* nops */
3852 		break;
3853 
3854 	case UHF_PORT_POWER:
3855 		sc->sc_flags.port_powered = 0;
3856 		musbotg_pull_down(sc);
3857 		musbotg_clocks_off(sc);
3858 		break;
3859 	case UHF_C_PORT_CONNECTION:
3860 		sc->sc_flags.change_connect = 0;
3861 		break;
3862 	case UHF_C_PORT_SUSPEND:
3863 		sc->sc_flags.change_suspend = 0;
3864 		break;
3865 	default:
3866 		err = USB_ERR_IOERROR;
3867 		goto done;
3868 	}
3869 	goto tr_valid;
3870 
3871 tr_handle_set_port_feature:
3872 	if (index != 1) {
3873 		goto tr_stalled;
3874 	}
3875 	DPRINTFN(8, "UR_SET_PORT_FEATURE\n");
3876 
3877 	switch (value) {
3878 	case UHF_PORT_ENABLE:
3879 		sc->sc_flags.port_enabled = 1;
3880 		break;
3881 	case UHF_PORT_SUSPEND:
3882 		if (sc->sc_mode == MUSB2_HOST_MODE)
3883 			musbotg_suspend_host(sc);
3884 		break;
3885 
3886 	case UHF_PORT_RESET:
3887 		if (sc->sc_mode == MUSB2_HOST_MODE) {
3888 			reg = MUSB2_READ_1(sc, MUSB2_REG_POWER);
3889 			reg |= MUSB2_MASK_RESET;
3890 			MUSB2_WRITE_1(sc, MUSB2_REG_POWER, reg);
3891 
3892 			/* Wait for 20 msec */
3893 			usb_pause_mtx(&sc->sc_bus.bus_mtx, hz / 5);
3894 
3895 			reg = MUSB2_READ_1(sc, MUSB2_REG_POWER);
3896 			reg &= ~MUSB2_MASK_RESET;
3897 			MUSB2_WRITE_1(sc, MUSB2_REG_POWER, reg);
3898 
3899 			/* determine line speed */
3900 			reg = MUSB2_READ_1(sc, MUSB2_REG_POWER);
3901 			if (reg & MUSB2_MASK_HSMODE)
3902 				sc->sc_flags.status_high_speed = 1;
3903 			else
3904 				sc->sc_flags.status_high_speed = 0;
3905 
3906 			sc->sc_flags.change_reset = 1;
3907 		} else
3908 			err = USB_ERR_IOERROR;
3909 		break;
3910 
3911 	case UHF_PORT_TEST:
3912 	case UHF_PORT_INDICATOR:
3913 		/* nops */
3914 		break;
3915 	case UHF_PORT_POWER:
3916 		sc->sc_flags.port_powered = 1;
3917 		break;
3918 	default:
3919 		err = USB_ERR_IOERROR;
3920 		goto done;
3921 	}
3922 	goto tr_valid;
3923 
3924 tr_handle_get_port_status:
3925 
3926 	DPRINTFN(8, "UR_GET_PORT_STATUS\n");
3927 
3928 	if (index != 1) {
3929 		goto tr_stalled;
3930 	}
3931 	if (sc->sc_flags.status_vbus) {
3932 		musbotg_clocks_on(sc);
3933 		musbotg_pull_up(sc);
3934 	} else {
3935 		musbotg_pull_down(sc);
3936 		musbotg_clocks_off(sc);
3937 	}
3938 
3939 	/* Select Device Side Mode */
3940 	if (sc->sc_mode == MUSB2_DEVICE_MODE)
3941 		value = UPS_PORT_MODE_DEVICE;
3942 	else
3943 		value = 0;
3944 
3945 	if (sc->sc_flags.status_high_speed) {
3946 		value |= UPS_HIGH_SPEED;
3947 	}
3948 	if (sc->sc_flags.port_powered) {
3949 		value |= UPS_PORT_POWER;
3950 	}
3951 	if (sc->sc_flags.port_enabled) {
3952 		value |= UPS_PORT_ENABLED;
3953 	}
3954 
3955 	if (sc->sc_flags.port_over_current)
3956 		value |= UPS_OVERCURRENT_INDICATOR;
3957 
3958 	if (sc->sc_flags.status_vbus &&
3959 	    sc->sc_flags.status_bus_reset) {
3960 		value |= UPS_CURRENT_CONNECT_STATUS;
3961 	}
3962 	if (sc->sc_flags.status_suspend) {
3963 		value |= UPS_SUSPEND;
3964 	}
3965 	USETW(sc->sc_hub_temp.ps.wPortStatus, value);
3966 
3967 	value = 0;
3968 
3969 	if (sc->sc_flags.change_connect) {
3970 		value |= UPS_C_CONNECT_STATUS;
3971 
3972 		if (sc->sc_mode == MUSB2_DEVICE_MODE) {
3973 			if (sc->sc_flags.status_vbus &&
3974 			    sc->sc_flags.status_bus_reset) {
3975 				/* reset EP0 state */
3976 				sc->sc_ep0_busy = 0;
3977 				sc->sc_ep0_cmd = 0;
3978 			}
3979 		}
3980 	}
3981 	if (sc->sc_flags.change_suspend)
3982 		value |= UPS_C_SUSPEND;
3983 	if (sc->sc_flags.change_reset)
3984 		value |= UPS_C_PORT_RESET;
3985 	if (sc->sc_flags.change_over_current)
3986 		value |= UPS_C_OVERCURRENT_INDICATOR;
3987 
3988 	USETW(sc->sc_hub_temp.ps.wPortChange, value);
3989 	len = sizeof(sc->sc_hub_temp.ps);
3990 	goto tr_valid;
3991 
3992 tr_handle_get_class_descriptor:
3993 	if (value & 0xFF) {
3994 		goto tr_stalled;
3995 	}
3996 	ptr = (const void *)&musbotg_hubd;
3997 	len = sizeof(musbotg_hubd);
3998 	goto tr_valid;
3999 
4000 tr_stalled:
4001 	err = USB_ERR_STALLED;
4002 tr_valid:
4003 done:
4004 	*plength = len;
4005 	*pptr = ptr;
4006 	return (err);
4007 }
4008 
4009 static void
4010 musbotg_xfer_setup(struct usb_setup_params *parm)
4011 {
4012 	struct usb_xfer *xfer;
4013 	void *last_obj;
4014 	uint32_t ntd;
4015 	uint32_t n;
4016 	uint8_t ep_no;
4017 
4018 	xfer = parm->curr_xfer;
4019 
4020 	/*
4021 	 * NOTE: This driver does not use any of the parameters that
4022 	 * are computed from the following values. Just set some
4023 	 * reasonable dummies:
4024 	 */
4025 	parm->hc_max_packet_size = 0x400;
4026 	parm->hc_max_frame_size = 0xc00;
4027 
4028 	if ((parm->methods == &musbotg_device_isoc_methods) ||
4029 	    (parm->methods == &musbotg_device_intr_methods))
4030 		parm->hc_max_packet_count = 3;
4031 	else
4032 		parm->hc_max_packet_count = 1;
4033 
4034 	usbd_transfer_setup_sub(parm);
4035 
4036 	/*
4037 	 * compute maximum number of TDs
4038 	 */
4039 	if (parm->methods == &musbotg_device_ctrl_methods) {
4040 		ntd = xfer->nframes + 1 /* STATUS */ + 1 /* SYNC */ ;
4041 
4042 	} else if (parm->methods == &musbotg_device_bulk_methods) {
4043 		ntd = xfer->nframes + 1 /* SYNC */ ;
4044 
4045 	} else if (parm->methods == &musbotg_device_intr_methods) {
4046 		ntd = xfer->nframes + 1 /* SYNC */ ;
4047 
4048 	} else if (parm->methods == &musbotg_device_isoc_methods) {
4049 		ntd = xfer->nframes + 1 /* SYNC */ ;
4050 
4051 	} else {
4052 		ntd = 0;
4053 	}
4054 
4055 	/*
4056 	 * check if "usbd_transfer_setup_sub" set an error
4057 	 */
4058 	if (parm->err) {
4059 		return;
4060 	}
4061 	/*
4062 	 * allocate transfer descriptors
4063 	 */
4064 	last_obj = NULL;
4065 
4066 	ep_no = xfer->endpointno & UE_ADDR;
4067 
4068 	/*
4069 	 * Check for a valid endpoint profile in USB device mode:
4070 	 */
4071 	if (xfer->flags_int.usb_mode == USB_MODE_DEVICE) {
4072 		const struct usb_hw_ep_profile *pf;
4073 
4074 		musbotg_get_hw_ep_profile(parm->udev, &pf, ep_no);
4075 
4076 		if (pf == NULL) {
4077 			/* should not happen */
4078 			parm->err = USB_ERR_INVAL;
4079 			return;
4080 		}
4081 	}
4082 
4083 	/* align data */
4084 	parm->size[0] += ((-parm->size[0]) & (USB_HOST_ALIGN - 1));
4085 
4086 	for (n = 0; n != ntd; n++) {
4087 		struct musbotg_td *td;
4088 
4089 		if (parm->buf) {
4090 			td = USB_ADD_BYTES(parm->buf, parm->size[0]);
4091 
4092 			/* init TD */
4093 			td->max_frame_size = xfer->max_frame_size;
4094 			td->reg_max_packet = xfer->max_packet_size |
4095 			    ((xfer->max_packet_count - 1) << 11);
4096 			td->ep_no = ep_no;
4097 			td->obj_next = last_obj;
4098 
4099 			last_obj = td;
4100 		}
4101 		parm->size[0] += sizeof(*td);
4102 	}
4103 
4104 	xfer->td_start[0] = last_obj;
4105 }
4106 
4107 static void
4108 musbotg_xfer_unsetup(struct usb_xfer *xfer)
4109 {
4110 	return;
4111 }
4112 
4113 static void
4114 musbotg_get_dma_delay(struct usb_device *udev, uint32_t *pus)
4115 {
4116 	struct musbotg_softc *sc = MUSBOTG_BUS2SC(udev->bus);
4117 
4118 	if (sc->sc_mode == MUSB2_HOST_MODE)
4119 	        *pus = 2000;                   /* microseconds */
4120 	else
4121 		*pus = 0;
4122 }
4123 
4124 static void
4125 musbotg_ep_init(struct usb_device *udev, struct usb_endpoint_descriptor *edesc,
4126     struct usb_endpoint *ep)
4127 {
4128 	struct musbotg_softc *sc = MUSBOTG_BUS2SC(udev->bus);
4129 
4130 	DPRINTFN(2, "endpoint=%p, addr=%d, endpt=%d, mode=%d (%d)\n",
4131 	    ep, udev->address,
4132 	    edesc->bEndpointAddress, udev->flags.usb_mode,
4133 	    sc->sc_rt_addr);
4134 
4135 	if (udev->device_index != sc->sc_rt_addr) {
4136 		switch (edesc->bmAttributes & UE_XFERTYPE) {
4137 		case UE_CONTROL:
4138 			ep->methods = &musbotg_device_ctrl_methods;
4139 			break;
4140 		case UE_INTERRUPT:
4141 			ep->methods = &musbotg_device_intr_methods;
4142 			break;
4143 		case UE_ISOCHRONOUS:
4144 			ep->methods = &musbotg_device_isoc_methods;
4145 			break;
4146 		case UE_BULK:
4147 			ep->methods = &musbotg_device_bulk_methods;
4148 			break;
4149 		default:
4150 			/* do nothing */
4151 			break;
4152 		}
4153 	}
4154 }
4155 
4156 static void
4157 musbotg_set_hw_power_sleep(struct usb_bus *bus, uint32_t state)
4158 {
4159 	struct musbotg_softc *sc = MUSBOTG_BUS2SC(bus);
4160 
4161 	switch (state) {
4162 	case USB_HW_POWER_SUSPEND:
4163 		musbotg_uninit(sc);
4164 		break;
4165 	case USB_HW_POWER_SHUTDOWN:
4166 		musbotg_uninit(sc);
4167 		break;
4168 	case USB_HW_POWER_RESUME:
4169 		musbotg_init(sc);
4170 		break;
4171 	default:
4172 		break;
4173 	}
4174 }
4175 
4176 static const struct usb_bus_methods musbotg_bus_methods =
4177 {
4178 	.endpoint_init = &musbotg_ep_init,
4179 	.get_dma_delay = &musbotg_get_dma_delay,
4180 	.xfer_setup = &musbotg_xfer_setup,
4181 	.xfer_unsetup = &musbotg_xfer_unsetup,
4182 	.get_hw_ep_profile = &musbotg_get_hw_ep_profile,
4183 	.xfer_stall = &musbotg_xfer_stall,
4184 	.set_stall = &musbotg_set_stall,
4185 	.clear_stall = &musbotg_clear_stall,
4186 	.roothub_exec = &musbotg_roothub_exec,
4187 	.xfer_poll = &musbotg_do_poll,
4188 	.set_hw_power_sleep = &musbotg_set_hw_power_sleep,
4189 };
4190