~toykeeper/flashlight-firmware/trunk

« back to all changes in this revision

Viewing changes to Flintrock/bistro-hd/configs/config_eswitch-TA-FETONLY-VCCREAD-INDICATOR-HD.h

  • Committer: Selene Scriven
  • Date: 2017-11-18 19:58:08 UTC
  • Revision ID: bzr@toykeeper.net-20171118195808-1v4if4nvkexp2143
Updated bistro-HD to 1.7.1.
Flintrock suggested skipping the intermediate versions, due to known issues in them.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#ifndef config_bistro_H
 
2
#define config_bistro_H
 
3
/*
 
4
 *  Firmware configuration header. 
 
5
 *
 
6
 * Bistro configuration file for TA-based triple driver, (C) Flintrock (FR).
 
7
 * USES voltage divider and OTC.
 
8
 * 
 
9
 * To work with tk-bistro and other compatible software.
 
10
 *
 
11
 * This program is free software: you can redistribute it and/or modify
 
12
 * it under the terms of the GNU General Public License as published by
 
13
 * the Free Software Foundation, either version 3 of the License, or
 
14
 * (at your option) any later version.
 
15
 *
 
16
 * This program is distributed in the hope that it will be useful,
 
17
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
18
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
19
 * GNU General Public License for more details.
 
20
 *
 
21
 * You should have received a copy of the GNU General Public License
 
22
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
23
 *
 
24
 */
 
25
 
 
26
 
 
27
/*
 
28
 * =========================================================================
 
29
 * Settings to modify per driver
 
30
 */
 
31
 
 
32
/////////////// Choose a layout////////////////
 
33
 
 
34
//#define FET_7135_LAYOUT  //FET+1
 
35
#define TRIPLEDOWN_LAYOUT  //TA triple
 
36
//#define NANJG105D_LAYOUT      // biscotti/convoy/nanjg105D
 
37
//#define BLFA6_LAYOUT      // BLFA6, FET+1, OTC and star3
 
38
//#define NANJG_LAYOUT  // specify an I/O pin layout
 
39
//#define QUADRUPLEDOWN_LAYOUT                     // Yes, that right :)
 
40
//#define CUSTOM_LAYOUT  // go define it for however you want to wire your driver.
 
41
//**** You can now easily customize layouts in fr-tk-attiny.h :
 
42
 
 
43
// choose the file that defines your modegruops (so we can easily keep more)
 
44
#define MODEGROUPS_H "modegroups/modegroups-TA-fetonly.h"
 
45
//#define MODEGROUPS_H "modegroups/modegroups-TA-triple-v1.3plus.h"
 
46
//#define MODEGROUPS_H "modegroups/modegroups-biscotti.h"
 
47
//#define MODEGROUPS_H "modegroups/modegroups-BLFA6.h"
 
48
 
 
49
/*************************  Misc utility configs*************************************/
 
50
//#define VOLTAGE_CAL  // builds a driver that just blinks ADC reading, set the VOLTAGE mode below.
 
51
//#define STRIPPED // use for debugging, strips many features to make more space for debug compiler options or testing functions.
 
52
                   // customize it below
 
53
//#define OTSM_debug //may require STRIPPED to fit. //Will blink out number of wakes (see SLEEP_TIME_EXPONENT) on short clicks, before entering mode.
 
54
 
 
55
/************************************OFF-TIME CONFIGS**********************************/
 
56
//USE redundancy to make noinit off memory safer (if used at all) redundancy 4 requires 38 bytes.
 
57
// This is only used if OTC and OTSM are not used and you have a clicking switch.
 
58
// #define USE_SAFE_PRESSES // enable
 
59
// redundancy 4 requires 38 bytes.
 
60
// redundancy level. Default is 4, but 3 could save some space, 2 has lower than 1 in 255 chance of failure:
 
61
                     // 3 has maybe 1 in 2,800 odds (based observations that 1's twice as probable as 0's)
 
62
                                         // 4 should have 1 in 69,000 odds of failure.
 
63
                                         // Failure rate is most likely per chip, not per click, but could be a little of both.
 
64
//#define N_SAFE_BYTES 4
 
65
 
 
66
#define OFFTIM3      // Use short/med/long off-time presses instead of just short/long
 
67
 
 
68
 
 
69
//#define USE_OTC // use off time cap. 
 
70
 
 
71
// Off-time sleep mode by -FR, thanks to flashy Mike and Mike C for early feasibility test with similar methods.
 
72
//#define USE_OTSM  // USE OTSM.  Pin must be defined in the layout too.
 
73
 
 
74
//#define OTSM_USES_OTC // use OTC cap for extra power on OTSM (sets it output high to charge up)
 
75
#define POWERSAVE // Also works without OTSM to reduce moon-mode drain. 
 
76
             // Squeeze out a bit more off-time by saving power during
 
77
             // shutoff detection (so at all times).  Implements ms resolution (could be less) idle sleeps in place of delay.
 
78
             // Seems to add at 0.5s of sleep at 3.1V 30uF cap, starting with only 0.75 that matters.  
 
79
                         // But at higher voltages, it's still only 0.5s additional, not multiplicative.
 
80
             // Also adds about 12 bytes that could be used for about two more mode groups instead :P
 
81
 
 
82
 
 
83
// Traditionally Cap values defined in tk-calibration
 
84
// But wake times in OTSM are not a calibration, just a configuration, so they go here.
 
85
// Times are in decimal seconds.  short (med) wakes are <, not = to wake_time_short(med)
 
86
#define SLEEP_TIME_EXPONENT 4   // OTSM clicky sleep will be increments of 16ms*2^STE  
 
87
                               // so 0 is 16, 1 is 32, 2 is 64, 3 is 128, 4 is 0.25s, 5 is 0.5s etc.
 
88
// To allow long click times use 4. For 1/8s resolution, use 3.
 
89
#define wake_time_short 0.375   // 0.5s : Short press is up to 0.5 s
 
90
#define wake_time_med   1.0   // this is limited by cap performance, but setting it high won't hurt 
 
91
                              // Since anything beyond the cap capacity will be read as long anyway.
 
92
                                                          // It's also the long-press off-threshold for e-switch operation.
 
93
 
 
94
/*****************************END OTSM CONGIGS*********************************/
 
95
 
 
96
#define USE_ESWITCH  // pin must be defined in the layout too.
 
97
//  #define USE_ESWITCH_LOCKOUT_TOGGLE  // enables menu to turn off eswitch, experimental, maybe be removed.
 
98
 
 
99
//  #define DUAL_SWITCH_NOINIT // clicking switch on dual switch light uses noinit to measure long/short presses.
 
100
                             //No OTSM or OTC.
 
101
 
 
102
//  #define DUMB_CLICK   //Power switch on dual-switch light doesn't change the mode.
 
103
                       //Better not use it with USE_ESWITCH_LOCKOUT_TOGGLE
 
104
 
 
105
 
 
106
//This option will just let the indicator turn on.  Future options may control function.
 
107
// INDICATOR_PIN must be defined in the layout.
 
108
#define USE_INDICATOR
 
109
 
 
110
/**********************VOLTAGE CONFIG****************************************/
 
111
 
 
112
#define VOLTAGE_MON         // Comment out to disable LVP
 
113
//You should leave one (but only one) of the next two uncommented.  
 
114
#define READ_VOLTAGE_FROM_VCC  // inverted "internal" Vcc voltage monitoring
 
115
                               // Works well for 1S lights without worrying about resistor values.
 
116
//#define READ_VOLTAGE_FROM_DIVIDER  // classic voltage reading
 
117
//#define REFERENCE_DIVIDER_READS_TO_VCC // default is 1.1V, but this is needed for divider reading with OTSM on the voltage pin.
 
118
                                         // This should normally be used with an LDO.  For 1S (non-LDO or 5.0VLDO) just avoid the problem with READ_VOLTAGE_FROM_VCC.
 
119
 
 
120
/***** Choose a battery indicator style (if enabled in modegroups)*******/
 
121
//#define BATTCHECK_4bars  // up to 4 blinks
 
122
//#define BATTCHECK_8bars  // up to 8 blinks
 
123
#define BATTCHECK_VpT  // Volts + tenths
 
124
 
 
125
/******thermal protection:  ***/
 
126
#define TEMPERATURE_MON          // You can set starting temperature in the "maxtemp" setting in config options first boot options.
 
127
  #define USE_TEMP_CAL    // include a TEMP_CAL mode in the menu.  
 
128
  #define TEMP_STEP_DOWN //Requires TEMPERATURE_MON, Use step-down and tap-up instead of oscillate
 
129
    #define MINIMUM_TURBO_TIME  10 //Turbo will never run less than this long. Requires TEMP_STEP_DOWN
 
130
 
 
131
/*******Mode features***********/
 
132
#define USE_MUGGLE_MODE  // compile in use of muggle mode
 
133
#define USE_REVERSE_MODES  // compile in use of reverse modes
 
134
#define USE_MOON  // compile in moon mode control
 
135
 
 
136
// Options for first bootup/default:
 
137
 
 
138
#define USE_FIRSTBOOT //Enables reset menu option, only costs a couple of bytes.
 
139
 
 
140
#define INIT_MODEGROUP      11       // which mode group will be default, mode groups below start at zero, select the mode group you want and subtract one from the number to get it by defualt here
 
141
#define INIT_ENABLE_MOON    1       // Should we add moon to the set of modes?
 
142
#define INIT_REVERSE_MODES  0       // flip the mode order?
 
143
#define INIT_MEMORY         0       // mode memory, or not
 
144
#define INIT_OFFTIM3        1       // enable medium-press by default?
 
145
#define INIT_MUGGLE_MODE    0       // simple mode designed for mugglesotsm
 
146
#define INIT_LOCKSWITCH     0       // 0 => E-swtich enabled, 1 => locked.
 
147
#define INIT_MAXTEMP       88       // maximum temperature
 
148
 
 
149
#define BLINK_SPEED         750
 
150
 
 
151
 
 
152
 
 
153
 
 
154
#ifdef STRIPPED  // define what you want to remove in stripped mode
 
155
#undef TEMPERATURE_MON
 
156
#undef VOLTAGE_MON
 
157
#define NO_STROBES  // don't use strobes (not automatically stripped from modes though, result can be undefined) 
 
158
#undef USE_BATTCHECK
 
159
#endif
 
160
 
 
161
 
 
162
/**********************************************************************************
 
163
**********************END OF CONFIGURATION*****************************************
 
164
***********************************************************************************/
 
165
 
 
166
 
 
167
#endif
 
 
b'\\ No newline at end of file'