Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00058
00059 #if !defined(__MTOUCH_HARDWARE_16F184X_H)
00060 #define __MTOUCH_HARDWARE_16F184X_H
00061
00062 #if !defined(_16F1847) && !defined(_16LF1847)
00063 #error The current mTouch hardware include file does not support this PIC microcontroller.
00064 #endif
00065
00066 #if MTOUCH_NUMBER_SENSORS > 12
00067 #error The PIC16F/LF1847 is not able to support more than 12 sensors due to pinout limitations.
00068 #endif
00069
00070
00071 #if ((MTOUCH_COMM_TYPE == MTOUCH_COMM_RS232_1WAY_ASCII) && !defined(MTOUCH_COMM_ASCII_SOFT_ENABLED)) || (MTOUCH_COMM_TYPE == MTOUCH_COMM_RS232_2WAY_BINARY)
00072 #if !defined(APFCON_INITIALIZED)
00073 #warning The mTouch comm module does not automatically set the APFCON# register. The TX pin may be selectable. This warning can be removed by defining the precompiler variable 'APFCON_INITIALIZED' in the mTouch_config.h file - verifying that you've initialized this register.
00074 #endif
00075 #endif
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085 #define PIC_UART_AVAILABLE
00086 #define PIC_UART_BAUD_BITS 16
00087
00088 #define PIC_TIMER0_AVAILABLE
00089 #define PIC_TIMER1_AVAILABLE
00090 #define PIC_TIMER2_AVAILABLE
00091 #define PIC_TIMER4_AVAILABLE
00092 #define PIC_TIMER6_AVAILABLE
00093
00094
00095
00096
00097 #define PIC_ADC_BITS 10
00098 #define PIC_ADC_UNIMP_AVAILABLE
00099
00100 #define PIC_ADC_ADCS ADCON1bits.ADCS
00101 #define PIC_ADC_ADFM ADCON1bits.ADFM
00102 #define PIC_ADC_ADON ADCON0bits.ADON
00103
00104 #define PIC_ADC_ADCS_FOSC2 0b000
00105 #define PIC_ADC_ADCS_FOSC4 0b100
00106 #define PIC_ADC_ADCS_FOSC8 0b001
00107 #define PIC_ADC_ADCS_FOSC16 0b101
00108 #define PIC_ADC_ADCS_FOSC32 0b010
00109 #define PIC_ADC_ADCS_FOSC64 0b110
00110 #define PIC_ADC_ADCS_FRC 0b111
00111
00112 #define PIC_ADC_ADFM_RIGHT 1
00113 #define PIC_ADC_ADFM_LEFT 0
00114
00115 #if _XTAL_FREQ == 32000000
00116 #define PIC_ADC_SETCLK() PIC_ADC_ADCS = PIC_ADC_ADCS_FOSC32
00117 #define PIC_ADC_TAD 1
00118 #elif _XTAL_FREQ == 16000000
00119 #define PIC_ADC_SETCLK() PIC_ADC_ADCS = PIC_ADC_ADCS_FOSC16
00120 #define PIC_ADC_TAD 1
00121 #elif _XTAL_FREQ == 8000000
00122 #define PIC_ADC_SETCLK() PIC_ADC_ADCS = PIC_ADC_ADCS_FOSC8
00123 #define PIC_ADC_TAD 1
00124 #elif _XTAL_FREQ == 4000000
00125 #define PIC_ADC_SETCLK() PIC_ADC_ADCS = PIC_ADC_ADCS_FOSC4
00126 #define PIC_ADC_TAD 1
00127 #elif _XTAL_FREQ == 2000000
00128 #define PIC_ADC_SETCLK() PIC_ADC_ADCS = PIC_ADC_ADCS_FOSC2
00129 #define PIC_ADC_TAD 1
00130 #elif _XTAL_FREQ == 1000000
00131 #define PIC_ADC_SETCLK() PIC_ADC_ADCS = PIC_ADC_ADCS_FOSC2
00132 #define PIC_ADC_TAD 2
00133 #else
00134 #error No predefined ADC clock values for the chosen _XTAL_FREQ.
00135 #endif
00136
00137
00138
00139
00140
00141 #define PIC_DAC_AVAILABLE
00142 #define PIC_DACOUT_AVAILABLE
00143
00144 #define PIC_DACOUT_TRIS_C TRISA2
00145 #define PIC_DACOUT_LAT_C LATA2
00146 #define PIC_DACOUT_LAT_ASM _LATA
00147 #define PIC_DACOUT_PIN 2
00148
00149 #define PIC_DACCON0_VDD 0xC0
00150 #define PIC_DACCON1_VDD 0x1F
00151 #define PIC_DACCON0_VSS 0x80
00152 #define PIC_DACCON1_VSS 0x00
00153
00154 #define PIC_DACOUT_DACCON0_VSS 0xA0
00155 #define PIC_DACOUT_DACCON0_1_3RD_VDD 0xA0
00156 #define PIC_DACOUT_DACCON0_HALF_VDD 0xA0
00157 #define PIC_DACOUT_DACCON0_2_3RD_VDD 0xE0
00158 #define PIC_DACOUT_DACCON0_VDD 0xE0
00159
00160 #define PIC_DACOUT_DACCON1_VSS 0x00
00161 #define PIC_DACOUT_DACCON1_1_3RD_VDD 0x0B
00162 #define PIC_DACOUT_DACCON1_HALF_VDD 0x10
00163 #define PIC_DACOUT_DACCON1_2_3RD_VDD 0x16
00164 #define PIC_DACOUT_DACCON1_VDD 0x1F
00165
00166
00167
00168
00169
00170 #define PIC_SWDTEN_AVAILABLE
00171 #define PIC_SWDTEN_OFF() WDTCONbits.SWDTEN = 0
00172 #define PIC_SWDTEN_ON() WDTCONbits.SWDTEN = 1
00173
00174
00175
00176
00177
00178
00179
00180
00181
00182
00183 #define MTOUCH_AD_AN0 0x01
00184 #define MTOUCH_AD_AN1 0x05
00185 #define MTOUCH_AD_AN2 0x09
00186 #define MTOUCH_AD_AN3 0x0D
00187 #define MTOUCH_AD_AN4 0x11
00188 #define MTOUCH_AD_AN5 0x15
00189 #define MTOUCH_AD_AN6 0x19
00190 #define MTOUCH_AD_AN7 0x1D
00191 #define MTOUCH_AD_AN8 0x21
00192 #define MTOUCH_AD_AN9 0x25
00193 #define MTOUCH_AD_AN10 0x29
00194 #define MTOUCH_AD_AN11 0x2D
00195 #define MTOUCH_AD_DAC_AND_GO 0x7B
00196 #define MTOUCH_AD_DAC_NOGO 0x79
00197 #define MTOUCH_AD_ISO_AND_GO 0x33
00198 #define MTOUCH_AD_ISO_NOGO 0x31
00199
00200
00201 #define MTOUCH_PIN_AN0 0
00202 #define MTOUCH_PIN_AN1 1
00203 #define MTOUCH_PIN_AN2 2
00204 #define MTOUCH_PIN_AN3 3
00205 #define MTOUCH_PIN_AN4 4
00206 #define MTOUCH_PIN_AN5 6
00207 #define MTOUCH_PIN_AN6 7
00208 #define MTOUCH_PIN_AN7 5
00209 #define MTOUCH_PIN_AN8 4
00210 #define MTOUCH_PIN_AN9 3
00211 #define MTOUCH_PIN_AN10 2
00212 #define MTOUCH_PIN_AN11 1
00213
00214
00215 #define MTOUCH_LETTER_AN0 A
00216 #define MTOUCH_LETTER_AN1 A
00217 #define MTOUCH_LETTER_AN2 A
00218 #define MTOUCH_LETTER_AN3 A
00219 #define MTOUCH_LETTER_AN4 A
00220 #define MTOUCH_LETTER_AN5 B
00221 #define MTOUCH_LETTER_AN6 B
00222 #define MTOUCH_LETTER_AN7 B
00223 #define MTOUCH_LETTER_AN8 B
00224 #define MTOUCH_LETTER_AN9 B
00225 #define MTOUCH_LETTER_AN10 B
00226 #define MTOUCH_LETTER_AN11 B
00227
00228
00229 #endif
00230
00231