Rev 1661 Rev 1711
1 /******************************************************************** 1 /********************************************************************
2 FileName: HardwareProfile - PIC24FJ256GB110 PIM.h 2 FileName: HardwareProfile - PIC24FJ256GB110 PIM.h
3 Dependencies: See INCLUDES section 3 Dependencies: See INCLUDES section
4 Processor: PIC24FJ256GB110 4 Processor: PIC24FJ256GB110
5 Hardware: PIC24FJ256GB110 PIM 5 Hardware: PIC24FJ256GB110 PIM
6 Compiler: Microchip C30 6 Compiler: Microchip C30
7 Company: Microchip Technology, Inc. 7 Company: Microchip Technology, Inc.
8   8  
9 Software License Agreement: 9 Software License Agreement:
10   10  
11 The software supplied herewith by Microchip Technology Incorporated 11 The software supplied herewith by Microchip Technology Incorporated
12 (the “Company”) for its PIC® Microcontroller is intended and 12 (the “Company”) for its PIC® Microcontroller is intended and
13 supplied to you, the Company’s customer, for use solely and 13 supplied to you, the Company’s customer, for use solely and
14 exclusively on Microchip PIC Microcontroller products. The 14 exclusively on Microchip PIC Microcontroller products. The
15 software is owned by the Company and/or its supplier, and is 15 software is owned by the Company and/or its supplier, and is
16 protected under applicable copyright laws. All rights are reserved. 16 protected under applicable copyright laws. All rights are reserved.
17 Any use in violation of the foregoing restrictions may subject the 17 Any use in violation of the foregoing restrictions may subject the
18 user to criminal sanctions under applicable laws, as well as to 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 19 civil liability for the breach of the terms and conditions of this
20 license. 20 license.
21   21  
22 THIS SOFTWARE IS PROVIDED IN AN “AS IS” CONDITION. NO WARRANTIES, 22 THIS SOFTWARE IS PROVIDED IN AN “AS IS” CONDITION. NO WARRANTIES,
23 WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT NOT LIMITED 23 WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT NOT LIMITED
24 TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A 24 TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
25 PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. THE COMPANY SHALL NOT, 25 PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. THE COMPANY SHALL NOT,
26 IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL OR 26 IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL OR
27 CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER. 27 CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
28   28  
29 ******************************************************************** 29 ********************************************************************
30 File Description: 30 File Description:
31   31  
32 Change History: 32 Change History:
33 Rev Date Description 33 Rev Date Description
34 1.0 11/19/2004 Initial release 34 1.0 11/19/2004 Initial release
35 2.1 02/26/2007 Updated for simplicity and to use common 35 2.1 02/26/2007 Updated for simplicity and to use common
36 coding style 36 coding style
37 2.3 09/15/2008 Broke out each hardware platform into its own 37 2.3 09/15/2008 Broke out each hardware platform into its own
38 "HardwareProfile - xxx.h" file 38 "HardwareProfile - xxx.h" file
39 ********************************************************************/ 39 ********************************************************************/
40   40  
41 #ifndef HARDWARE_PROFILE_PIC24FJ256GB110_PIM_H 41 #ifndef HARDWARE_PROFILE_PIC24FJ256GB110_PIM_H
42 #define HARDWARE_PROFILE_PIC24FJ256GB110_PIM_H 42 #define HARDWARE_PROFILE_PIC24FJ256GB110_PIM_H
43   43  
44 /*******************************************************************/ 44 /*******************************************************************/
45 /******** USB stack hardware selection options *********************/ 45 /******** USB stack hardware selection options *********************/
46 /*******************************************************************/ 46 /*******************************************************************/
47 //This section is the set of definitions required by the MCHPFSUSB 47 //This section is the set of definitions required by the MCHPFSUSB
48 // framework. These definitions tell the firmware what mode it is 48 // framework. These definitions tell the firmware what mode it is
49 // running in, and where it can find the results to some information 49 // running in, and where it can find the results to some information
50 // that the stack needs. 50 // that the stack needs.
51 //These definitions are required by every application developed with 51 //These definitions are required by every application developed with
52 // this revision of the MCHPFSUSB framework. Please review each 52 // this revision of the MCHPFSUSB framework. Please review each
53 // option carefully and determine which options are desired/required 53 // option carefully and determine which options are desired/required
54 // for your application. 54 // for your application.
55   55  
56 //#define USE_SELF_POWER_SENSE_IO 56 //#define USE_SELF_POWER_SENSE_IO
57 #define tris_self_power TRISAbits.TRISA2 // Input 57 #define tris_self_power TRISAbits.TRISA2 // Input
58 #define self_power 1 58 #define self_power 1
59   59  
60 //#define USE_USB_BUS_SENSE_IO 60 //#define USE_USB_BUS_SENSE_IO
61 #define tris_usb_bus_sense TRISBbits.TRISB5 // Input 61 #define tris_usb_bus_sense TRISBbits.TRISB5 // Input
62 #define USB_BUS_SENSE 1 62 #define USB_BUS_SENSE 1
63 63
64 //Uncomment this to make the output HEX of this project 64 //Uncomment this to make the output HEX of this project
65 // to be able to be bootloaded using the HID bootloader 65 // to be able to be bootloaded using the HID bootloader
66 #define PROGRAMMABLE_WITH_USB_HID_BOOTLOADER 66 #define PROGRAMMABLE_WITH_USB_HID_BOOTLOADER
67   67  
68 //If the application is going to be used with the HID bootloader 68 //If the application is going to be used with the HID bootloader
69 // then this will provide a function for the application to 69 // then this will provide a function for the application to
70 // enter the bootloader from the application (optional) 70 // enter the bootloader from the application (optional)
71 #if defined(PROGRAMMABLE_WITH_USB_HID_BOOTLOADER) 71 #if defined(PROGRAMMABLE_WITH_USB_HID_BOOTLOADER)
72 #define EnterBootloader() __asm__("goto 0x400") 72 #define EnterBootloader() __asm__("goto 0x400")
73 #endif 73 #endif
74   74  
75   75  
76 /*******************************************************************/ 76 /*******************************************************************/
77 /*******************************************************************/ 77 /*******************************************************************/
78 /*******************************************************************/ 78 /*******************************************************************/
79 /******** Application specific definitions *************************/ 79 /******** Application specific definitions *************************/
80 /*******************************************************************/ 80 /*******************************************************************/
81 /*******************************************************************/ 81 /*******************************************************************/
82 /*******************************************************************/ 82 /*******************************************************************/
83   83  
84 /** Board definition ***********************************************/ 84 /** Board definition ***********************************************/
85 //These defintions will tell the main() function which board is 85 //These defintions will tell the main() function which board is
86 // currently selected. This will allow the application to add 86 // currently selected. This will allow the application to add
87 // the correct configuration bits as wells use the correct 87 // the correct configuration bits as wells use the correct
88 // initialization functions for the board. These defitions are only 88 // initialization functions for the board. These defitions are only
89 // required in the stack provided demos. They are not required in 89 // required in the stack provided demos. They are not required in
90 // final application design. 90 // final application design.
91 #define DEMO_BOARD PIC24FJ256GB110_PIM 91 #define DEMO_BOARD PIC24FJ256GB110_PIM
92 #define EXPLORER_16 92 #define EXPLORER_16
93 #define PIC24FJ256GB110_PIM 93 #define PIC24FJ256GB110_PIM
94 #define CLOCK_FREQ 32000000 94 #define CLOCK_FREQ 32000000
95 #define GetSystemClock() CLOCK_FREQ 95 #define GetSystemClock() CLOCK_FREQ
96 #define GetInstructionClock() GetSystemClock() 96 #define GetInstructionClock() GetSystemClock()
97 97
98 /** LED ************************************************************/ 98 /** LED ************************************************************/
99 #define mInitAllLEDs() LATA &= 0xF0; TRISA &= 0xF0; 99 #define mInitAllLEDs() LATA &= 0xF0; TRISA &= 0xF0;
100 100
101 #define mLED_1 LATAbits.LATA0 101 #define mLED_1 LATAbits.LATA0
102 #define mLED_2 LATAbits.LATA1 102 #define mLED_2 LATAbits.LATA1
103 #define mLED_3 LATAbits.LATA2 103 #define mLED_3 LATAbits.LATA2
104 #define mLED_4 LATAbits.LATA3 104 #define mLED_4 LATAbits.LATA3
105   105  
106 #define mGetLED_1() mLED_1 106 #define mGetLED_1() mLED_1
107 #define mGetLED_2() mLED_2 107 #define mGetLED_2() mLED_2
108 #define mGetLED_3() mLED_3 108 #define mGetLED_3() mLED_3
109 #define mGetLED_4() mLED_4 109 #define mGetLED_4() mLED_4
110 110
111 #define mLED_1_On() mLED_1 = 1; 111 #define mLED_1_On() mLED_1 = 1;
112 #define mLED_2_On() mLED_2 = 1; 112 #define mLED_2_On() mLED_2 = 1;
113 #define mLED_3_On() mLED_3 = 1; 113 #define mLED_3_On() mLED_3 = 1;
114 #define mLED_4_On() mLED_4 = 1; 114 #define mLED_4_On() mLED_4 = 1;
115 115
116 #define mLED_1_Off() mLED_1 = 0; 116 #define mLED_1_Off() mLED_1 = 0;
117 #define mLED_2_Off() mLED_2 = 0; 117 #define mLED_2_Off() mLED_2 = 0;
118 #define mLED_3_Off() mLED_3 = 0; 118 #define mLED_3_Off() mLED_3 = 0;
119 #define mLED_4_Off() mLED_4 = 0; 119 #define mLED_4_Off() mLED_4 = 0;
120 120
121 #define mLED_1_Toggle() mLED_1 = !mLED_1; 121 #define mLED_1_Toggle() mLED_1 = !mLED_1;
122 #define mLED_2_Toggle() mLED_2 = !mLED_2; 122 #define mLED_2_Toggle() mLED_2 = !mLED_2;
123 #define mLED_3_Toggle() mLED_3 = !mLED_3; 123 #define mLED_3_Toggle() mLED_3 = !mLED_3;
124 #define mLED_4_Toggle() mLED_4 = !mLED_4; 124 #define mLED_4_Toggle() mLED_4 = !mLED_4;
125 125
126 /** SWITCH *********************************************************/ 126 /** SWITCH *********************************************************/
127 #define mInitSwitch2() TRISDbits.TRISD6=1; 127 #define mInitSwitch2() TRISDbits.TRISD6=1;
128 #define mInitSwitch3() TRISDbits.TRISD7=1; 128 #define mInitSwitch3() TRISDbits.TRISD7=1;
129 #define mInitAllSwitches() mInitSwitch2();mInitSwitch3(); 129 #define mInitAllSwitches() mInitSwitch2();mInitSwitch3();
130 #define sw2 PORTDbits.RD6 130 #define sw2 PORTDbits.RD6
131 #define sw3 PORTDbits.RD7 131 #define sw3 PORTDbits.RD7
132   132  
133 /** POT ************************************************************/ 133 /** POT ************************************************************/
134 #define mInitPOT() {AD1PCFGLbits.PCFG5 = 0; AD1CON2bits.VCFG = 0x0; AD1CON3bits.ADCS = 0xFF; AD1CON1bits.SSRC = 0x0; AD1CON3bits.SAMC = 0b10000; AD1CON1bits.FORM = 0b00; AD1CON2bits.SMPI = 0x0; AD1CON1bits.ADON = 1;} 134 #define mInitPOT() {AD1PCFGLbits.PCFG5 = 0; AD1CON2bits.VCFG = 0x0; AD1CON3bits.ADCS = 0xFF; AD1CON1bits.SSRC = 0x0; AD1CON3bits.SAMC = 0b10000; AD1CON1bits.FORM = 0b00; AD1CON2bits.SMPI = 0x0; AD1CON1bits.ADON = 1;}
135 135
136 #endif //HARDWARE_PROFILE_PIC24FJ256GB110_PIM_H 136 #endif //HARDWARE_PROFILE_PIC24FJ256GB110_PIM_H