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