MP3 Player without external hardware MP3 Player without external hardware. A software based MP3 player based on a modified version of libmad. Mono output (at the moment) via AnalogOut. Files are read from an USB drive. This is a demo program, it plays only one file at the moment. Documentation is in "main.cpp" and "config.h"

Dependencies:   mbed

Committer:
Gruenfrosch
Date:
Fri Nov 26 12:18:30 2010 +0000
Revision:
0:7627c79db971
First Version

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Gruenfrosch 0:7627c79db971 1 /*
Gruenfrosch 0:7627c79db971 2 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 3 * NXP USB Host Stack
Gruenfrosch 0:7627c79db971 4 *
Gruenfrosch 0:7627c79db971 5 * (c) Copyright 2008, NXP SemiConductors
Gruenfrosch 0:7627c79db971 6 * (c) Copyright 2008, OnChip Technologies LLC
Gruenfrosch 0:7627c79db971 7 * All Rights Reserved
Gruenfrosch 0:7627c79db971 8 *
Gruenfrosch 0:7627c79db971 9 * www.nxp.com
Gruenfrosch 0:7627c79db971 10 * www.onchiptech.com
Gruenfrosch 0:7627c79db971 11 *
Gruenfrosch 0:7627c79db971 12 * File : usbhost_lpc17xx.c
Gruenfrosch 0:7627c79db971 13 * Programmer(s) : Ravikanth.P
Gruenfrosch 0:7627c79db971 14 * Version :
Gruenfrosch 0:7627c79db971 15 *
Gruenfrosch 0:7627c79db971 16 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 17 */
Gruenfrosch 0:7627c79db971 18
Gruenfrosch 0:7627c79db971 19 /*
Gruenfrosch 0:7627c79db971 20 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 21 * INCLUDE HEADER FILES
Gruenfrosch 0:7627c79db971 22 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 23 */
Gruenfrosch 0:7627c79db971 24
Gruenfrosch 0:7627c79db971 25 #include "usbhost_lpc17xx.h"
Gruenfrosch 0:7627c79db971 26
Gruenfrosch 0:7627c79db971 27 /*
Gruenfrosch 0:7627c79db971 28 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 29 * GLOBAL VARIABLES
Gruenfrosch 0:7627c79db971 30 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 31 */
Gruenfrosch 0:7627c79db971 32 int gUSBConnected;
Gruenfrosch 0:7627c79db971 33
Gruenfrosch 0:7627c79db971 34 volatile USB_INT32U HOST_RhscIntr = 0; /* Root Hub Status Change interrupt */
Gruenfrosch 0:7627c79db971 35 volatile USB_INT32U HOST_WdhIntr = 0; /* Semaphore to wait until the TD is submitted */
Gruenfrosch 0:7627c79db971 36 volatile USB_INT08U HOST_TDControlStatus = 0;
Gruenfrosch 0:7627c79db971 37 volatile HCED *EDCtrl; /* Control endpoint descriptor structure */
Gruenfrosch 0:7627c79db971 38 volatile HCED *EDBulkIn; /* BulkIn endpoint descriptor structure */
Gruenfrosch 0:7627c79db971 39 volatile HCED *EDBulkOut; /* BulkOut endpoint descriptor structure */
Gruenfrosch 0:7627c79db971 40 volatile HCTD *TDHead; /* Head transfer descriptor structure */
Gruenfrosch 0:7627c79db971 41 volatile HCTD *TDTail; /* Tail transfer descriptor structure */
Gruenfrosch 0:7627c79db971 42 volatile HCCA *Hcca; /* Host Controller Communications Area structure */
Gruenfrosch 0:7627c79db971 43 USB_INT16U *TDBufNonVol; /* Identical to TDBuffer just to reduce compiler warnings */
Gruenfrosch 0:7627c79db971 44 volatile USB_INT08U *TDBuffer; /* Current Buffer Pointer of transfer descriptor */
Gruenfrosch 0:7627c79db971 45
Gruenfrosch 0:7627c79db971 46 // USB host structures
Gruenfrosch 0:7627c79db971 47 // AHB SRAM block 1
Gruenfrosch 0:7627c79db971 48 #define HOSTBASEADDR 0x2007C000
Gruenfrosch 0:7627c79db971 49 // reserve memory for the linker
Gruenfrosch 0:7627c79db971 50 static USB_INT08U HostBuf[0x200] __attribute__((at(HOSTBASEADDR)));
Gruenfrosch 0:7627c79db971 51 /*
Gruenfrosch 0:7627c79db971 52 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 53 * DELAY IN MILLI SECONDS
Gruenfrosch 0:7627c79db971 54 *
Gruenfrosch 0:7627c79db971 55 * Description: This function provides a delay in milli seconds
Gruenfrosch 0:7627c79db971 56 *
Gruenfrosch 0:7627c79db971 57 * Arguments : delay The delay required
Gruenfrosch 0:7627c79db971 58 *
Gruenfrosch 0:7627c79db971 59 * Returns : None
Gruenfrosch 0:7627c79db971 60 *
Gruenfrosch 0:7627c79db971 61 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 62 */
Gruenfrosch 0:7627c79db971 63
Gruenfrosch 0:7627c79db971 64 void Host_DelayMS (USB_INT32U delay)
Gruenfrosch 0:7627c79db971 65 {
Gruenfrosch 0:7627c79db971 66 volatile USB_INT32U i;
Gruenfrosch 0:7627c79db971 67
Gruenfrosch 0:7627c79db971 68
Gruenfrosch 0:7627c79db971 69 for (i = 0; i < delay; i++) {
Gruenfrosch 0:7627c79db971 70 Host_DelayUS(1000);
Gruenfrosch 0:7627c79db971 71 }
Gruenfrosch 0:7627c79db971 72 }
Gruenfrosch 0:7627c79db971 73
Gruenfrosch 0:7627c79db971 74 /*
Gruenfrosch 0:7627c79db971 75 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 76 * DELAY IN MICRO SECONDS
Gruenfrosch 0:7627c79db971 77 *
Gruenfrosch 0:7627c79db971 78 * Description: This function provides a delay in micro seconds
Gruenfrosch 0:7627c79db971 79 *
Gruenfrosch 0:7627c79db971 80 * Arguments : delay The delay required
Gruenfrosch 0:7627c79db971 81 *
Gruenfrosch 0:7627c79db971 82 * Returns : None
Gruenfrosch 0:7627c79db971 83 *
Gruenfrosch 0:7627c79db971 84 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 85 */
Gruenfrosch 0:7627c79db971 86
Gruenfrosch 0:7627c79db971 87 void Host_DelayUS (USB_INT32U delay)
Gruenfrosch 0:7627c79db971 88 {
Gruenfrosch 0:7627c79db971 89 volatile USB_INT32U i;
Gruenfrosch 0:7627c79db971 90
Gruenfrosch 0:7627c79db971 91
Gruenfrosch 0:7627c79db971 92 for (i = 0; i < (4 * delay); i++) { /* This logic was tested. It gives app. 1 micro sec delay */
Gruenfrosch 0:7627c79db971 93 ;
Gruenfrosch 0:7627c79db971 94 }
Gruenfrosch 0:7627c79db971 95 }
Gruenfrosch 0:7627c79db971 96
Gruenfrosch 0:7627c79db971 97 // bits of the USB/OTG clock control register
Gruenfrosch 0:7627c79db971 98 #define HOST_CLK_EN (1<<0)
Gruenfrosch 0:7627c79db971 99 #define DEV_CLK_EN (1<<1)
Gruenfrosch 0:7627c79db971 100 #define PORTSEL_CLK_EN (1<<3)
Gruenfrosch 0:7627c79db971 101 #define AHB_CLK_EN (1<<4)
Gruenfrosch 0:7627c79db971 102
Gruenfrosch 0:7627c79db971 103 // bits of the USB/OTG clock status register
Gruenfrosch 0:7627c79db971 104 #define HOST_CLK_ON (1<<0)
Gruenfrosch 0:7627c79db971 105 #define DEV_CLK_ON (1<<1)
Gruenfrosch 0:7627c79db971 106 #define PORTSEL_CLK_ON (1<<3)
Gruenfrosch 0:7627c79db971 107 #define AHB_CLK_ON (1<<4)
Gruenfrosch 0:7627c79db971 108
Gruenfrosch 0:7627c79db971 109 // we need host clock, OTG/portsel clock and AHB clock
Gruenfrosch 0:7627c79db971 110 #define CLOCK_MASK (HOST_CLK_EN | PORTSEL_CLK_EN | AHB_CLK_EN)
Gruenfrosch 0:7627c79db971 111
Gruenfrosch 0:7627c79db971 112 /*
Gruenfrosch 0:7627c79db971 113 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 114 * INITIALIZE THE HOST CONTROLLER
Gruenfrosch 0:7627c79db971 115 *
Gruenfrosch 0:7627c79db971 116 * Description: This function initializes lpc17xx host controller
Gruenfrosch 0:7627c79db971 117 *
Gruenfrosch 0:7627c79db971 118 * Arguments : None
Gruenfrosch 0:7627c79db971 119 *
Gruenfrosch 0:7627c79db971 120 * Returns :
Gruenfrosch 0:7627c79db971 121 *
Gruenfrosch 0:7627c79db971 122 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 123 */
Gruenfrosch 0:7627c79db971 124 void Host_Init (void)
Gruenfrosch 0:7627c79db971 125 {
Gruenfrosch 0:7627c79db971 126 PRINT_Log("In Host_Init\n");
Gruenfrosch 0:7627c79db971 127 NVIC_DisableIRQ(USB_IRQn); /* Disable the USB interrupt source */
Gruenfrosch 0:7627c79db971 128
Gruenfrosch 0:7627c79db971 129 // turn on power for USB
Gruenfrosch 0:7627c79db971 130 LPC_SC->PCONP |= (1UL<<31);
Gruenfrosch 0:7627c79db971 131 // Enable USB host clock, port selection and AHB clock
Gruenfrosch 0:7627c79db971 132 LPC_USB->USBClkCtrl |= CLOCK_MASK;
Gruenfrosch 0:7627c79db971 133 // Wait for clocks to become available
Gruenfrosch 0:7627c79db971 134 while ((LPC_USB->USBClkSt & CLOCK_MASK) != CLOCK_MASK)
Gruenfrosch 0:7627c79db971 135 ;
Gruenfrosch 0:7627c79db971 136
Gruenfrosch 0:7627c79db971 137 // it seems the bits[0:1] mean the following
Gruenfrosch 0:7627c79db971 138 // 0: U1=device, U2=host
Gruenfrosch 0:7627c79db971 139 // 1: U1=host, U2=host
Gruenfrosch 0:7627c79db971 140 // 2: reserved
Gruenfrosch 0:7627c79db971 141 // 3: U1=host, U2=device
Gruenfrosch 0:7627c79db971 142 // NB: this register is only available if OTG clock (aka "port select") is enabled!!
Gruenfrosch 0:7627c79db971 143 // since we don't care about port 2, set just bit 0 to 1 (U1=host)
Gruenfrosch 0:7627c79db971 144 LPC_USB->OTGStCtrl |= 1;
Gruenfrosch 0:7627c79db971 145
Gruenfrosch 0:7627c79db971 146 // now that we've configured the ports, we can turn off the portsel clock
Gruenfrosch 0:7627c79db971 147 LPC_USB->USBClkCtrl &= ~PORTSEL_CLK_EN;
Gruenfrosch 0:7627c79db971 148
Gruenfrosch 0:7627c79db971 149 // power pins are not connected on mbed, so we can skip them
Gruenfrosch 0:7627c79db971 150 /* P1[18] = USB_UP_LED, 01 */
Gruenfrosch 0:7627c79db971 151 /* P1[19] = /USB_PPWR, 10 */
Gruenfrosch 0:7627c79db971 152 /* P1[22] = USB_PWRD, 10 */
Gruenfrosch 0:7627c79db971 153 /* P1[27] = /USB_OVRCR, 10 */
Gruenfrosch 0:7627c79db971 154 /*LPC_PINCON->PINSEL3 &= ~((3<<4) | (3<<6) | (3<<12) | (3<<22));
Gruenfrosch 0:7627c79db971 155 LPC_PINCON->PINSEL3 |= ((1<<4)|(2<<6) | (2<<12) | (2<<22)); // 0x00802080
Gruenfrosch 0:7627c79db971 156 */
Gruenfrosch 0:7627c79db971 157
Gruenfrosch 0:7627c79db971 158 // configure USB D+/D- pins
Gruenfrosch 0:7627c79db971 159 /* P0[29] = USB_D+, 01 */
Gruenfrosch 0:7627c79db971 160 /* P0[30] = USB_D-, 01 */
Gruenfrosch 0:7627c79db971 161 LPC_PINCON->PINSEL1 &= ~((3<<26) | (3<<28));
Gruenfrosch 0:7627c79db971 162 LPC_PINCON->PINSEL1 |= ((1<<26)|(1<<28)); // 0x14000000
Gruenfrosch 0:7627c79db971 163
Gruenfrosch 0:7627c79db971 164 PRINT_Log("Initializing Host Stack\n");
Gruenfrosch 0:7627c79db971 165
Gruenfrosch 0:7627c79db971 166 Hcca = (volatile HCCA *)(HostBuf+0x000);
Gruenfrosch 0:7627c79db971 167 TDHead = (volatile HCTD *)(HostBuf+0x100);
Gruenfrosch 0:7627c79db971 168 TDTail = (volatile HCTD *)(HostBuf+0x110);
Gruenfrosch 0:7627c79db971 169 EDCtrl = (volatile HCED *)(HostBuf+0x120);
Gruenfrosch 0:7627c79db971 170 EDBulkIn = (volatile HCED *)(HostBuf+0x130);
Gruenfrosch 0:7627c79db971 171 EDBulkOut = (volatile HCED *)(HostBuf+0x140);
Gruenfrosch 0:7627c79db971 172 TDBuffer = (volatile USB_INT08U *)(HostBuf+0x150);
Gruenfrosch 0:7627c79db971 173
Gruenfrosch 0:7627c79db971 174 /* Initialize all the TDs, EDs and HCCA to 0 */
Gruenfrosch 0:7627c79db971 175 Host_EDInit(EDCtrl);
Gruenfrosch 0:7627c79db971 176 Host_EDInit(EDBulkIn);
Gruenfrosch 0:7627c79db971 177 Host_EDInit(EDBulkOut);
Gruenfrosch 0:7627c79db971 178 Host_TDInit(TDHead);
Gruenfrosch 0:7627c79db971 179 Host_TDInit(TDTail);
Gruenfrosch 0:7627c79db971 180 Host_HCCAInit(Hcca);
Gruenfrosch 0:7627c79db971 181
Gruenfrosch 0:7627c79db971 182 Host_DelayMS(50); /* Wait 50 ms before apply reset */
Gruenfrosch 0:7627c79db971 183 LPC_USB->HcControl = 0; /* HARDWARE RESET */
Gruenfrosch 0:7627c79db971 184 LPC_USB->HcControlHeadED = 0; /* Initialize Control list head to Zero */
Gruenfrosch 0:7627c79db971 185 LPC_USB->HcBulkHeadED = 0; /* Initialize Bulk list head to Zero */
Gruenfrosch 0:7627c79db971 186
Gruenfrosch 0:7627c79db971 187 /* SOFTWARE RESET */
Gruenfrosch 0:7627c79db971 188 LPC_USB->HcCommandStatus = OR_CMD_STATUS_HCR;
Gruenfrosch 0:7627c79db971 189 LPC_USB->HcFmInterval = DEFAULT_FMINTERVAL; /* Write Fm Interval and Largest Data Packet Counter */
Gruenfrosch 0:7627c79db971 190
Gruenfrosch 0:7627c79db971 191 /* Put HC in operational state */
Gruenfrosch 0:7627c79db971 192 LPC_USB->HcControl = (LPC_USB->HcControl & (~OR_CONTROL_HCFS)) | OR_CONTROL_HC_OPER;
Gruenfrosch 0:7627c79db971 193 LPC_USB->HcRhStatus = OR_RH_STATUS_LPSC; /* Set Global Power */
Gruenfrosch 0:7627c79db971 194
Gruenfrosch 0:7627c79db971 195 LPC_USB->HcHCCA = (USB_INT32U)Hcca;
Gruenfrosch 0:7627c79db971 196 LPC_USB->HcInterruptStatus |= LPC_USB->HcInterruptStatus; /* Clear Interrrupt Status */
Gruenfrosch 0:7627c79db971 197
Gruenfrosch 0:7627c79db971 198
Gruenfrosch 0:7627c79db971 199 LPC_USB->HcInterruptEnable = OR_INTR_ENABLE_MIE |
Gruenfrosch 0:7627c79db971 200 OR_INTR_ENABLE_WDH |
Gruenfrosch 0:7627c79db971 201 OR_INTR_ENABLE_RHSC;
Gruenfrosch 0:7627c79db971 202
Gruenfrosch 0:7627c79db971 203 NVIC_SetPriority(USB_IRQn, 0); /* highest priority */
Gruenfrosch 0:7627c79db971 204 /* Enable the USB Interrupt */
Gruenfrosch 0:7627c79db971 205 NVIC_EnableIRQ(USB_IRQn);
Gruenfrosch 0:7627c79db971 206 PRINT_Log("Host Initialized\n");
Gruenfrosch 0:7627c79db971 207 }
Gruenfrosch 0:7627c79db971 208
Gruenfrosch 0:7627c79db971 209 /*
Gruenfrosch 0:7627c79db971 210 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 211 * INTERRUPT SERVICE ROUTINE
Gruenfrosch 0:7627c79db971 212 *
Gruenfrosch 0:7627c79db971 213 * Description: This function services the interrupt caused by host controller
Gruenfrosch 0:7627c79db971 214 *
Gruenfrosch 0:7627c79db971 215 * Arguments : None
Gruenfrosch 0:7627c79db971 216 *
Gruenfrosch 0:7627c79db971 217 * Returns : None
Gruenfrosch 0:7627c79db971 218 *
Gruenfrosch 0:7627c79db971 219 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 220 */
Gruenfrosch 0:7627c79db971 221
Gruenfrosch 0:7627c79db971 222 void USB_IRQHandler (void) __irq
Gruenfrosch 0:7627c79db971 223 {
Gruenfrosch 0:7627c79db971 224 USB_INT32U int_status;
Gruenfrosch 0:7627c79db971 225 USB_INT32U ie_status;
Gruenfrosch 0:7627c79db971 226
Gruenfrosch 0:7627c79db971 227 int_status = LPC_USB->HcInterruptStatus; /* Read Interrupt Status */
Gruenfrosch 0:7627c79db971 228 ie_status = LPC_USB->HcInterruptEnable; /* Read Interrupt enable status */
Gruenfrosch 0:7627c79db971 229
Gruenfrosch 0:7627c79db971 230 if (!(int_status & ie_status)) {
Gruenfrosch 0:7627c79db971 231 return;
Gruenfrosch 0:7627c79db971 232 } else {
Gruenfrosch 0:7627c79db971 233
Gruenfrosch 0:7627c79db971 234 int_status = int_status & ie_status;
Gruenfrosch 0:7627c79db971 235 if (int_status & OR_INTR_STATUS_RHSC) { /* Root hub status change interrupt */
Gruenfrosch 0:7627c79db971 236 if (LPC_USB->HcRhPortStatus1 & OR_RH_PORT_CSC) {
Gruenfrosch 0:7627c79db971 237 if (LPC_USB->HcRhStatus & OR_RH_STATUS_DRWE) {
Gruenfrosch 0:7627c79db971 238 /*
Gruenfrosch 0:7627c79db971 239 * When DRWE is on, Connect Status Change
Gruenfrosch 0:7627c79db971 240 * means a remote wakeup event.
Gruenfrosch 0:7627c79db971 241 */
Gruenfrosch 0:7627c79db971 242 HOST_RhscIntr = 1;// JUST SOMETHING FOR A BREAKPOINT
Gruenfrosch 0:7627c79db971 243 }
Gruenfrosch 0:7627c79db971 244 else {
Gruenfrosch 0:7627c79db971 245 /*
Gruenfrosch 0:7627c79db971 246 * When DRWE is off, Connect Status Change
Gruenfrosch 0:7627c79db971 247 * is NOT a remote wakeup event
Gruenfrosch 0:7627c79db971 248 */
Gruenfrosch 0:7627c79db971 249 if (LPC_USB->HcRhPortStatus1 & OR_RH_PORT_CCS) {
Gruenfrosch 0:7627c79db971 250 if (!gUSBConnected) {
Gruenfrosch 0:7627c79db971 251 HOST_TDControlStatus = 0;
Gruenfrosch 0:7627c79db971 252 HOST_WdhIntr = 0;
Gruenfrosch 0:7627c79db971 253 HOST_RhscIntr = 1;
Gruenfrosch 0:7627c79db971 254 gUSBConnected = 1;
Gruenfrosch 0:7627c79db971 255 }
Gruenfrosch 0:7627c79db971 256 else
Gruenfrosch 0:7627c79db971 257 PRINT_Log("Spurious status change (connected)?\n");
Gruenfrosch 0:7627c79db971 258 } else {
Gruenfrosch 0:7627c79db971 259 if (gUSBConnected) {
Gruenfrosch 0:7627c79db971 260 LPC_USB->HcInterruptEnable = 0; // why do we get multiple disc. rupts???
Gruenfrosch 0:7627c79db971 261 HOST_RhscIntr = 0;
Gruenfrosch 0:7627c79db971 262 gUSBConnected = 0;
Gruenfrosch 0:7627c79db971 263 }
Gruenfrosch 0:7627c79db971 264 else
Gruenfrosch 0:7627c79db971 265 PRINT_Log("Spurious status change (disconnected)?\n");
Gruenfrosch 0:7627c79db971 266 }
Gruenfrosch 0:7627c79db971 267 }
Gruenfrosch 0:7627c79db971 268 LPC_USB->HcRhPortStatus1 = OR_RH_PORT_CSC;
Gruenfrosch 0:7627c79db971 269 }
Gruenfrosch 0:7627c79db971 270 if (LPC_USB->HcRhPortStatus1 & OR_RH_PORT_PRSC) {
Gruenfrosch 0:7627c79db971 271 LPC_USB->HcRhPortStatus1 = OR_RH_PORT_PRSC;
Gruenfrosch 0:7627c79db971 272 }
Gruenfrosch 0:7627c79db971 273 }
Gruenfrosch 0:7627c79db971 274 if (int_status & OR_INTR_STATUS_WDH) { /* Writeback Done Head interrupt */
Gruenfrosch 0:7627c79db971 275 HOST_WdhIntr = 1;
Gruenfrosch 0:7627c79db971 276 HOST_TDControlStatus = (TDHead->Control >> 28) & 0xf;
Gruenfrosch 0:7627c79db971 277 }
Gruenfrosch 0:7627c79db971 278 LPC_USB->HcInterruptStatus = int_status; /* Clear interrupt status register */
Gruenfrosch 0:7627c79db971 279 }
Gruenfrosch 0:7627c79db971 280 return;
Gruenfrosch 0:7627c79db971 281 }
Gruenfrosch 0:7627c79db971 282
Gruenfrosch 0:7627c79db971 283 /*
Gruenfrosch 0:7627c79db971 284 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 285 * PROCESS TRANSFER DESCRIPTOR
Gruenfrosch 0:7627c79db971 286 *
Gruenfrosch 0:7627c79db971 287 * Description: This function processes the transfer descriptor
Gruenfrosch 0:7627c79db971 288 *
Gruenfrosch 0:7627c79db971 289 * Arguments : ed Endpoint descriptor that contains this transfer descriptor
Gruenfrosch 0:7627c79db971 290 * token SETUP, IN, OUT
Gruenfrosch 0:7627c79db971 291 * buffer Current Buffer Pointer of the transfer descriptor
Gruenfrosch 0:7627c79db971 292 * buffer_len Length of the buffer
Gruenfrosch 0:7627c79db971 293 *
Gruenfrosch 0:7627c79db971 294 * Returns : OK if TD submission is successful
Gruenfrosch 0:7627c79db971 295 * ERROR if TD submission fails
Gruenfrosch 0:7627c79db971 296 *
Gruenfrosch 0:7627c79db971 297 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 298 */
Gruenfrosch 0:7627c79db971 299
Gruenfrosch 0:7627c79db971 300 USB_INT32S Host_ProcessTD (volatile HCED *ed,
Gruenfrosch 0:7627c79db971 301 volatile USB_INT32U token,
Gruenfrosch 0:7627c79db971 302 volatile USB_INT08U *buffer,
Gruenfrosch 0:7627c79db971 303 USB_INT32U buffer_len)
Gruenfrosch 0:7627c79db971 304 {
Gruenfrosch 0:7627c79db971 305 volatile USB_INT32U td_toggle;
Gruenfrosch 0:7627c79db971 306
Gruenfrosch 0:7627c79db971 307
Gruenfrosch 0:7627c79db971 308 if (ed == EDCtrl) {
Gruenfrosch 0:7627c79db971 309 if (token == TD_SETUP) {
Gruenfrosch 0:7627c79db971 310 td_toggle = TD_TOGGLE_0;
Gruenfrosch 0:7627c79db971 311 } else {
Gruenfrosch 0:7627c79db971 312 td_toggle = TD_TOGGLE_1;
Gruenfrosch 0:7627c79db971 313 }
Gruenfrosch 0:7627c79db971 314 } else {
Gruenfrosch 0:7627c79db971 315 td_toggle = 0;
Gruenfrosch 0:7627c79db971 316 }
Gruenfrosch 0:7627c79db971 317 TDHead->Control = (TD_ROUNDING |
Gruenfrosch 0:7627c79db971 318 token |
Gruenfrosch 0:7627c79db971 319 TD_DELAY_INT(0) |
Gruenfrosch 0:7627c79db971 320 td_toggle |
Gruenfrosch 0:7627c79db971 321 TD_CC);
Gruenfrosch 0:7627c79db971 322 TDTail->Control = 0;
Gruenfrosch 0:7627c79db971 323 TDHead->CurrBufPtr = (USB_INT32U) buffer;
Gruenfrosch 0:7627c79db971 324 TDTail->CurrBufPtr = 0;
Gruenfrosch 0:7627c79db971 325 TDHead->Next = (USB_INT32U) TDTail;
Gruenfrosch 0:7627c79db971 326 TDTail->Next = 0;
Gruenfrosch 0:7627c79db971 327 TDHead->BufEnd = (USB_INT32U)(buffer + (buffer_len - 1));
Gruenfrosch 0:7627c79db971 328 TDTail->BufEnd = 0;
Gruenfrosch 0:7627c79db971 329
Gruenfrosch 0:7627c79db971 330 ed->HeadTd = (USB_INT32U)TDHead | ((ed->HeadTd) & 0x00000002);
Gruenfrosch 0:7627c79db971 331 ed->TailTd = (USB_INT32U)TDTail;
Gruenfrosch 0:7627c79db971 332 ed->Next = 0;
Gruenfrosch 0:7627c79db971 333
Gruenfrosch 0:7627c79db971 334 if (ed == EDCtrl) {
Gruenfrosch 0:7627c79db971 335 LPC_USB->HcControlHeadED = (USB_INT32U)ed;
Gruenfrosch 0:7627c79db971 336 LPC_USB->HcCommandStatus = LPC_USB->HcCommandStatus | OR_CMD_STATUS_CLF;
Gruenfrosch 0:7627c79db971 337 LPC_USB->HcControl = LPC_USB->HcControl | OR_CONTROL_CLE;
Gruenfrosch 0:7627c79db971 338 } else {
Gruenfrosch 0:7627c79db971 339 LPC_USB->HcBulkHeadED = (USB_INT32U)ed;
Gruenfrosch 0:7627c79db971 340 LPC_USB->HcCommandStatus = LPC_USB->HcCommandStatus | OR_CMD_STATUS_BLF;
Gruenfrosch 0:7627c79db971 341 LPC_USB->HcControl = LPC_USB->HcControl | OR_CONTROL_BLE;
Gruenfrosch 0:7627c79db971 342 }
Gruenfrosch 0:7627c79db971 343
Gruenfrosch 0:7627c79db971 344 Host_WDHWait();
Gruenfrosch 0:7627c79db971 345
Gruenfrosch 0:7627c79db971 346 // if (!(TDHead->Control & 0xF0000000)) {
Gruenfrosch 0:7627c79db971 347 if (!HOST_TDControlStatus) {
Gruenfrosch 0:7627c79db971 348 return (OK);
Gruenfrosch 0:7627c79db971 349 } else {
Gruenfrosch 0:7627c79db971 350 return (ERR_TD_FAIL);
Gruenfrosch 0:7627c79db971 351 }
Gruenfrosch 0:7627c79db971 352 }
Gruenfrosch 0:7627c79db971 353
Gruenfrosch 0:7627c79db971 354 /*
Gruenfrosch 0:7627c79db971 355 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 356 * ENUMERATE THE DEVICE
Gruenfrosch 0:7627c79db971 357 *
Gruenfrosch 0:7627c79db971 358 * Description: This function is used to enumerate the device connected
Gruenfrosch 0:7627c79db971 359 *
Gruenfrosch 0:7627c79db971 360 * Arguments : None
Gruenfrosch 0:7627c79db971 361 *
Gruenfrosch 0:7627c79db971 362 * Returns : None
Gruenfrosch 0:7627c79db971 363 *
Gruenfrosch 0:7627c79db971 364 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 365 */
Gruenfrosch 0:7627c79db971 366
Gruenfrosch 0:7627c79db971 367 USB_INT32S Host_EnumDev (void)
Gruenfrosch 0:7627c79db971 368 {
Gruenfrosch 0:7627c79db971 369 USB_INT32S rc;
Gruenfrosch 0:7627c79db971 370
Gruenfrosch 0:7627c79db971 371 PRINT_Log("Connect a Mass Storage device\n");
Gruenfrosch 0:7627c79db971 372 while (!HOST_RhscIntr)
Gruenfrosch 0:7627c79db971 373 __WFI();
Gruenfrosch 0:7627c79db971 374 Host_DelayMS(100); /* USB 2.0 spec says atleast 50ms delay beore port reset */
Gruenfrosch 0:7627c79db971 375 LPC_USB->HcRhPortStatus1 = OR_RH_PORT_PRS; // Initiate port reset
Gruenfrosch 0:7627c79db971 376 while (LPC_USB->HcRhPortStatus1 & OR_RH_PORT_PRS)
Gruenfrosch 0:7627c79db971 377 __WFI(); // Wait for port reset to complete...
Gruenfrosch 0:7627c79db971 378 LPC_USB->HcRhPortStatus1 = OR_RH_PORT_PRSC; // ...and clear port reset signal
Gruenfrosch 0:7627c79db971 379 Host_DelayMS(200); /* Wait for 100 MS after port reset */
Gruenfrosch 0:7627c79db971 380
Gruenfrosch 0:7627c79db971 381 EDCtrl->Control = 8 << 16; /* Put max pkt size = 8 */
Gruenfrosch 0:7627c79db971 382 /* Read first 8 bytes of device desc */
Gruenfrosch 0:7627c79db971 383 rc = HOST_GET_DESCRIPTOR(USB_DESCRIPTOR_TYPE_DEVICE, 0, TDBuffer, 8);
Gruenfrosch 0:7627c79db971 384 if (rc != OK) {
Gruenfrosch 0:7627c79db971 385 PRINT_Err(rc);
Gruenfrosch 0:7627c79db971 386 return (rc);
Gruenfrosch 0:7627c79db971 387 }
Gruenfrosch 0:7627c79db971 388 EDCtrl->Control = TDBuffer[7] << 16; /* Get max pkt size of endpoint 0 */
Gruenfrosch 0:7627c79db971 389 rc = HOST_SET_ADDRESS(1); /* Set the device address to 1 */
Gruenfrosch 0:7627c79db971 390 if (rc != OK) {
Gruenfrosch 0:7627c79db971 391 PRINT_Err(rc);
Gruenfrosch 0:7627c79db971 392 return (rc);
Gruenfrosch 0:7627c79db971 393 }
Gruenfrosch 0:7627c79db971 394 Host_DelayMS(2);
Gruenfrosch 0:7627c79db971 395 EDCtrl->Control = (EDCtrl->Control) | 1; /* Modify control pipe with address 1 */
Gruenfrosch 0:7627c79db971 396 /* Get the configuration descriptor */
Gruenfrosch 0:7627c79db971 397 rc = HOST_GET_DESCRIPTOR(USB_DESCRIPTOR_TYPE_CONFIGURATION, 0, TDBuffer, 9);
Gruenfrosch 0:7627c79db971 398 if (rc != OK) {
Gruenfrosch 0:7627c79db971 399 PRINT_Err(rc);
Gruenfrosch 0:7627c79db971 400 return (rc);
Gruenfrosch 0:7627c79db971 401 }
Gruenfrosch 0:7627c79db971 402 /* Get the first configuration data */
Gruenfrosch 0:7627c79db971 403 rc = HOST_GET_DESCRIPTOR(USB_DESCRIPTOR_TYPE_CONFIGURATION, 0, TDBuffer, ReadLE16U(&TDBuffer[2]));
Gruenfrosch 0:7627c79db971 404 if (rc != OK) {
Gruenfrosch 0:7627c79db971 405 PRINT_Err(rc);
Gruenfrosch 0:7627c79db971 406 return (rc);
Gruenfrosch 0:7627c79db971 407 }
Gruenfrosch 0:7627c79db971 408 rc = MS_ParseConfiguration(); /* Parse the configuration */
Gruenfrosch 0:7627c79db971 409 if (rc != OK) {
Gruenfrosch 0:7627c79db971 410 PRINT_Err(rc);
Gruenfrosch 0:7627c79db971 411 return (rc);
Gruenfrosch 0:7627c79db971 412 }
Gruenfrosch 0:7627c79db971 413 rc = USBH_SET_CONFIGURATION(1); /* Select device configuration 1 */
Gruenfrosch 0:7627c79db971 414 if (rc != OK) {
Gruenfrosch 0:7627c79db971 415 PRINT_Err(rc);
Gruenfrosch 0:7627c79db971 416 }
Gruenfrosch 0:7627c79db971 417 Host_DelayMS(100); /* Some devices may require this delay */
Gruenfrosch 0:7627c79db971 418 return (rc);
Gruenfrosch 0:7627c79db971 419 }
Gruenfrosch 0:7627c79db971 420
Gruenfrosch 0:7627c79db971 421 /*
Gruenfrosch 0:7627c79db971 422 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 423 * RECEIVE THE CONTROL INFORMATION
Gruenfrosch 0:7627c79db971 424 *
Gruenfrosch 0:7627c79db971 425 * Description: This function is used to receive the control information
Gruenfrosch 0:7627c79db971 426 *
Gruenfrosch 0:7627c79db971 427 * Arguments : bm_request_type
Gruenfrosch 0:7627c79db971 428 * b_request
Gruenfrosch 0:7627c79db971 429 * w_value
Gruenfrosch 0:7627c79db971 430 * w_index
Gruenfrosch 0:7627c79db971 431 * w_length
Gruenfrosch 0:7627c79db971 432 * buffer
Gruenfrosch 0:7627c79db971 433 *
Gruenfrosch 0:7627c79db971 434 * Returns : OK if Success
Gruenfrosch 0:7627c79db971 435 * ERROR if Failed
Gruenfrosch 0:7627c79db971 436 *
Gruenfrosch 0:7627c79db971 437 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 438 */
Gruenfrosch 0:7627c79db971 439
Gruenfrosch 0:7627c79db971 440 USB_INT32S Host_CtrlRecv ( USB_INT08U bm_request_type,
Gruenfrosch 0:7627c79db971 441 USB_INT08U b_request,
Gruenfrosch 0:7627c79db971 442 USB_INT16U w_value,
Gruenfrosch 0:7627c79db971 443 USB_INT16U w_index,
Gruenfrosch 0:7627c79db971 444 USB_INT16U w_length,
Gruenfrosch 0:7627c79db971 445 volatile USB_INT08U *buffer)
Gruenfrosch 0:7627c79db971 446 {
Gruenfrosch 0:7627c79db971 447 USB_INT32S rc;
Gruenfrosch 0:7627c79db971 448
Gruenfrosch 0:7627c79db971 449
Gruenfrosch 0:7627c79db971 450 Host_FillSetup(bm_request_type, b_request, w_value, w_index, w_length);
Gruenfrosch 0:7627c79db971 451 rc = Host_ProcessTD(EDCtrl, TD_SETUP, TDBuffer, 8);
Gruenfrosch 0:7627c79db971 452 if (rc == OK) {
Gruenfrosch 0:7627c79db971 453 if (w_length) {
Gruenfrosch 0:7627c79db971 454 rc = Host_ProcessTD(EDCtrl, TD_IN, TDBuffer, w_length);
Gruenfrosch 0:7627c79db971 455 }
Gruenfrosch 0:7627c79db971 456 if (rc == OK) {
Gruenfrosch 0:7627c79db971 457 rc = Host_ProcessTD(EDCtrl, TD_OUT, NULL, 0);
Gruenfrosch 0:7627c79db971 458 }
Gruenfrosch 0:7627c79db971 459 }
Gruenfrosch 0:7627c79db971 460 return (rc);
Gruenfrosch 0:7627c79db971 461 }
Gruenfrosch 0:7627c79db971 462
Gruenfrosch 0:7627c79db971 463 /*
Gruenfrosch 0:7627c79db971 464 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 465 * SEND THE CONTROL INFORMATION
Gruenfrosch 0:7627c79db971 466 *
Gruenfrosch 0:7627c79db971 467 * Description: This function is used to send the control information
Gruenfrosch 0:7627c79db971 468 *
Gruenfrosch 0:7627c79db971 469 * Arguments : None
Gruenfrosch 0:7627c79db971 470 *
Gruenfrosch 0:7627c79db971 471 * Returns : OK if Success
Gruenfrosch 0:7627c79db971 472 * ERR_INVALID_BOOTSIG if Failed
Gruenfrosch 0:7627c79db971 473 *
Gruenfrosch 0:7627c79db971 474 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 475 */
Gruenfrosch 0:7627c79db971 476
Gruenfrosch 0:7627c79db971 477 USB_INT32S Host_CtrlSend ( USB_INT08U bm_request_type,
Gruenfrosch 0:7627c79db971 478 USB_INT08U b_request,
Gruenfrosch 0:7627c79db971 479 USB_INT16U w_value,
Gruenfrosch 0:7627c79db971 480 USB_INT16U w_index,
Gruenfrosch 0:7627c79db971 481 USB_INT16U w_length,
Gruenfrosch 0:7627c79db971 482 volatile USB_INT08U *buffer)
Gruenfrosch 0:7627c79db971 483 {
Gruenfrosch 0:7627c79db971 484 USB_INT32S rc;
Gruenfrosch 0:7627c79db971 485
Gruenfrosch 0:7627c79db971 486
Gruenfrosch 0:7627c79db971 487 Host_FillSetup(bm_request_type, b_request, w_value, w_index, w_length);
Gruenfrosch 0:7627c79db971 488
Gruenfrosch 0:7627c79db971 489 rc = Host_ProcessTD(EDCtrl, TD_SETUP, TDBuffer, 8);
Gruenfrosch 0:7627c79db971 490 if (rc == OK) {
Gruenfrosch 0:7627c79db971 491 if (w_length) {
Gruenfrosch 0:7627c79db971 492 rc = Host_ProcessTD(EDCtrl, TD_OUT, TDBuffer, w_length);
Gruenfrosch 0:7627c79db971 493 }
Gruenfrosch 0:7627c79db971 494 if (rc == OK) {
Gruenfrosch 0:7627c79db971 495 rc = Host_ProcessTD(EDCtrl, TD_IN, NULL, 0);
Gruenfrosch 0:7627c79db971 496 }
Gruenfrosch 0:7627c79db971 497 }
Gruenfrosch 0:7627c79db971 498 return (rc);
Gruenfrosch 0:7627c79db971 499 }
Gruenfrosch 0:7627c79db971 500
Gruenfrosch 0:7627c79db971 501 /*
Gruenfrosch 0:7627c79db971 502 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 503 * FILL SETUP PACKET
Gruenfrosch 0:7627c79db971 504 *
Gruenfrosch 0:7627c79db971 505 * Description: This function is used to fill the setup packet
Gruenfrosch 0:7627c79db971 506 *
Gruenfrosch 0:7627c79db971 507 * Arguments : None
Gruenfrosch 0:7627c79db971 508 *
Gruenfrosch 0:7627c79db971 509 * Returns : OK if Success
Gruenfrosch 0:7627c79db971 510 * ERR_INVALID_BOOTSIG if Failed
Gruenfrosch 0:7627c79db971 511 *
Gruenfrosch 0:7627c79db971 512 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 513 */
Gruenfrosch 0:7627c79db971 514
Gruenfrosch 0:7627c79db971 515 void Host_FillSetup (USB_INT08U bm_request_type,
Gruenfrosch 0:7627c79db971 516 USB_INT08U b_request,
Gruenfrosch 0:7627c79db971 517 USB_INT16U w_value,
Gruenfrosch 0:7627c79db971 518 USB_INT16U w_index,
Gruenfrosch 0:7627c79db971 519 USB_INT16U w_length)
Gruenfrosch 0:7627c79db971 520 {
Gruenfrosch 0:7627c79db971 521 int i;
Gruenfrosch 0:7627c79db971 522 for (i=0;i<w_length;i++)
Gruenfrosch 0:7627c79db971 523 TDBuffer[i] = 0;
Gruenfrosch 0:7627c79db971 524
Gruenfrosch 0:7627c79db971 525 TDBuffer[0] = bm_request_type;
Gruenfrosch 0:7627c79db971 526 TDBuffer[1] = b_request;
Gruenfrosch 0:7627c79db971 527 WriteLE16U(&TDBuffer[2], w_value);
Gruenfrosch 0:7627c79db971 528 WriteLE16U(&TDBuffer[4], w_index);
Gruenfrosch 0:7627c79db971 529 WriteLE16U(&TDBuffer[6], w_length);
Gruenfrosch 0:7627c79db971 530 }
Gruenfrosch 0:7627c79db971 531
Gruenfrosch 0:7627c79db971 532
Gruenfrosch 0:7627c79db971 533
Gruenfrosch 0:7627c79db971 534 /*
Gruenfrosch 0:7627c79db971 535 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 536 * INITIALIZE THE TRANSFER DESCRIPTOR
Gruenfrosch 0:7627c79db971 537 *
Gruenfrosch 0:7627c79db971 538 * Description: This function initializes transfer descriptor
Gruenfrosch 0:7627c79db971 539 *
Gruenfrosch 0:7627c79db971 540 * Arguments : Pointer to TD structure
Gruenfrosch 0:7627c79db971 541 *
Gruenfrosch 0:7627c79db971 542 * Returns : None
Gruenfrosch 0:7627c79db971 543 *
Gruenfrosch 0:7627c79db971 544 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 545 */
Gruenfrosch 0:7627c79db971 546
Gruenfrosch 0:7627c79db971 547 void Host_TDInit (volatile HCTD *td)
Gruenfrosch 0:7627c79db971 548 {
Gruenfrosch 0:7627c79db971 549
Gruenfrosch 0:7627c79db971 550 td->Control = 0;
Gruenfrosch 0:7627c79db971 551 td->CurrBufPtr = 0;
Gruenfrosch 0:7627c79db971 552 td->Next = 0;
Gruenfrosch 0:7627c79db971 553 td->BufEnd = 0;
Gruenfrosch 0:7627c79db971 554 }
Gruenfrosch 0:7627c79db971 555
Gruenfrosch 0:7627c79db971 556 /*
Gruenfrosch 0:7627c79db971 557 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 558 * INITIALIZE THE ENDPOINT DESCRIPTOR
Gruenfrosch 0:7627c79db971 559 *
Gruenfrosch 0:7627c79db971 560 * Description: This function initializes endpoint descriptor
Gruenfrosch 0:7627c79db971 561 *
Gruenfrosch 0:7627c79db971 562 * Arguments : Pointer to ED strcuture
Gruenfrosch 0:7627c79db971 563 *
Gruenfrosch 0:7627c79db971 564 * Returns : None
Gruenfrosch 0:7627c79db971 565 *
Gruenfrosch 0:7627c79db971 566 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 567 */
Gruenfrosch 0:7627c79db971 568
Gruenfrosch 0:7627c79db971 569 void Host_EDInit (volatile HCED *ed)
Gruenfrosch 0:7627c79db971 570 {
Gruenfrosch 0:7627c79db971 571
Gruenfrosch 0:7627c79db971 572 ed->Control = 0;
Gruenfrosch 0:7627c79db971 573 ed->TailTd = 0;
Gruenfrosch 0:7627c79db971 574 ed->HeadTd = 0;
Gruenfrosch 0:7627c79db971 575 ed->Next = 0;
Gruenfrosch 0:7627c79db971 576 }
Gruenfrosch 0:7627c79db971 577
Gruenfrosch 0:7627c79db971 578 /*
Gruenfrosch 0:7627c79db971 579 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 580 * INITIALIZE HOST CONTROLLER COMMUNICATIONS AREA
Gruenfrosch 0:7627c79db971 581 *
Gruenfrosch 0:7627c79db971 582 * Description: This function initializes host controller communications area
Gruenfrosch 0:7627c79db971 583 *
Gruenfrosch 0:7627c79db971 584 * Arguments : Pointer to HCCA
Gruenfrosch 0:7627c79db971 585 *
Gruenfrosch 0:7627c79db971 586 * Returns :
Gruenfrosch 0:7627c79db971 587 *
Gruenfrosch 0:7627c79db971 588 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 589 */
Gruenfrosch 0:7627c79db971 590
Gruenfrosch 0:7627c79db971 591 void Host_HCCAInit (volatile HCCA *hcca)
Gruenfrosch 0:7627c79db971 592 {
Gruenfrosch 0:7627c79db971 593 USB_INT32U i;
Gruenfrosch 0:7627c79db971 594
Gruenfrosch 0:7627c79db971 595
Gruenfrosch 0:7627c79db971 596 for (i = 0; i < 32; i++) {
Gruenfrosch 0:7627c79db971 597
Gruenfrosch 0:7627c79db971 598 hcca->IntTable[i] = 0;
Gruenfrosch 0:7627c79db971 599 hcca->FrameNumber = 0;
Gruenfrosch 0:7627c79db971 600 hcca->DoneHead = 0;
Gruenfrosch 0:7627c79db971 601 }
Gruenfrosch 0:7627c79db971 602
Gruenfrosch 0:7627c79db971 603 }
Gruenfrosch 0:7627c79db971 604
Gruenfrosch 0:7627c79db971 605 /*
Gruenfrosch 0:7627c79db971 606 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 607 * WAIT FOR WDH INTERRUPT
Gruenfrosch 0:7627c79db971 608 *
Gruenfrosch 0:7627c79db971 609 * Description: This function is infinite loop which breaks when ever a WDH interrupt rises
Gruenfrosch 0:7627c79db971 610 *
Gruenfrosch 0:7627c79db971 611 * Arguments : None
Gruenfrosch 0:7627c79db971 612 *
Gruenfrosch 0:7627c79db971 613 * Returns : None
Gruenfrosch 0:7627c79db971 614 *
Gruenfrosch 0:7627c79db971 615 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 616 */
Gruenfrosch 0:7627c79db971 617
Gruenfrosch 0:7627c79db971 618 void Host_WDHWait (void)
Gruenfrosch 0:7627c79db971 619 {
Gruenfrosch 0:7627c79db971 620 while (!HOST_WdhIntr)
Gruenfrosch 0:7627c79db971 621 __WFI();
Gruenfrosch 0:7627c79db971 622
Gruenfrosch 0:7627c79db971 623 HOST_WdhIntr = 0;
Gruenfrosch 0:7627c79db971 624 }
Gruenfrosch 0:7627c79db971 625
Gruenfrosch 0:7627c79db971 626 /*
Gruenfrosch 0:7627c79db971 627 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 628 * READ LE 32U
Gruenfrosch 0:7627c79db971 629 *
Gruenfrosch 0:7627c79db971 630 * Description: This function is used to read an unsigned integer from a character buffer in the platform
Gruenfrosch 0:7627c79db971 631 * containing little endian processor
Gruenfrosch 0:7627c79db971 632 *
Gruenfrosch 0:7627c79db971 633 * Arguments : pmem Pointer to the character buffer
Gruenfrosch 0:7627c79db971 634 *
Gruenfrosch 0:7627c79db971 635 * Returns : val Unsigned integer
Gruenfrosch 0:7627c79db971 636 *
Gruenfrosch 0:7627c79db971 637 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 638 */
Gruenfrosch 0:7627c79db971 639
Gruenfrosch 0:7627c79db971 640 USB_INT32U ReadLE32U (volatile USB_INT08U *pmem)
Gruenfrosch 0:7627c79db971 641 {
Gruenfrosch 0:7627c79db971 642 USB_INT32U val = *(USB_INT32U*)pmem;
Gruenfrosch 0:7627c79db971 643 #ifdef __BIG_ENDIAN
Gruenfrosch 0:7627c79db971 644 return __REV(val);
Gruenfrosch 0:7627c79db971 645 #else
Gruenfrosch 0:7627c79db971 646 return val;
Gruenfrosch 0:7627c79db971 647 #endif
Gruenfrosch 0:7627c79db971 648 }
Gruenfrosch 0:7627c79db971 649
Gruenfrosch 0:7627c79db971 650 /*
Gruenfrosch 0:7627c79db971 651 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 652 * WRITE LE 32U
Gruenfrosch 0:7627c79db971 653 *
Gruenfrosch 0:7627c79db971 654 * Description: This function is used to write an unsigned integer into a charecter buffer in the platform
Gruenfrosch 0:7627c79db971 655 * containing little endian processor.
Gruenfrosch 0:7627c79db971 656 *
Gruenfrosch 0:7627c79db971 657 * Arguments : pmem Pointer to the charecter buffer
Gruenfrosch 0:7627c79db971 658 * val Integer value to be placed in the charecter buffer
Gruenfrosch 0:7627c79db971 659 *
Gruenfrosch 0:7627c79db971 660 * Returns : None
Gruenfrosch 0:7627c79db971 661 *
Gruenfrosch 0:7627c79db971 662 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 663 */
Gruenfrosch 0:7627c79db971 664
Gruenfrosch 0:7627c79db971 665 void WriteLE32U (volatile USB_INT08U *pmem,
Gruenfrosch 0:7627c79db971 666 USB_INT32U val)
Gruenfrosch 0:7627c79db971 667 {
Gruenfrosch 0:7627c79db971 668 #ifdef __BIG_ENDIAN
Gruenfrosch 0:7627c79db971 669 *(USB_INT32U*)pmem = __REV(val);
Gruenfrosch 0:7627c79db971 670 #else
Gruenfrosch 0:7627c79db971 671 *(USB_INT32U*)pmem = val;
Gruenfrosch 0:7627c79db971 672 #endif
Gruenfrosch 0:7627c79db971 673 }
Gruenfrosch 0:7627c79db971 674
Gruenfrosch 0:7627c79db971 675 /*
Gruenfrosch 0:7627c79db971 676 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 677 * READ LE 16U
Gruenfrosch 0:7627c79db971 678 *
Gruenfrosch 0:7627c79db971 679 * Description: This function is used to read an unsigned short integer from a charecter buffer in the platform
Gruenfrosch 0:7627c79db971 680 * containing little endian processor
Gruenfrosch 0:7627c79db971 681 *
Gruenfrosch 0:7627c79db971 682 * Arguments : pmem Pointer to the charecter buffer
Gruenfrosch 0:7627c79db971 683 *
Gruenfrosch 0:7627c79db971 684 * Returns : val Unsigned short integer
Gruenfrosch 0:7627c79db971 685 *
Gruenfrosch 0:7627c79db971 686 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 687 */
Gruenfrosch 0:7627c79db971 688
Gruenfrosch 0:7627c79db971 689 USB_INT16U ReadLE16U (volatile USB_INT08U *pmem)
Gruenfrosch 0:7627c79db971 690 {
Gruenfrosch 0:7627c79db971 691 USB_INT16U val = *(USB_INT16U*)pmem;
Gruenfrosch 0:7627c79db971 692 #ifdef __BIG_ENDIAN
Gruenfrosch 0:7627c79db971 693 return __REV16(val);
Gruenfrosch 0:7627c79db971 694 #else
Gruenfrosch 0:7627c79db971 695 return val;
Gruenfrosch 0:7627c79db971 696 #endif
Gruenfrosch 0:7627c79db971 697 }
Gruenfrosch 0:7627c79db971 698
Gruenfrosch 0:7627c79db971 699 /*
Gruenfrosch 0:7627c79db971 700 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 701 * WRITE LE 16U
Gruenfrosch 0:7627c79db971 702 *
Gruenfrosch 0:7627c79db971 703 * Description: This function is used to write an unsigned short integer into a charecter buffer in the
Gruenfrosch 0:7627c79db971 704 * platform containing little endian processor
Gruenfrosch 0:7627c79db971 705 *
Gruenfrosch 0:7627c79db971 706 * Arguments : pmem Pointer to the charecter buffer
Gruenfrosch 0:7627c79db971 707 * val Value to be placed in the charecter buffer
Gruenfrosch 0:7627c79db971 708 *
Gruenfrosch 0:7627c79db971 709 * Returns : None
Gruenfrosch 0:7627c79db971 710 *
Gruenfrosch 0:7627c79db971 711 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 712 */
Gruenfrosch 0:7627c79db971 713
Gruenfrosch 0:7627c79db971 714 void WriteLE16U (volatile USB_INT08U *pmem,
Gruenfrosch 0:7627c79db971 715 USB_INT16U val)
Gruenfrosch 0:7627c79db971 716 {
Gruenfrosch 0:7627c79db971 717 #ifdef __BIG_ENDIAN
Gruenfrosch 0:7627c79db971 718 *(USB_INT16U*)pmem = (__REV16(val) & 0xFFFF);
Gruenfrosch 0:7627c79db971 719 #else
Gruenfrosch 0:7627c79db971 720 *(USB_INT16U*)pmem = val;
Gruenfrosch 0:7627c79db971 721 #endif
Gruenfrosch 0:7627c79db971 722 }
Gruenfrosch 0:7627c79db971 723
Gruenfrosch 0:7627c79db971 724 /*
Gruenfrosch 0:7627c79db971 725 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 726 * READ BE 32U
Gruenfrosch 0:7627c79db971 727 *
Gruenfrosch 0:7627c79db971 728 * Description: This function is used to read an unsigned integer from a charecter buffer in the platform
Gruenfrosch 0:7627c79db971 729 * containing big endian processor
Gruenfrosch 0:7627c79db971 730 *
Gruenfrosch 0:7627c79db971 731 * Arguments : pmem Pointer to the charecter buffer
Gruenfrosch 0:7627c79db971 732 *
Gruenfrosch 0:7627c79db971 733 * Returns : val Unsigned integer
Gruenfrosch 0:7627c79db971 734 *
Gruenfrosch 0:7627c79db971 735 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 736 */
Gruenfrosch 0:7627c79db971 737
Gruenfrosch 0:7627c79db971 738 USB_INT32U ReadBE32U (volatile USB_INT08U *pmem)
Gruenfrosch 0:7627c79db971 739 {
Gruenfrosch 0:7627c79db971 740 USB_INT32U val = *(USB_INT32U*)pmem;
Gruenfrosch 0:7627c79db971 741 #ifdef __BIG_ENDIAN
Gruenfrosch 0:7627c79db971 742 return val;
Gruenfrosch 0:7627c79db971 743 #else
Gruenfrosch 0:7627c79db971 744 return __REV(val);
Gruenfrosch 0:7627c79db971 745 #endif
Gruenfrosch 0:7627c79db971 746 }
Gruenfrosch 0:7627c79db971 747
Gruenfrosch 0:7627c79db971 748 /*
Gruenfrosch 0:7627c79db971 749 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 750 * WRITE BE 32U
Gruenfrosch 0:7627c79db971 751 *
Gruenfrosch 0:7627c79db971 752 * Description: This function is used to write an unsigned integer into a charecter buffer in the platform
Gruenfrosch 0:7627c79db971 753 * containing big endian processor
Gruenfrosch 0:7627c79db971 754 *
Gruenfrosch 0:7627c79db971 755 * Arguments : pmem Pointer to the charecter buffer
Gruenfrosch 0:7627c79db971 756 * val Value to be placed in the charecter buffer
Gruenfrosch 0:7627c79db971 757 *
Gruenfrosch 0:7627c79db971 758 * Returns : None
Gruenfrosch 0:7627c79db971 759 *
Gruenfrosch 0:7627c79db971 760 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 761 */
Gruenfrosch 0:7627c79db971 762
Gruenfrosch 0:7627c79db971 763 void WriteBE32U (volatile USB_INT08U *pmem,
Gruenfrosch 0:7627c79db971 764 USB_INT32U val)
Gruenfrosch 0:7627c79db971 765 {
Gruenfrosch 0:7627c79db971 766 #ifdef __BIG_ENDIAN
Gruenfrosch 0:7627c79db971 767 *(USB_INT32U*)pmem = val;
Gruenfrosch 0:7627c79db971 768 #else
Gruenfrosch 0:7627c79db971 769 *(USB_INT32U*)pmem = __REV(val);
Gruenfrosch 0:7627c79db971 770 #endif
Gruenfrosch 0:7627c79db971 771 }
Gruenfrosch 0:7627c79db971 772
Gruenfrosch 0:7627c79db971 773 /*
Gruenfrosch 0:7627c79db971 774 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 775 * READ BE 16U
Gruenfrosch 0:7627c79db971 776 *
Gruenfrosch 0:7627c79db971 777 * Description: This function is used to read an unsigned short integer from a charecter buffer in the platform
Gruenfrosch 0:7627c79db971 778 * containing big endian processor
Gruenfrosch 0:7627c79db971 779 *
Gruenfrosch 0:7627c79db971 780 * Arguments : pmem Pointer to the charecter buffer
Gruenfrosch 0:7627c79db971 781 *
Gruenfrosch 0:7627c79db971 782 * Returns : val Unsigned short integer
Gruenfrosch 0:7627c79db971 783 *
Gruenfrosch 0:7627c79db971 784 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 785 */
Gruenfrosch 0:7627c79db971 786
Gruenfrosch 0:7627c79db971 787 USB_INT16U ReadBE16U (volatile USB_INT08U *pmem)
Gruenfrosch 0:7627c79db971 788 {
Gruenfrosch 0:7627c79db971 789 USB_INT16U val = *(USB_INT16U*)pmem;
Gruenfrosch 0:7627c79db971 790 #ifdef __BIG_ENDIAN
Gruenfrosch 0:7627c79db971 791 return val;
Gruenfrosch 0:7627c79db971 792 #else
Gruenfrosch 0:7627c79db971 793 return __REV16(val);
Gruenfrosch 0:7627c79db971 794 #endif
Gruenfrosch 0:7627c79db971 795 }
Gruenfrosch 0:7627c79db971 796
Gruenfrosch 0:7627c79db971 797 /*
Gruenfrosch 0:7627c79db971 798 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 799 * WRITE BE 16U
Gruenfrosch 0:7627c79db971 800 *
Gruenfrosch 0:7627c79db971 801 * Description: This function is used to write an unsigned short integer into the charecter buffer in the
Gruenfrosch 0:7627c79db971 802 * platform containing big endian processor
Gruenfrosch 0:7627c79db971 803 *
Gruenfrosch 0:7627c79db971 804 * Arguments : pmem Pointer to the charecter buffer
Gruenfrosch 0:7627c79db971 805 * val Value to be placed in the charecter buffer
Gruenfrosch 0:7627c79db971 806 *
Gruenfrosch 0:7627c79db971 807 * Returns : None
Gruenfrosch 0:7627c79db971 808 *
Gruenfrosch 0:7627c79db971 809 **************************************************************************************************************
Gruenfrosch 0:7627c79db971 810 */
Gruenfrosch 0:7627c79db971 811
Gruenfrosch 0:7627c79db971 812 void WriteBE16U (volatile USB_INT08U *pmem,
Gruenfrosch 0:7627c79db971 813 USB_INT16U val)
Gruenfrosch 0:7627c79db971 814 {
Gruenfrosch 0:7627c79db971 815 #ifdef __BIG_ENDIAN
Gruenfrosch 0:7627c79db971 816 *(USB_INT16U*)pmem = val;
Gruenfrosch 0:7627c79db971 817 #else
Gruenfrosch 0:7627c79db971 818 *(USB_INT16U*)pmem = (__REV16(val) & 0xFFFF);
Gruenfrosch 0:7627c79db971 819 #endif
Gruenfrosch 0:7627c79db971 820 }