vusbh11sh.c
3.79 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/*HEADER******************************************************************
**************************************************************************
***
*** Copyright (c) 2001-2002 ARC International.
*** All rights reserved
***
*** This software embodies materials and concepts which are
*** confidential to ARC International and is made
*** available solely pursuant to the terms of a written license
*** agreement with ARC International
***
*** File: vusbh11.c
***
*** Comments:
*** This file contains the low-level Host API functions specific to the VUSB
*** chip.
***
**************************************************************************
*END*********************************************************************/
#ifdef __USB_OS_MQX__
#include "mqx.h"
#include "bsp.h"
#else
#include "types.h"
#include "vusb11.h"
#include "usb.h"
#include "hostapi.h"
#endif
#include "usbhprv.h"
#include "usbprv.h"
#ifndef __USB_OS_MQX__
extern boolean IN_ISR;
#endif
/*FUNCTION*-------------------------------------------------------------
*
* Function Name : _usb_hci_vusb11_bus_control
* Returned Value : None
* Comments :
* Bus control
*END*-----------------------------------------------------------------*/
void _usb_hci_vusb11_bus_control
(
/* [IN] the USB Host state structure */
_usb_host_handle handle,
/* The operation to be performed on the bus */
uint_8 bControl
)
{ /* Body */
USB_HOST_STATE_STRUCT_PTR usb_host_ptr;
usb_host_ptr = (USB_HOST_STATE_STRUCT_PTR)handle;
switch(bControl) {
case USB_ASSERT_BUS_RESET:
usb_host_ptr->DEV_PTR->CONTROL = (VUSB_CTRL_HOST_MODE_EN |
VUSB_CTRL_USB_EN | VUSB_CTRL_RESET);
break;
case USB_ASSERT_RESUME:
usb_host_ptr->DEV_PTR->CONTROL = (VUSB_CTRL_HOST_MODE_EN
| VUSB_CTRL_USB_EN | VUSB_CTRL_RESUME);
break;
case USB_SUSPEND_SOF:
usb_host_ptr->DEV_PTR->CONTROL = VUSB_CTRL_HOST_MODE_EN;
/* Enable the resume interrupt when suspended */
usb_host_ptr->DEV_PTR->INTENABLE |= VUSB_INT_ENB_RESUME;
break;
case USB_DEASSERT_BUS_RESET:
case USB_RESUME_SOF:
case USB_DEASSERT_RESUME:
/* Resume interrupt should not be enabled when not suspended */
usb_host_ptr->DEV_PTR->INTENABLE &= ~VUSB_INT_ENB_RESUME;
usb_host_ptr->DEV_PTR->CONTROL = (VUSB_CTRL_HOST_MODE_EN |
VUSB_CTRL_USB_EN);
default:
break;
} /* EndSwitch */
} /* EndBody */
/*FUNCTION*-------------------------------------------------------------
*
* Function Name : _usb_hci_vusb11_shutdown
* Returned Value : None
* Comments :
* Shutdown and de-initialize the VUSB1.1 hardware
*
*END*-----------------------------------------------------------------*/
void _usb_hci_vusb11_shutdown
(
/* [IN] the USB Host state structure */
_usb_host_handle handle
)
{ /* Body */
USB_HOST_STATE_STRUCT_PTR usb_host_ptr;
usb_host_ptr = (USB_HOST_STATE_STRUCT_PTR)handle;
*usb_host_ptr->ENDPT_HOST_RG = VUSB_ENDPT_DISABLE;
usb_host_ptr->DEV_PTR->CONTROL = 0x00; /* Disable VUSB */
usb_host_ptr->DEV_PTR->INTENABLE = 0x00; /* Mask all interupts */
usb_host_ptr->DEV_PTR->INTSTATUS = 0xFF; /* Clear all interupts */
usb_host_ptr->DEV_PTR->ADDRESS = 0;
/* Free the Buffer Descriptor Table */
USB_memfree(usb_host_ptr->USB_BDT_PAGE_BASE);
} /* EndBody */
/* EOF */