HardwareProfile - Low Pin Count USB Development Kit.h 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. /********************************************************************
  2. FileName: HardwareProfile - Low Pin Count USB Development Kit.h
  3. Dependencies: See INCLUDES section
  4. Processor: PIC18 or PIC24 USB Microcontrollers
  5. Hardware: Low Pin Count USB Development Kit
  6. Compiler: Microchip C18
  7. Company: Microchip Technology, Inc.
  8. Software License Agreement:
  9. The software supplied herewith by Microchip Technology Incorporated
  10. (the “Company”) for its PIC® Microcontroller is intended and
  11. supplied to you, the Company’s customer, for use solely and
  12. exclusively on Microchip PIC Microcontroller products. The
  13. software is owned by the Company and/or its supplier, and is
  14. protected under applicable copyright laws. All rights are reserved.
  15. Any use in violation of the foregoing restrictions may subject the
  16. user to criminal sanctions under applicable laws, as well as to
  17. civil liability for the breach of the terms and conditions of this
  18. license.
  19. THIS SOFTWARE IS PROVIDED IN AN “AS IS” CONDITION. NO WARRANTIES,
  20. WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT NOT LIMITED
  21. TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
  22. PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. THE COMPANY SHALL NOT,
  23. IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL OR
  24. CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
  25. ********************************************************************
  26. File Description:
  27. Change History:
  28. Rev Date Description
  29. 1.0 11/19/2004 Initial release
  30. 2.1 02/26/2007 Updated for simplicity and to use common
  31. coding style
  32. 2.3 09/15/2008 Broke out each hardware platform into its own
  33. "HardwareProfile - xxx.h" file
  34. ********************************************************************/
  35. #ifndef HARDWARE_PROFILE_LOW_PIN_COUNT_USB_DEVELOPMENT_KIT_H
  36. #define HARDWARE_PROFILE_LOW_PIN_COUNT_USB_DEVELOPMENT_KIT_H
  37. /*******************************************************************/
  38. /******** USB stack hardware selection options *********************/
  39. /*******************************************************************/
  40. //This section is the set of definitions required by the MCHPFSUSB
  41. // framework. These definitions tell the firmware what mode it is
  42. // running in, and where it can find the results to some information
  43. // that the stack needs.
  44. //These definitions are required by every application developed with
  45. // this revision of the MCHPFSUSB framework. Please review each
  46. // option carefully and determine which options are desired/required
  47. // for your application.
  48. //#define USE_SELF_POWER_SENSE_IO
  49. #define tris_self_power TRISAbits.TRISA2 // Input
  50. #if defined(USE_SELF_POWER_SENSE_IO)
  51. #define self_power PORTAbits.RA2
  52. #else
  53. #define self_power 1
  54. #endif
  55. //#define USE_USB_BUS_SENSE_IO
  56. #define tris_usb_bus_sense TRISAbits.TRISA1 // Input
  57. #if defined(USE_USB_BUS_SENSE_IO)
  58. #define USB_BUS_SENSE PORTAbits.RA1
  59. #else
  60. #define USB_BUS_SENSE 1
  61. #endif
  62. /*******************************************************************/
  63. /*******************************************************************/
  64. /*******************************************************************/
  65. /******** Application specific definitions *************************/
  66. /*******************************************************************/
  67. /*******************************************************************/
  68. /*******************************************************************/
  69. //Uncomment the following line to make the output HEX of this
  70. // project work with the HID Bootloader
  71. #define PROGRAMMABLE_WITH_USB_HID_BOOTLOADER
  72. /** Board definition ***********************************************/
  73. //These defintions will tell the main() function which board is
  74. // currently selected. This will allow the application to add
  75. // the correct configuration bits as wells use the correct
  76. // initialization functions for the board. These defitions are only
  77. // required in the stack provided demos. They are not required in
  78. // final application design.
  79. #define DEMO_BOARD LOW_PIN_COUNT_USB_DEVELOPMENT_KIT
  80. #define LOW_PIN_COUNT_USB_DEVELOPMENT_KIT
  81. #define CLOCK_FREQ 48000000
  82. /** LED ************************************************************/
  83. #define mInitAllLEDs() LATC &= 0xF0; TRISC &= 0xF0;
  84. #define mLED_1 LATCbits.LATC0
  85. #define mLED_2 LATCbits.LATC1
  86. #define mLED_3 LATCbits.LATC2
  87. #define mLED_4 LATCbits.LATC3
  88. #define mGetLED_1() mLED_1
  89. #define mGetLED_2() mLED_2
  90. #define mGetLED_3() mLED_3
  91. #define mGetLED_4() mLED_4
  92. #define mLED_1_On() mLED_1 = 1;
  93. #define mLED_2_On() mLED_2 = 1;
  94. #define mLED_3_On() mLED_3 = 1;
  95. #define mLED_4_On() mLED_4 = 1;
  96. #define mLED_1_Off() mLED_1 = 0;
  97. #define mLED_2_Off() mLED_2 = 0;
  98. #define mLED_3_Off() mLED_3 = 0;
  99. #define mLED_4_Off() mLED_4 = 0;
  100. #define mLED_1_Toggle() mLED_1 = !mLED_1;
  101. #define mLED_2_Toggle() mLED_2 = !mLED_2;
  102. #define mLED_3_Toggle() mLED_3 = !mLED_3;
  103. #define mLED_4_Toggle() mLED_4 = !mLED_4;
  104. /** SWITCH *********************************************************/
  105. #define mInitSwitch2() //TRISAbits.TRISA3=1
  106. //only one switch available so double duty
  107. #define mInitSwitch3() //TRISAbits.TRISA3=1
  108. #define sw2 PORTAbits.RA3
  109. #define sw3 PORTAbits.RA3
  110. #define mInitAllSwitches() mInitSwitch2();
  111. /** I/O pin definitions ********************************************/
  112. #define INPUT_PIN 1
  113. #define OUTPUT_PIN 0
  114. #endif //HARDWARE_PROFILE_LOW_PIN_COUNT_USB_DEVELOPMENT_KIT_H