]> cloudbase.mooo.com Git - irmp.git/blame_incremental - irsndconfig.h
Version 2.3.0: some timer and variable name corrections
[irmp.git] / irsndconfig.h
... / ...
CommitLineData
1/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
2 * irsndconfig.h\r
3 *\r
4 * DO NOT INCLUDE THIS FILE, WILL BE INCLUDED BY IRSND.H!\r
5 *\r
6 * Copyright (c) 2010-2011 Frank Meyer - frank(at)fli4l.de\r
7 *\r
8 * $Id: irsndconfig.h,v 1.41 2012/10/05 07:58:39 fm Exp $\r
9 *\r
10 * ATMEGA88 @ 8 MHz\r
11 *\r
12 * This program is free software; you can redistribute it and/or modify\r
13 * it under the terms of the GNU General Public License as published by\r
14 * the Free Software Foundation; either version 2 of the License, or\r
15 * (at your option) any later version.\r
16 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
17 */\r
18\r
19#ifndef _IRSNDCONFIG_H_\r
20#define _IRSNDCONFIG_H_\r
21\r
22#if !defined(_IRSND_H_)\r
23# error please include only irsnd.h, not irsndconfig.h\r
24#endif\r
25\r
26/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
27 * F_INTERRUPTS: number of interrupts per second, should be in the range from 10000 to 20000, typically 15000\r
28 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
29 */\r
30#ifndef F_INTERRUPTS\r
31# define F_INTERRUPTS 15000 // interrupts per second\r
32#endif\r
33\r
34/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
35 * Change settings from 1 to 0 if you want to disable one or more encoders.\r
36 * This saves program space.\r
37 * 1 enable decoder\r
38 * 0 disable decoder\r
39 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
40 */\r
41\r
42// typical protocols, disable here! Enable Remarks F_INTERRUPTS Program Space\r
43#define IRSND_SUPPORT_SIRCS_PROTOCOL 1 // Sony SIRCS >= 10000 ~200 bytes\r
44#define IRSND_SUPPORT_NEC_PROTOCOL 1 // NEC + APPLE >= 10000 ~100 bytes\r
45#define IRSND_SUPPORT_SAMSUNG_PROTOCOL 1 // Samsung + Samsung32 >= 10000 ~300 bytes\r
46#define IRSND_SUPPORT_MATSUSHITA_PROTOCOL 1 // Matsushita >= 10000 ~200 bytes\r
47#define IRSND_SUPPORT_KASEIKYO_PROTOCOL 1 // Kaseikyo >= 10000 ~300 bytes\r
48#define IRSND_SUPPORT_DENON_PROTOCOL 1 // DENON, Sharp >= 10000 ~200 bytes\r
49\r
50// more protocols, enable here! Enable Remarks F_INTERRUPTS Program Space\r
51#define IRSND_SUPPORT_RC5_PROTOCOL 1 // RC5 >= 10000 ~150 bytes\r
52#define IRSND_SUPPORT_RC6_PROTOCOL 0 // RC6 >= 10000 ~250 bytes\r
53#define IRSND_SUPPORT_RC6A_PROTOCOL 0 // RC6A >= 10000 ~250 bytes\r
54#define IRSND_SUPPORT_JVC_PROTOCOL 0 // JVC >= 10000 ~150 bytes\r
55#define IRSND_SUPPORT_NEC16_PROTOCOL 0 // NEC16 >= 10000 ~150 bytes\r
56#define IRSND_SUPPORT_NEC42_PROTOCOL 0 // NEC42 >= 10000 ~150 bytes\r
57#define IRSND_SUPPORT_IR60_PROTOCOL 0 // IR60 (SDA2008) >= 10000 ~250 bytes\r
58#define IRSND_SUPPORT_GRUNDIG_PROTOCOL 0 // Grundig >= 10000 ~300 bytes\r
59#define IRSND_SUPPORT_SIEMENS_PROTOCOL 0 // Siemens, Gigaset >= 15000 ~150 bytes\r
60#define IRSND_SUPPORT_NOKIA_PROTOCOL 0 // Nokia >= 10000 ~400 bytes\r
61\r
62// exotic protocols, enable here! Enable Remarks F_INTERRUPTS Program Space\r
63#define IRSND_SUPPORT_KATHREIN_PROTOCOL 0 // Kathrein >= 10000 DON'T CHANGE, NOT SUPPORTED YET!\r
64#define IRSND_SUPPORT_NUBERT_PROTOCOL 0 // NUBERT >= 10000 ~100 bytes\r
65#define IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL 0 // Bang&Olufsen >= 10000 ~250 bytes\r
66#define IRSND_SUPPORT_RECS80_PROTOCOL 0 // RECS80 >= 20000 ~100 bytes\r
67#define IRSND_SUPPORT_RECS80EXT_PROTOCOL 0 // RECS80EXT >= 20000 ~100 bytes\r
68#define IRSND_SUPPORT_THOMSON_PROTOCOL 0 // Thomson >= 10000 ~250 bytes\r
69#define IRSND_SUPPORT_NIKON_PROTOCOL 0 // NIKON >= 10000 ~150 bytes\r
70#define IRSND_SUPPORT_NETBOX_PROTOCOL 0 // Netbox keyboard >= 10000 DON'T CHANGE, NOT SUPPORTED YET!\r
71#define IRSND_SUPPORT_FDC_PROTOCOL 0 // FDC IR keyboard >= 10000 (better 15000) ~150 bytes\r
72#define IRSND_SUPPORT_RCCAR_PROTOCOL 0 // RC CAR >= 10000 (better 15000) ~150 bytes\r
73#define IRSND_SUPPORT_RUWIDO_PROTOCOL 0 // RUWIDO, T-Home >= 15000 DON'T CHANGE, NOT SUPPORTED YET!\r
74#define IRSND_SUPPORT_LEGO_PROTOCOL 0 // LEGO Power RC >= 20000 ~150 bytes\r
75\r
76/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
77 * AVR section:\r
78 *\r
79 * Change hardware pin here: IRSND_OC2 = OC2 on ATmegas supporting OC2, e.g. ATmega8\r
80 * IRSND_OC2A = OC2A on ATmegas supporting OC2A, e.g. ATmega88\r
81 * IRSND_OC2B = OC2B on ATmegas supporting OC2B, e.g. ATmega88\r
82 * IRSND_OC0 = OC0 on ATmegas supporting OC0, e.g. ATmega162\r
83 * IRSND_OC0A = OC0A on ATmegas/ATtinys supporting OC0A, e.g. ATtiny84, ATtiny85, ATtiny87/167\r
84 * IRSND_OC0B = OC0B on ATmegas/ATtinys supporting OC0B, e.g. ATtiny84, ATtiny85\r
85 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
86 */\r
87#if defined(ATMEL_AVR)\r
88# define IRSND_OCx IRSND_OC2B // use OC2B\r
89\r
90/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
91 * PIC C18 section:\r
92 *\r
93 * Change hardware pin here: IRSND_PIC_CCP1 = RC2 on PIC 18F2550/18F4550, ...\r
94 * IRSND_PIC_CCP2 = RC1 on PIC 18F2550/18F4550, ...\r
95 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
96 */\r
97#elif defined(PIC_C18)\r
98# define IRSND_OCx IRSND_PIC_CCP2 // Use PWMx for PIC\r
99 // change other PIC C18 specific settings:\r
100# define F_CPU 48000000UL // PIC frequency: set your freq here\r
101# define Pre_Scaler 4 // define prescaler for timer2 e.g. 1,4,16\r
102# define PIC_Scaler 2 // PIC needs /2 extra in IRSND_FREQ_32_KHZ calculation for right value\r
103# warning Timer2 used for IRSND (PWM out) ! Do not use/setup Timer 2 yourself !\r
104\r
105/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
106 * ARM STM32 section:\r
107 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
108 */\r
109#elif defined (ARM_STM32) // use A6 as IR output on STM32\r
110# define IRSND_PORT_LETTER A\r
111# define IRSND_BIT_NUMBER 6\r
112# define IRSND_TIMER_NUMBER 10\r
113# define IRSND_TIMER_CHANNEL_NUMBER 1 // only channel 1 can be used at the moment, others won't work\r
114\r
115/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
116 * Other target system\r
117 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
118 */\r
119#elif !defined (UNIX_OR_WINDOWS)\r
120# error target system not defined.\r
121#endif\r
122\r
123/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
124 * Use Callbacks to indicate output signal or something else\r
125 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
126 */\r
127#ifndef IRSND_USE_CALLBACK\r
128# define IRSND_USE_CALLBACK 0 // flag: 0 = don't use callbacks, 1 = use callbacks, default is 0\r
129#endif\r
130\r
131#endif // _IRSNDCONFIG_H_\r