Fork to update libraries and fix disk_read/disk_write functions

Dependencies:   FATFileSystem mbed-rtos

Dependents:   lpc4088_qsb_usbhost

Fork of LPC4088-USBHost by Norimasa Okamoto

Committer:
va009039
Date:
Fri Apr 25 05:18:55 2014 +0000
Revision:
0:148fca6fd246
first commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
va009039 0:148fca6fd246 1 /* mbed USBHost Library
va009039 0:148fca6fd246 2 * Copyright (c) 2006-2013 ARM Limited
va009039 0:148fca6fd246 3 *
va009039 0:148fca6fd246 4 * Licensed under the Apache License, Version 2.0 (the "License");
va009039 0:148fca6fd246 5 * you may not use this file except in compliance with the License.
va009039 0:148fca6fd246 6 * You may obtain a copy of the License at
va009039 0:148fca6fd246 7 *
va009039 0:148fca6fd246 8 * http://www.apache.org/licenses/LICENSE-2.0
va009039 0:148fca6fd246 9 *
va009039 0:148fca6fd246 10 * Unless required by applicable law or agreed to in writing, software
va009039 0:148fca6fd246 11 * distributed under the License is distributed on an "AS IS" BASIS,
va009039 0:148fca6fd246 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
va009039 0:148fca6fd246 13 * See the License for the specific language governing permissions and
va009039 0:148fca6fd246 14 * limitations under the License.
va009039 0:148fca6fd246 15 */
va009039 0:148fca6fd246 16
va009039 0:148fca6fd246 17 #ifndef USB_DEBUG_H
va009039 0:148fca6fd246 18 #define USB_DEBUG_H
va009039 0:148fca6fd246 19
va009039 0:148fca6fd246 20 //Debug is disabled by default
va009039 0:148fca6fd246 21 #ifndef DEBUG
va009039 0:148fca6fd246 22 #define DEBUG 3 /*INFO,ERR,WARN*/
va009039 0:148fca6fd246 23 #endif
va009039 0:148fca6fd246 24 #ifndef DEBUG2
va009039 0:148fca6fd246 25 #define DEBUG2 0
va009039 0:148fca6fd246 26 #endif
va009039 0:148fca6fd246 27 #define DEBUG_TRANSFER 0
va009039 0:148fca6fd246 28 #define DEBUG_EP_STATE 0
va009039 0:148fca6fd246 29 #define DEBUG_EVENT 0
va009039 0:148fca6fd246 30
va009039 0:148fca6fd246 31 #if (DEBUG > 3)
va009039 0:148fca6fd246 32 #define USB_DBG(...) do{fprintf(stderr,"[%s@%d] ",__PRETTY_FUNCTION__,__LINE__);fprintf(stderr,__VA_ARGS__);fprintf(stderr,"\r\n");} while(0);
va009039 0:148fca6fd246 33 //#define USB_DBG(x, ...) std::printf("[USB_DBG: %s:%d]" x "\r\n", __FILE__, __LINE__, ##__VA_ARGS__);
va009039 0:148fca6fd246 34 #define USB_DBG_HEX(A,B) debug_hex(A,B)
va009039 0:148fca6fd246 35 extern void debug_hex(uint8_t* buf, int size);
va009039 0:148fca6fd246 36 #define USB_DBG_ERRSTAT() report.print_errstat();
va009039 0:148fca6fd246 37 #else
va009039 0:148fca6fd246 38 #define USB_DBG(x, ...)
va009039 0:148fca6fd246 39 #define USB_DBG_HEX(A,B) while(0)
va009039 0:148fca6fd246 40 #define USB_DBG_ERRSTAT() while(0)
va009039 0:148fca6fd246 41 #endif
va009039 0:148fca6fd246 42
va009039 0:148fca6fd246 43 #if (DEBUG2 > 3)
va009039 0:148fca6fd246 44 #define USB_DBG2(...) do{fprintf(stderr,"[%s@%d] ",__PRETTY_FUNCTION__,__LINE__);fprintf(stderr,__VA_ARGS__);fprintf(stderr,"\r\n");} while(0);
va009039 0:148fca6fd246 45 #else
va009039 0:148fca6fd246 46 #define USB_DBG2(...) while(0);
va009039 0:148fca6fd246 47 #endif
va009039 0:148fca6fd246 48
va009039 0:148fca6fd246 49 #if (DEBUG > 2)
va009039 0:148fca6fd246 50 #define USB_INFO(...) do{fprintf(stderr,__VA_ARGS__);fprintf(stderr,"\r\n");}while(0);
va009039 0:148fca6fd246 51 //#define USB_INFO(x, ...) std::printf("[USB_INFO: %s:%d]" x "\r\n", __FILE__, __LINE__, ##__VA_ARGS__);
va009039 0:148fca6fd246 52 #else
va009039 0:148fca6fd246 53 #define USB_INFO(x, ...)
va009039 0:148fca6fd246 54 #endif
va009039 0:148fca6fd246 55
va009039 0:148fca6fd246 56 #if (DEBUG > 1)
va009039 0:148fca6fd246 57 #define USB_WARN(x, ...) std::printf("[USB_WARNING: %s:%d]" x "\r\n", __FILE__, __LINE__, ##__VA_ARGS__);
va009039 0:148fca6fd246 58 #else
va009039 0:148fca6fd246 59 #define USB_WARN(x, ...)
va009039 0:148fca6fd246 60 #endif
va009039 0:148fca6fd246 61
va009039 0:148fca6fd246 62 #if (DEBUG > 0)
va009039 0:148fca6fd246 63 #define USB_ERR(x, ...) std::printf("[USB_ERR: %s:%d]" x "\r\n", __FILE__, __LINE__, ##__VA_ARGS__);
va009039 0:148fca6fd246 64 #else
va009039 0:148fca6fd246 65 #define USB_ERR(x, ...)
va009039 0:148fca6fd246 66 #endif
va009039 0:148fca6fd246 67
va009039 0:148fca6fd246 68 #if (DEBUG_TRANSFER)
va009039 0:148fca6fd246 69 #define USB_DBG_TRANSFER(x, ...) std::printf("[USB_TRANSFER: %s:%d]" x "\r\n", __FILE__, __LINE__, ##__VA_ARGS__);
va009039 0:148fca6fd246 70 #else
va009039 0:148fca6fd246 71 #define USB_DBG_TRANSFER(x, ...)
va009039 0:148fca6fd246 72 #endif
va009039 0:148fca6fd246 73
va009039 0:148fca6fd246 74 #if (DEBUG_EVENT)
va009039 0:148fca6fd246 75 #define USB_DBG_EVENT(x, ...) std::printf("[USB_EVENT: %s:%d]" x "\r\n", __FILE__, __LINE__, ##__VA_ARGS__);
va009039 0:148fca6fd246 76 #else
va009039 0:148fca6fd246 77 #define USB_DBG_EVENT(x, ...)
va009039 0:148fca6fd246 78 #endif
va009039 0:148fca6fd246 79
va009039 0:148fca6fd246 80 template <bool>struct CtAssert;
va009039 0:148fca6fd246 81 template <>struct CtAssert<true> {};
va009039 0:148fca6fd246 82 #define CTASSERT(A) CtAssert<A>();
va009039 0:148fca6fd246 83
va009039 0:148fca6fd246 84 #ifdef _USB_TEST
va009039 0:148fca6fd246 85 #define USB_TEST_ASSERT(A) while(!(A)){fprintf(stderr,"\n\n%s@%d %s ASSERT!\n\n",__PRETTY_FUNCTION__,__LINE__,#A);exit(1);};
va009039 0:148fca6fd246 86 #define USB_TEST_ASSERT_FALSE(A) USB_TEST_ASSERT(!(A))
va009039 0:148fca6fd246 87 #else
va009039 0:148fca6fd246 88 #define USB_TEST_ASSERT(A) while(0)
va009039 0:148fca6fd246 89 #define USB_TEST_ASSERT_FALSE(A) while(0)
va009039 0:148fca6fd246 90 #endif
va009039 0:148fca6fd246 91
va009039 0:148fca6fd246 92 #endif
va009039 0:148fca6fd246 93