ASoC: cs42l73: Remove trailing semicolon
[sfrench/cifs-2.6.git] / drivers / staging / pi433 / rf69.c
1 /*
2  * abstraction of the spi interface of HopeRf rf69 radio module
3  *
4  * Copyright (C) 2016 Wolf-Entwicklungen
5  *      Marcus Wolf <linux@wolf-entwicklungen.de>
6  *
7  * This program is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 2 of the License, or
10  * (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  */
17
18 /* enable prosa debug info */
19 #undef DEBUG
20 /* enable print of values on reg access */
21 #undef DEBUG_VALUES
22 /* enable print of values on fifo access */
23 #undef DEBUG_FIFO_ACCESS
24
25 #include <linux/types.h>
26 #include <linux/spi/spi.h>
27
28 #include "rf69.h"
29 #include "rf69_registers.h"
30
31 #define F_OSC     32000000 /* in Hz */
32 #define FIFO_SIZE 66       /* in byte */
33
34 /*-------------------------------------------------------------------------*/
35
36 #define READ_REG(x)     rf69_read_reg (spi, x)
37 #define WRITE_REG(x, y) rf69_write_reg(spi, x, y)
38
39 /*-------------------------------------------------------------------------*/
40
41 int rf69_set_mode(struct spi_device *spi, enum mode mode)
42 {
43         #ifdef DEBUG
44                 dev_dbg(&spi->dev, "set: mode");
45         #endif
46
47         switch (mode) {
48         case transmit:    return WRITE_REG(REG_OPMODE, (READ_REG(REG_OPMODE) & ~MASK_OPMODE_MODE) | OPMODE_MODE_TRANSMIT);
49         case receive:     return WRITE_REG(REG_OPMODE, (READ_REG(REG_OPMODE) & ~MASK_OPMODE_MODE) | OPMODE_MODE_RECEIVE);
50         case synthesizer: return WRITE_REG(REG_OPMODE, (READ_REG(REG_OPMODE) & ~MASK_OPMODE_MODE) | OPMODE_MODE_SYNTHESIZER);
51         case standby:     return WRITE_REG(REG_OPMODE, (READ_REG(REG_OPMODE) & ~MASK_OPMODE_MODE) | OPMODE_MODE_STANDBY);
52         case mode_sleep:  return WRITE_REG(REG_OPMODE, (READ_REG(REG_OPMODE) & ~MASK_OPMODE_MODE) | OPMODE_MODE_SLEEP);
53         default:
54                 dev_dbg(&spi->dev, "set: illegal input param");
55                 return -EINVAL;
56         }
57
58         // we are using packet mode, so this check is not really needed
59         // but waiting for mode ready is necessary when going from sleep because the FIFO may not be immediately available from previous mode
60         //while (_mode == RF69_MODE_SLEEP && (READ_REG(REG_IRQFLAGS1) & RF_IRQFLAGS1_MODEREADY) == 0x00); // Wait for ModeReady
61
62 }
63
64 int rf69_set_data_mode(struct spi_device *spi, enum dataMode dataMode)
65 {
66         #ifdef DEBUG
67                 dev_dbg(&spi->dev, "set: data mode");
68         #endif
69
70         switch (dataMode) {
71         case packet:            return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODE) | DATAMODUL_MODE_PACKET);
72         case continuous:        return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODE) | DATAMODUL_MODE_CONTINUOUS);
73         case continuousNoSync:  return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODE) | DATAMODUL_MODE_CONTINUOUS_NOSYNC);
74         default:
75                 dev_dbg(&spi->dev, "set: illegal input param");
76                 return -EINVAL;
77         }
78 }
79
80 int rf69_set_modulation(struct spi_device *spi, enum modulation modulation)
81 {
82         #ifdef DEBUG
83                 dev_dbg(&spi->dev, "set: modulation");
84         #endif
85
86         switch (modulation) {
87         case OOK:   return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODULATION_TYPE) | DATAMODUL_MODULATION_TYPE_OOK);
88         case FSK:   return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODULATION_TYPE) | DATAMODUL_MODULATION_TYPE_FSK);
89         default:
90                 dev_dbg(&spi->dev, "set: illegal input param");
91                 return -EINVAL;
92         }
93 }
94
95 enum modulation rf69_get_modulation(struct spi_device *spi)
96 {
97         u8 currentValue;
98
99         #ifdef DEBUG
100                 dev_dbg(&spi->dev, "get: mode");
101         #endif
102
103         currentValue = READ_REG(REG_DATAMODUL);
104
105         switch (currentValue & MASK_DATAMODUL_MODULATION_TYPE >> 3) { // TODO improvement: change 3 to define
106         case DATAMODUL_MODULATION_TYPE_OOK: return OOK;
107         case DATAMODUL_MODULATION_TYPE_FSK: return FSK;
108         default:                            return undefined;
109         }
110 }
111
112 int rf69_set_modulation_shaping(struct spi_device *spi, enum modShaping modShaping)
113 {
114         #ifdef DEBUG
115                 dev_dbg(&spi->dev, "set: mod shaping");
116         #endif
117
118         if (rf69_get_modulation(spi) == FSK) {
119                 switch (modShaping) {
120                 case shapingOff: return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODULATION_SHAPE) | DATAMODUL_MODULATION_SHAPE_NONE);
121                 case shaping1_0: return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODULATION_SHAPE) | DATAMODUL_MODULATION_SHAPE_1_0);
122                 case shaping0_5: return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODULATION_SHAPE) | DATAMODUL_MODULATION_SHAPE_0_3);
123                 case shaping0_3: return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODULATION_SHAPE) | DATAMODUL_MODULATION_SHAPE_0_5);
124                 default:
125                         dev_dbg(&spi->dev, "set: illegal input param");
126                         return -EINVAL;
127                 }
128         } else {
129                 switch (modShaping) {
130                 case shapingOff: return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODULATION_SHAPE) | DATAMODUL_MODULATION_SHAPE_NONE);
131                 case shapingBR:  return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODULATION_SHAPE) | DATAMODUL_MODULATION_SHAPE_BR);
132                 case shaping2BR: return WRITE_REG(REG_DATAMODUL, (READ_REG(REG_DATAMODUL) & ~MASK_DATAMODUL_MODULATION_SHAPE) | DATAMODUL_MODULATION_SHAPE_2BR);
133                 default:
134                         dev_dbg(&spi->dev, "set: illegal input param");
135                         return -EINVAL;
136                 }
137         }
138 }
139
140 int rf69_set_bit_rate(struct spi_device *spi, u16 bitRate)
141 {
142         int retval;
143         u32 bitRate_min;
144         u32 bitRate_reg;
145         u8 msb;
146         u8 lsb;
147
148         #ifdef DEBUG
149                 dev_dbg(&spi->dev, "set: bit rate");
150         #endif
151
152         // check input value
153         bitRate_min = F_OSC / 8388608; // 8388608 = 2^23;
154         if (bitRate < bitRate_min) {
155                 dev_dbg(&spi->dev, "setBitRate: illegal input param");
156                 return -EINVAL;
157         }
158
159         // calculate reg settings
160         bitRate_reg = (F_OSC / bitRate);
161
162         msb = (bitRate_reg&0xff00)   >>  8;
163         lsb = (bitRate_reg&0xff);
164
165         // transmit to RF 69
166         retval = WRITE_REG(REG_BITRATE_MSB, msb);
167         if (retval)
168                 return retval;
169
170         retval = WRITE_REG(REG_BITRATE_LSB, lsb);
171         if (retval)
172                 return retval;
173
174         return 0;
175 }
176
177 int rf69_set_deviation(struct spi_device *spi, u32 deviation)
178 {
179         int retval;
180 //      u32 f_max; TODO: Abhängigkeit von Bitrate beachten!!
181         u64 f_reg;
182         u64 f_step;
183         u8 msb;
184         u8 lsb;
185         u64 factor = 1000000; // to improve precision of calculation
186
187         #ifdef DEBUG
188                 dev_dbg(&spi->dev, "set: deviation");
189         #endif
190
191         if (deviation < 600 || deviation > 500000) { //TODO: Abhängigkeit von Bitrate beachten!!
192                 dev_dbg(&spi->dev, "set_deviation: illegal input param");
193                 return -EINVAL;
194         }
195
196         // calculat f step
197         f_step = F_OSC * factor;
198         do_div(f_step, 524288); //  524288 = 2^19
199
200         // calculate register settings
201         f_reg = deviation * factor;
202         do_div(f_reg, f_step);
203
204         msb = (f_reg&0xff00)   >>  8;
205         lsb = (f_reg&0xff);
206
207         // check msb
208         if (msb & ~FDEVMASB_MASK) {
209                 dev_dbg(&spi->dev, "set_deviation: err in calc of msb");
210                 return -EINVAL;
211         }
212
213         // write to chip
214         retval = WRITE_REG(REG_FDEV_MSB, msb);
215         if (retval)
216                 return retval;
217
218         retval = WRITE_REG(REG_FDEV_LSB, lsb);
219         if (retval)
220                 return retval;
221
222         return 0;
223 }
224
225 int rf69_set_frequency(struct spi_device *spi, u32 frequency)
226 {
227         int retval;
228         u32 f_max;
229         u64 f_reg;
230         u64 f_step;
231         u8 msb;
232         u8 mid;
233         u8 lsb;
234         u64 factor = 1000000; // to improve precision of calculation
235
236         #ifdef DEBUG
237                 dev_dbg(&spi->dev, "set: frequency");
238         #endif
239
240         // calculat f step
241         f_step = F_OSC * factor;
242         do_div(f_step, 524288); //  524288 = 2^19
243
244         // check input value
245         f_max = div_u64(f_step * 8388608, factor);
246         if (frequency > f_max) {
247                 dev_dbg(&spi->dev, "setFrequency: illegal input param");
248                 return -EINVAL;
249         }
250
251         // calculate reg settings
252         f_reg = frequency * factor;
253         do_div(f_reg, f_step);
254
255         msb = (f_reg&0xff0000) >> 16;
256         mid = (f_reg&0xff00)   >>  8;
257         lsb = (f_reg&0xff);
258
259         // write to chip
260         retval = WRITE_REG(REG_FRF_MSB, msb);
261         if (retval)
262                 return retval;
263
264         retval = WRITE_REG(REG_FRF_MID, mid);
265         if (retval)
266                 return retval;
267
268         retval = WRITE_REG(REG_FRF_LSB, lsb);
269         if (retval)
270                 return retval;
271
272         return 0;
273 }
274
275 int rf69_set_amplifier_0(struct spi_device *spi, enum optionOnOff optionOnOff)
276 {
277         #ifdef DEBUG
278                 dev_dbg(&spi->dev, "set: amp #0");
279         #endif
280
281         switch (optionOnOff) {
282         case optionOn:  return WRITE_REG(REG_PALEVEL, (READ_REG(REG_PALEVEL) |  MASK_PALEVEL_PA0));
283         case optionOff: return WRITE_REG(REG_PALEVEL, (READ_REG(REG_PALEVEL) & ~MASK_PALEVEL_PA0));
284         default:
285                 dev_dbg(&spi->dev, "set: illegal input param");
286                 return -EINVAL;
287         }
288 }
289
290 int rf69_set_amplifier_1(struct spi_device *spi, enum optionOnOff optionOnOff)
291 {
292         #ifdef DEBUG
293                 dev_dbg(&spi->dev, "set: amp #1");
294         #endif
295
296         switch (optionOnOff) {
297         case optionOn:  return WRITE_REG(REG_PALEVEL, (READ_REG(REG_PALEVEL) |  MASK_PALEVEL_PA1));
298         case optionOff: return WRITE_REG(REG_PALEVEL, (READ_REG(REG_PALEVEL) & ~MASK_PALEVEL_PA1));
299         default:
300                 dev_dbg(&spi->dev, "set: illegal input param");
301                 return -EINVAL;
302         }
303 }
304
305 int rf69_set_amplifier_2(struct spi_device *spi, enum optionOnOff optionOnOff)
306 {
307         #ifdef DEBUG
308                 dev_dbg(&spi->dev, "set: amp #2");
309         #endif
310
311         switch (optionOnOff) {
312         case optionOn:  return WRITE_REG(REG_PALEVEL, (READ_REG(REG_PALEVEL) |  MASK_PALEVEL_PA2));
313         case optionOff: return WRITE_REG(REG_PALEVEL, (READ_REG(REG_PALEVEL) & ~MASK_PALEVEL_PA2));
314         default:
315                 dev_dbg(&spi->dev, "set: illegal input param");
316                 return -EINVAL;
317         }
318 }
319
320 int rf69_set_output_power_level(struct spi_device *spi, u8 powerLevel)
321 {
322         #ifdef DEBUG
323                 dev_dbg(&spi->dev, "set: power level");
324         #endif
325
326         powerLevel += 18; // TODO Abhängigkeit von PA0,1,2 setting
327
328         // check input value
329         if (powerLevel > 0x1f) {
330                 dev_dbg(&spi->dev, "set: illegal input param");
331                 return -EINVAL;
332         }
333
334         // write value
335         return WRITE_REG(REG_PALEVEL, (READ_REG(REG_PALEVEL) & ~MASK_PALEVEL_OUTPUT_POWER) | powerLevel);
336 }
337
338 int rf69_set_pa_ramp(struct spi_device *spi, enum paRamp paRamp)
339 {
340         #ifdef DEBUG
341                 dev_dbg(&spi->dev, "set: pa ramp");
342         #endif
343
344         switch (paRamp) {
345         case ramp3400:  return WRITE_REG(REG_PARAMP, PARAMP_3400);
346         case ramp2000:  return WRITE_REG(REG_PARAMP, PARAMP_2000);
347         case ramp1000:  return WRITE_REG(REG_PARAMP, PARAMP_1000);
348         case ramp500:   return WRITE_REG(REG_PARAMP, PARAMP_500);
349         case ramp250:   return WRITE_REG(REG_PARAMP, PARAMP_250);
350         case ramp125:   return WRITE_REG(REG_PARAMP, PARAMP_125);
351         case ramp100:   return WRITE_REG(REG_PARAMP, PARAMP_100);
352         case ramp62:    return WRITE_REG(REG_PARAMP, PARAMP_62);
353         case ramp50:    return WRITE_REG(REG_PARAMP, PARAMP_50);
354         case ramp40:    return WRITE_REG(REG_PARAMP, PARAMP_40);
355         case ramp31:    return WRITE_REG(REG_PARAMP, PARAMP_31);
356         case ramp25:    return WRITE_REG(REG_PARAMP, PARAMP_25);
357         case ramp20:    return WRITE_REG(REG_PARAMP, PARAMP_20);
358         case ramp15:    return WRITE_REG(REG_PARAMP, PARAMP_15);
359         case ramp12:    return WRITE_REG(REG_PARAMP, PARAMP_12);
360         case ramp10:    return WRITE_REG(REG_PARAMP, PARAMP_10);
361         default:
362                 dev_dbg(&spi->dev, "set: illegal input param");
363                 return -EINVAL;
364         }
365 }
366
367 int rf69_set_antenna_impedance(struct spi_device *spi, enum antennaImpedance antennaImpedance)
368 {
369         #ifdef DEBUG
370                 dev_dbg(&spi->dev, "set: antenna impedance");
371         #endif
372
373         switch (antennaImpedance) {
374         case fiftyOhm:      return WRITE_REG(REG_LNA, (READ_REG(REG_LNA) & ~MASK_LNA_ZIN));
375         case twohundretOhm: return WRITE_REG(REG_LNA, (READ_REG(REG_LNA) |  MASK_LNA_ZIN));
376         default:
377                 dev_dbg(&spi->dev, "set: illegal input param");
378                 return -EINVAL;
379         }
380 }
381
382 int rf69_set_lna_gain(struct spi_device *spi, enum lnaGain lnaGain)
383 {
384         #ifdef DEBUG
385                 dev_dbg(&spi->dev, "set: lna gain");
386         #endif
387
388         switch (lnaGain) {
389         case automatic:  return WRITE_REG(REG_LNA, ((READ_REG(REG_LNA) & ~MASK_LNA_GAIN) & LNA_GAIN_AUTO));
390         case max:        return WRITE_REG(REG_LNA, ((READ_REG(REG_LNA) & ~MASK_LNA_GAIN) & LNA_GAIN_MAX));
391         case maxMinus6:  return WRITE_REG(REG_LNA, ((READ_REG(REG_LNA) & ~MASK_LNA_GAIN) & LNA_GAIN_MAX_MINUS_6));
392         case maxMinus12: return WRITE_REG(REG_LNA, ((READ_REG(REG_LNA) & ~MASK_LNA_GAIN) & LNA_GAIN_MAX_MINUS_12));
393         case maxMinus24: return WRITE_REG(REG_LNA, ((READ_REG(REG_LNA) & ~MASK_LNA_GAIN) & LNA_GAIN_MAX_MINUS_24));
394         case maxMinus36: return WRITE_REG(REG_LNA, ((READ_REG(REG_LNA) & ~MASK_LNA_GAIN) & LNA_GAIN_MAX_MINUS_36));
395         case maxMinus48: return WRITE_REG(REG_LNA, ((READ_REG(REG_LNA) & ~MASK_LNA_GAIN) & LNA_GAIN_MAX_MINUS_48));
396         default:
397                 dev_dbg(&spi->dev, "set: illegal input param");
398                 return -EINVAL;
399         }
400 }
401
402 enum lnaGain rf69_get_lna_gain(struct spi_device *spi)
403 {
404         u8 currentValue;
405
406         #ifdef DEBUG
407                 dev_dbg(&spi->dev, "get: lna gain");
408         #endif
409
410         currentValue = READ_REG(REG_LNA);
411
412         switch (currentValue & MASK_LNA_CURRENT_GAIN >> 3) { // improvement: change 3 to define
413         case LNA_GAIN_AUTO:         return automatic;
414         case LNA_GAIN_MAX:          return max;
415         case LNA_GAIN_MAX_MINUS_6:  return maxMinus6;
416         case LNA_GAIN_MAX_MINUS_12: return maxMinus12;
417         case LNA_GAIN_MAX_MINUS_24: return maxMinus24;
418         case LNA_GAIN_MAX_MINUS_36: return maxMinus36;
419         case LNA_GAIN_MAX_MINUS_48: return maxMinus48;
420         default:                    return undefined;
421         }
422 }
423
424 int rf69_set_dc_cut_off_frequency_intern(struct spi_device *spi, u8 reg, enum dccPercent dccPercent)
425 {
426         switch (dccPercent) {
427         case dcc16Percent:      return WRITE_REG(reg, ((READ_REG(reg) & ~MASK_BW_DCC_FREQ) | BW_DCC_16_PERCENT));
428         case dcc8Percent:       return WRITE_REG(reg, ((READ_REG(reg) & ~MASK_BW_DCC_FREQ) | BW_DCC_8_PERCENT));
429         case dcc4Percent:       return WRITE_REG(reg, ((READ_REG(reg) & ~MASK_BW_DCC_FREQ) | BW_DCC_4_PERCENT));
430         case dcc2Percent:       return WRITE_REG(reg, ((READ_REG(reg) & ~MASK_BW_DCC_FREQ) | BW_DCC_2_PERCENT));
431         case dcc1Percent:       return WRITE_REG(reg, ((READ_REG(reg) & ~MASK_BW_DCC_FREQ) | BW_DCC_1_PERCENT));
432         case dcc0_5Percent:     return WRITE_REG(reg, ((READ_REG(reg) & ~MASK_BW_DCC_FREQ) | BW_DCC_0_5_PERCENT));
433         case dcc0_25Percent:    return WRITE_REG(reg, ((READ_REG(reg) & ~MASK_BW_DCC_FREQ) | BW_DCC_0_25_PERCENT));
434         case dcc0_125Percent:   return WRITE_REG(reg, ((READ_REG(reg) & ~MASK_BW_DCC_FREQ) | BW_DCC_0_125_PERCENT));
435         default:
436                 dev_dbg(&spi->dev, "set: illegal input param");
437                 return -EINVAL;
438         }
439 }
440
441 int rf69_set_dc_cut_off_frequency(struct spi_device *spi, enum dccPercent dccPercent)
442 {
443         #ifdef DEBUG
444                 dev_dbg(&spi->dev, "set: cut off freq");
445         #endif
446
447         return rf69_set_dc_cut_off_frequency_intern(spi, REG_RXBW, dccPercent);
448 }
449
450 int rf69_set_dc_cut_off_frequency_during_afc(struct spi_device *spi, enum dccPercent dccPercent)
451 {
452         #ifdef DEBUG
453                 dev_dbg(&spi->dev, "set: cut off freq during afc");
454         #endif
455
456         return rf69_set_dc_cut_off_frequency_intern(spi, REG_AFCBW, dccPercent);
457 }
458
459 static int rf69_set_bandwidth_intern(struct spi_device *spi, u8 reg,
460                                      enum mantisse mantisse, u8 exponent)
461 {
462         u8 newValue;
463
464         // check value for mantisse and exponent
465         if (exponent > 7) {
466                 dev_dbg(&spi->dev, "set: illegal input param");
467                 return -EINVAL;
468         }
469
470         if ((mantisse != mantisse16) &&
471             (mantisse != mantisse20) &&
472             (mantisse != mantisse24)) {
473                 dev_dbg(&spi->dev, "set: illegal input param");
474                 return -EINVAL;
475         }
476
477         // read old value
478         newValue = READ_REG(reg);
479
480         // "delete" mantisse and exponent = just keep the DCC setting
481         newValue = newValue & MASK_BW_DCC_FREQ;
482
483         // add new mantisse
484         switch (mantisse) {
485         case mantisse16:
486                 newValue = newValue | BW_MANT_16;
487                 break;
488         case mantisse20:
489                 newValue = newValue | BW_MANT_20;
490                 break;
491         case mantisse24:
492                 newValue = newValue | BW_MANT_24;
493                 break;
494         }
495
496         // add new exponent
497         newValue = newValue | exponent;
498
499         // write back
500         return WRITE_REG(reg, newValue);
501 }
502
503 int rf69_set_bandwidth(struct spi_device *spi, enum mantisse mantisse, u8 exponent)
504 {
505         #ifdef DEBUG
506                 dev_dbg(&spi->dev, "set: band width");
507         #endif
508
509         return rf69_set_bandwidth_intern(spi, REG_RXBW, mantisse, exponent);
510 }
511
512 int rf69_set_bandwidth_during_afc(struct spi_device *spi, enum mantisse mantisse, u8 exponent)
513 {
514         #ifdef DEBUG
515                 dev_dbg(&spi->dev, "set: band width during afc");
516         #endif
517
518         return rf69_set_bandwidth_intern(spi, REG_AFCBW, mantisse, exponent);
519 }
520
521 int rf69_set_ook_threshold_type(struct spi_device *spi, enum thresholdType thresholdType)
522 {
523         #ifdef DEBUG
524                 dev_dbg(&spi->dev, "set: threshold type");
525         #endif
526
527         switch (thresholdType) {
528         case fixed:     return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESTYPE) | OOKPEAK_THRESHTYPE_FIXED));
529         case peak:      return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESTYPE) | OOKPEAK_THRESHTYPE_PEAK));
530         case average:   return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESTYPE) | OOKPEAK_THRESHTYPE_AVERAGE));
531         default:
532                 dev_dbg(&spi->dev, "set: illegal input param");
533                 return -EINVAL;
534         }
535 }
536
537 int rf69_set_ook_threshold_step(struct spi_device *spi, enum thresholdStep thresholdStep)
538 {
539         #ifdef DEBUG
540                 dev_dbg(&spi->dev, "set: threshold step");
541         #endif
542
543         switch (thresholdStep) {
544         case step_0_5db: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESSTEP) | OOKPEAK_THRESHSTEP_0_5_DB));
545         case step_1_0db: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESSTEP) | OOKPEAK_THRESHSTEP_1_0_DB));
546         case step_1_5db: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESSTEP) | OOKPEAK_THRESHSTEP_1_5_DB));
547         case step_2_0db: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESSTEP) | OOKPEAK_THRESHSTEP_2_0_DB));
548         case step_3_0db: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESSTEP) | OOKPEAK_THRESHSTEP_3_0_DB));
549         case step_4_0db: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESSTEP) | OOKPEAK_THRESHSTEP_4_0_DB));
550         case step_5_0db: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESSTEP) | OOKPEAK_THRESHSTEP_5_0_DB));
551         case step_6_0db: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESSTEP) | OOKPEAK_THRESHSTEP_6_0_DB));
552         default:
553                 dev_dbg(&spi->dev, "set: illegal input param");
554                 return -EINVAL;
555         }
556 }
557
558 int rf69_set_ook_threshold_dec(struct spi_device *spi, enum thresholdDecrement thresholdDecrement)
559 {
560         #ifdef DEBUG
561                 dev_dbg(&spi->dev, "set: threshold decrement");
562         #endif
563
564         switch (thresholdDecrement) {
565         case dec_every8th: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESDEC) | OOKPEAK_THRESHDEC_EVERY_8TH));
566         case dec_every4th: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESDEC) | OOKPEAK_THRESHDEC_EVERY_4TH));
567         case dec_every2nd: return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESDEC) | OOKPEAK_THRESHDEC_EVERY_2ND));
568         case dec_once:     return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESDEC) | OOKPEAK_THRESHDEC_ONCE));
569         case dec_twice:    return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESDEC) | OOKPEAK_THRESHDEC_TWICE));
570         case dec_4times:   return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESDEC) | OOKPEAK_THRESHDEC_4_TIMES));
571         case dec_8times:   return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESDEC) | OOKPEAK_THRESHDEC_8_TIMES));
572         case dec_16times:  return WRITE_REG(REG_OOKPEAK, ((READ_REG(REG_OOKPEAK) & ~MASK_OOKPEAK_THRESDEC) | OOKPEAK_THRESHDEC_16_TIMES));
573         default:
574                 dev_dbg(&spi->dev, "set: illegal input param");
575                 return -EINVAL;
576         }
577 }
578
579 int rf69_set_dio_mapping(struct spi_device *spi, u8 DIONumber, u8 value)
580 {
581         u8 mask;
582         u8 shift;
583         u8 regaddr;
584         u8 regValue;
585
586         #ifdef DEBUG
587                 dev_dbg(&spi->dev, "set: DIO mapping");
588         #endif
589
590         switch (DIONumber) {
591         case 0:
592                 mask = MASK_DIO0; shift = SHIFT_DIO0; regaddr = REG_DIOMAPPING1;
593                 break;
594         case 1:
595                 mask = MASK_DIO1; shift = SHIFT_DIO1; regaddr = REG_DIOMAPPING1;
596                 break;
597         case 2:
598                 mask = MASK_DIO2; shift = SHIFT_DIO2; regaddr = REG_DIOMAPPING1;
599                 break;
600         case 3:
601                 mask = MASK_DIO3; shift = SHIFT_DIO3; regaddr = REG_DIOMAPPING1;
602                 break;
603         case 4:
604                 mask = MASK_DIO4; shift = SHIFT_DIO4; regaddr = REG_DIOMAPPING2;
605                 break;
606         case 5:
607                 mask = MASK_DIO5; shift = SHIFT_DIO5; regaddr = REG_DIOMAPPING2;
608                 break;
609         default:
610                 dev_dbg(&spi->dev, "set: illegal input param");
611                 return -EINVAL;
612         }
613
614         // read reg
615         regValue = READ_REG(regaddr);
616         // delete old value
617         regValue = regValue & ~mask;
618         // add new value
619         regValue = regValue | value << shift;
620         // write back
621         return WRITE_REG(regaddr, regValue);
622 }
623
624 bool rf69_get_flag(struct spi_device *spi, enum flag flag)
625 {
626         #ifdef DEBUG
627                 dev_dbg(&spi->dev, "get: flag");
628         #endif
629
630         switch (flag) {
631         case modeSwitchCompleted:     return (READ_REG(REG_IRQFLAGS1) & MASK_IRQFLAGS1_MODE_READY);
632         case readyToReceive:          return (READ_REG(REG_IRQFLAGS1) & MASK_IRQFLAGS1_RX_READY);
633         case readyToSend:             return (READ_REG(REG_IRQFLAGS1) & MASK_IRQFLAGS1_TX_READY);
634         case pllLocked:               return (READ_REG(REG_IRQFLAGS1) & MASK_IRQFLAGS1_PLL_LOCK);
635         case rssiExceededThreshold:   return (READ_REG(REG_IRQFLAGS1) & MASK_IRQFLAGS1_RSSI);
636         case timeout:                 return (READ_REG(REG_IRQFLAGS1) & MASK_IRQFLAGS1_TIMEOUT);
637         case automode:                return (READ_REG(REG_IRQFLAGS1) & MASK_IRQFLAGS1_AUTOMODE);
638         case syncAddressMatch:        return (READ_REG(REG_IRQFLAGS1) & MASK_IRQFLAGS1_SYNC_ADDRESS_MATCH);
639         case fifoFull:                return (READ_REG(REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_FULL);
640 /*      case fifoNotEmpty:            return (READ_REG(REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_NOT_EMPTY); */
641         case fifoEmpty:               return !(READ_REG(REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_NOT_EMPTY);
642         case fifoLevelBelowThreshold: return (READ_REG(REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_LEVEL);
643         case fifoOverrun:             return (READ_REG(REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_OVERRUN);
644         case packetSent:              return (READ_REG(REG_IRQFLAGS2) & MASK_IRQFLAGS2_PACKET_SENT);
645         case payloadReady:            return (READ_REG(REG_IRQFLAGS2) & MASK_IRQFLAGS2_PAYLOAD_READY);
646         case crcOk:                   return (READ_REG(REG_IRQFLAGS2) & MASK_IRQFLAGS2_CRC_OK);
647         case batteryLow:              return (READ_REG(REG_IRQFLAGS2) & MASK_IRQFLAGS2_LOW_BAT);
648         default:                      return false;
649         }
650 }
651
652 int rf69_reset_flag(struct spi_device *spi, enum flag flag)
653 {
654         #ifdef DEBUG
655                 dev_dbg(&spi->dev, "reset: flag");
656         #endif
657
658         switch (flag) {
659         case rssiExceededThreshold: return WRITE_REG(REG_IRQFLAGS1, MASK_IRQFLAGS1_RSSI);
660         case syncAddressMatch:      return WRITE_REG(REG_IRQFLAGS1, MASK_IRQFLAGS1_SYNC_ADDRESS_MATCH);
661         case fifoOverrun:           return WRITE_REG(REG_IRQFLAGS2, MASK_IRQFLAGS2_FIFO_OVERRUN);
662         default:
663                 dev_dbg(&spi->dev, "set: illegal input param");
664                 return -EINVAL;
665         }
666 }
667
668 int rf69_set_rssi_threshold(struct spi_device *spi, u8 threshold)
669 {
670         #ifdef DEBUG
671                 dev_dbg(&spi->dev, "set: rssi threshold");
672         #endif
673
674         /* no value check needed - u8 exactly matches register size */
675
676         return WRITE_REG(REG_RSSITHRESH, threshold);
677 }
678
679 int rf69_set_rx_start_timeout(struct spi_device *spi, u8 timeout)
680 {
681         #ifdef DEBUG
682                 dev_dbg(&spi->dev, "set: start timeout");
683         #endif
684
685         /* no value check needed - u8 exactly matches register size */
686
687         return WRITE_REG(REG_RXTIMEOUT1, timeout);
688 }
689
690 int rf69_set_rssi_timeout(struct spi_device *spi, u8 timeout)
691 {
692         #ifdef DEBUG
693                 dev_dbg(&spi->dev, "set: rssi timeout");
694         #endif
695
696         /* no value check needed - u8 exactly matches register size */
697
698         return WRITE_REG(REG_RXTIMEOUT2, timeout);
699 }
700
701 int rf69_set_preamble_length(struct spi_device *spi, u16 preambleLength)
702 {
703         int retval;
704         u8 msb, lsb;
705
706         #ifdef DEBUG
707                 dev_dbg(&spi->dev, "set: preamble length");
708         #endif
709
710         /* no value check needed - u16 exactly matches register size */
711
712         /* calculate reg settings */
713         msb = (preambleLength&0xff00)   >>  8;
714         lsb = (preambleLength&0xff);
715
716         /* transmit to chip */
717         retval = WRITE_REG(REG_PREAMBLE_MSB, msb);
718         if (retval)
719                 return retval;
720         return WRITE_REG(REG_PREAMBLE_LSB, lsb);
721 }
722
723 int rf69_set_sync_enable(struct spi_device *spi, enum optionOnOff optionOnOff)
724 {
725         #ifdef DEBUG
726                 dev_dbg(&spi->dev, "set: sync enable");
727         #endif
728
729         switch (optionOnOff) {
730         case optionOn:  return WRITE_REG(REG_SYNC_CONFIG, (READ_REG(REG_SYNC_CONFIG) |  MASK_SYNC_CONFIG_SYNC_ON));
731         case optionOff: return WRITE_REG(REG_SYNC_CONFIG, (READ_REG(REG_SYNC_CONFIG) & ~MASK_SYNC_CONFIG_SYNC_ON));
732         default:
733                 dev_dbg(&spi->dev, "set: illegal input param");
734                 return -EINVAL;
735         }
736 }
737
738 int rf69_set_fifo_fill_condition(struct spi_device *spi, enum fifoFillCondition fifoFillCondition)
739 {
740         #ifdef DEBUG
741                 dev_dbg(&spi->dev, "set: fifo fill condition");
742         #endif
743
744         switch (fifoFillCondition) {
745         case always:             return WRITE_REG(REG_SYNC_CONFIG, (READ_REG(REG_SYNC_CONFIG) |  MASK_SYNC_CONFIG_FIFO_FILL_CONDITION));
746         case afterSyncInterrupt: return WRITE_REG(REG_SYNC_CONFIG, (READ_REG(REG_SYNC_CONFIG) & ~MASK_SYNC_CONFIG_FIFO_FILL_CONDITION));
747         default:
748                 dev_dbg(&spi->dev, "set: illegal input param");
749                 return -EINVAL;
750         }
751 }
752
753 int rf69_set_sync_size(struct spi_device *spi, u8 syncSize)
754 {
755         #ifdef DEBUG
756                 dev_dbg(&spi->dev, "set: sync size");
757         #endif
758
759         // check input value
760         if (syncSize > 0x07) {
761                 dev_dbg(&spi->dev, "set: illegal input param");
762                 return -EINVAL;
763         }
764
765         // write value
766         return WRITE_REG(REG_SYNC_CONFIG, (READ_REG(REG_SYNC_CONFIG) & ~MASK_SYNC_CONFIG_SYNC_SIZE) | (syncSize << 3));
767 }
768
769 int rf69_set_sync_tolerance(struct spi_device *spi, u8 syncTolerance)
770 {
771         #ifdef DEBUG
772                 dev_dbg(&spi->dev, "set: sync tolerance");
773         #endif
774
775         // check input value
776         if (syncTolerance > 0x07) {
777                 dev_dbg(&spi->dev, "set: illegal input param");
778                 return -EINVAL;
779         }
780
781         // write value
782         return WRITE_REG(REG_SYNC_CONFIG, (READ_REG(REG_SYNC_CONFIG) & ~MASK_SYNC_CONFIG_SYNC_SIZE) | syncTolerance);
783 }
784
785 int rf69_set_sync_values(struct spi_device *spi, u8 syncValues[8])
786 {
787         int retval = 0;
788
789         #ifdef DEBUG
790                 dev_dbg(&spi->dev, "set: sync values");
791         #endif
792
793         retval += WRITE_REG(REG_SYNCVALUE1, syncValues[0]);
794         retval += WRITE_REG(REG_SYNCVALUE2, syncValues[1]);
795         retval += WRITE_REG(REG_SYNCVALUE3, syncValues[2]);
796         retval += WRITE_REG(REG_SYNCVALUE4, syncValues[3]);
797         retval += WRITE_REG(REG_SYNCVALUE5, syncValues[4]);
798         retval += WRITE_REG(REG_SYNCVALUE6, syncValues[5]);
799         retval += WRITE_REG(REG_SYNCVALUE7, syncValues[6]);
800         retval += WRITE_REG(REG_SYNCVALUE8, syncValues[7]);
801
802         return retval;
803 }
804
805 int rf69_set_packet_format(struct spi_device *spi, enum packetFormat packetFormat)
806 {
807         #ifdef DEBUG
808                 dev_dbg(&spi->dev, "set: packet format");
809         #endif
810
811         switch (packetFormat) {
812         case packetLengthVar: return WRITE_REG(REG_PACKETCONFIG1, (READ_REG(REG_PACKETCONFIG1) |  MASK_PACKETCONFIG1_PAKET_FORMAT_VARIABLE));
813         case packetLengthFix: return WRITE_REG(REG_PACKETCONFIG1, (READ_REG(REG_PACKETCONFIG1) & ~MASK_PACKETCONFIG1_PAKET_FORMAT_VARIABLE));
814         default:
815                 dev_dbg(&spi->dev, "set: illegal input param");
816                 return -EINVAL;
817         }
818 }
819
820 int rf69_set_crc_enable(struct spi_device *spi, enum optionOnOff optionOnOff)
821 {
822         #ifdef DEBUG
823                 dev_dbg(&spi->dev, "set: crc enable");
824         #endif
825
826         switch (optionOnOff) {
827         case optionOn:  return WRITE_REG(REG_PACKETCONFIG1, (READ_REG(REG_PACKETCONFIG1) |  MASK_PACKETCONFIG1_CRC_ON));
828         case optionOff: return WRITE_REG(REG_PACKETCONFIG1, (READ_REG(REG_PACKETCONFIG1) & ~MASK_PACKETCONFIG1_CRC_ON));
829         default:
830                 dev_dbg(&spi->dev, "set: illegal input param");
831                 return -EINVAL;
832         }
833 }
834
835 int rf69_set_adressFiltering(struct spi_device *spi, enum addressFiltering addressFiltering)
836 {
837         #ifdef DEBUG
838                 dev_dbg(&spi->dev, "set: address filtering");
839         #endif
840
841         switch (addressFiltering) {
842         case filteringOff:           return WRITE_REG(REG_PACKETCONFIG1, ((READ_REG(REG_PACKETCONFIG1) & ~MASK_PACKETCONFIG1_ADDRESSFILTERING) | PACKETCONFIG1_ADDRESSFILTERING_OFF));
843         case nodeAddress:            return WRITE_REG(REG_PACKETCONFIG1, ((READ_REG(REG_PACKETCONFIG1) & ~MASK_PACKETCONFIG1_ADDRESSFILTERING) | PACKETCONFIG1_ADDRESSFILTERING_NODE));
844         case nodeOrBroadcastAddress: return WRITE_REG(REG_PACKETCONFIG1, ((READ_REG(REG_PACKETCONFIG1) & ~MASK_PACKETCONFIG1_ADDRESSFILTERING) | PACKETCONFIG1_ADDRESSFILTERING_NODEBROADCAST));
845         default:
846                 dev_dbg(&spi->dev, "set: illegal input param");
847                 return -EINVAL;
848         }
849 }
850
851 int rf69_set_payload_length(struct spi_device *spi, u8 payloadLength)
852 {
853         #ifdef DEBUG
854                 dev_dbg(&spi->dev, "set: payload length");
855         #endif
856
857         return WRITE_REG(REG_PAYLOAD_LENGTH, payloadLength);
858 }
859
860 u8  rf69_get_payload_length(struct spi_device *spi)
861 {
862         #ifdef DEBUG
863                 dev_dbg(&spi->dev, "get: payload length");
864         #endif
865
866         return (u8) READ_REG(REG_PAYLOAD_LENGTH);
867 }
868
869 int rf69_set_node_address(struct spi_device *spi, u8 nodeAddress)
870 {
871         #ifdef DEBUG
872                 dev_dbg(&spi->dev, "set: node address");
873         #endif
874
875         return WRITE_REG(REG_NODEADRS, nodeAddress);
876 }
877
878 int rf69_set_broadcast_address(struct spi_device *spi, u8 broadcastAddress)
879 {
880         #ifdef DEBUG
881                 dev_dbg(&spi->dev, "set: broadcast address");
882         #endif
883
884         return WRITE_REG(REG_BROADCASTADRS, broadcastAddress);
885 }
886
887 int rf69_set_tx_start_condition(struct spi_device *spi, enum txStartCondition txStartCondition)
888 {
889         #ifdef DEBUG
890                 dev_dbg(&spi->dev, "set: start condition");
891         #endif
892
893         switch (txStartCondition) {
894         case fifoLevel:    return WRITE_REG(REG_FIFO_THRESH, (READ_REG(REG_FIFO_THRESH) & ~MASK_FIFO_THRESH_TXSTART));
895         case fifoNotEmpty: return WRITE_REG(REG_FIFO_THRESH, (READ_REG(REG_FIFO_THRESH) |  MASK_FIFO_THRESH_TXSTART));
896         default:
897                 dev_dbg(&spi->dev, "set: illegal input param");
898                 return -EINVAL;
899         }
900 }
901
902 int rf69_set_fifo_threshold(struct spi_device *spi, u8 threshold)
903 {
904         int retval;
905
906         #ifdef DEBUG
907                 dev_dbg(&spi->dev, "set: fifo threshold");
908         #endif
909
910         // check input value
911         if (threshold & 0x80) {
912                 dev_dbg(&spi->dev, "set: illegal input param");
913                 return -EINVAL;
914         }
915
916         // write value
917         retval = WRITE_REG(REG_FIFO_THRESH, (READ_REG(REG_FIFO_THRESH) & ~MASK_FIFO_THRESH_VALUE) | threshold);
918         if (retval)
919                 return retval;
920
921         // access the fifo to activate new threshold
922         return rf69_read_fifo(spi, (u8 *)&retval, 1); // retval used as buffer
923 }
924
925 int rf69_set_dagc(struct spi_device *spi, enum dagc dagc)
926 {
927         #ifdef DEBUG
928                 dev_dbg(&spi->dev, "set: dagc");
929         #endif
930
931         switch (dagc) {
932         case normalMode:                 return WRITE_REG(REG_TESTDAGC, DAGC_NORMAL);
933         case improve:                    return WRITE_REG(REG_TESTDAGC, DAGC_IMPROVED_LOWBETA0);
934         case improve4LowModulationIndex: return WRITE_REG(REG_TESTDAGC, DAGC_IMPROVED_LOWBETA1);
935         default:
936                 dev_dbg(&spi->dev, "set: illegal input param");
937                 return -EINVAL;
938         }
939 }
940
941 /*-------------------------------------------------------------------------*/
942
943 int rf69_read_fifo (struct spi_device *spi, u8 *buffer, unsigned int size)
944 {
945         #ifdef DEBUG_FIFO_ACCESS
946                 int i;
947         #endif
948         struct spi_transfer transfer;
949         u8 local_buffer[FIFO_SIZE + 1];
950         int retval;
951
952         if (size > FIFO_SIZE) {
953                 #ifdef DEBUG
954                         dev_dbg(&spi->dev, "read fifo: passed in buffer bigger then internal buffer \n");
955                 #endif
956                 return -EMSGSIZE;
957         }
958
959         /* prepare a bidirectional transfer */
960         local_buffer[0] = REG_FIFO;
961         memset(&transfer, 0, sizeof(transfer));
962         transfer.tx_buf = local_buffer;
963         transfer.rx_buf = local_buffer;
964         transfer.len    = size+1;
965
966         retval = spi_sync_transfer(spi, &transfer, 1);
967
968         #ifdef DEBUG_FIFO_ACCESS
969                 for (i = 0; i < size; i++)
970                         dev_dbg(&spi->dev, "%d - 0x%x\n", i, local_buffer[i+1]);
971         #endif
972
973         memcpy(buffer, &local_buffer[1], size);  // TODO: ohne memcopy wäre schöner
974
975         return retval;
976 }
977
978 int rf69_write_fifo(struct spi_device *spi, u8 *buffer, unsigned int size)
979 {
980         #ifdef DEBUG_FIFO_ACCESS
981                 int i;
982         #endif
983         char spi_address = REG_FIFO | WRITE_BIT;
984         u8 local_buffer[FIFO_SIZE + 1];
985
986         if (size > FIFO_SIZE) {
987                 #ifdef DEBUG
988                         dev_dbg(&spi->dev, "read fifo: passed in buffer bigger then internal buffer \n");
989                 #endif
990                 return -EMSGSIZE;
991         }
992
993         local_buffer[0] = spi_address;
994         memcpy(&local_buffer[1], buffer, size);  // TODO: ohne memcopy wäre schöner
995
996         #ifdef DEBUG_FIFO_ACCESS
997                 for (i = 0; i < size; i++)
998                         dev_dbg(&spi->dev, "0x%x\n", buffer[i]);
999         #endif
1000
1001         return spi_write (spi, local_buffer, size + 1);
1002 }
1003
1004 /*-------------------------------------------------------------------------*/
1005
1006 u8 rf69_read_reg(struct spi_device *spi, u8 addr)
1007 {
1008         int retval;
1009
1010         retval = spi_w8r8(spi, addr);
1011
1012         #ifdef DEBUG_VALUES
1013                 if (retval < 0)
1014                         /* should never happen, since we already checked,
1015                          * that module is connected. Therefore no error
1016                          * handling, just an optional error message...
1017                          */
1018                         dev_dbg(&spi->dev, "read 0x%x FAILED\n",
1019                                 addr);
1020                 else
1021                         dev_dbg(&spi->dev, "read 0x%x from reg 0x%x\n",
1022                                 retval,
1023                                 addr);
1024         #endif
1025
1026         return retval;
1027 }
1028
1029 int rf69_write_reg(struct spi_device *spi, u8 addr, u8 value)
1030 {
1031         int retval;
1032         char buffer[2];
1033
1034         buffer[0] = addr | WRITE_BIT;
1035         buffer[1] = value;
1036
1037         retval = spi_write(spi, &buffer, 2);
1038
1039         #ifdef DEBUG_VALUES
1040                 if (retval < 0)
1041                         /* should never happen, since we already checked,
1042                          * that module is connected. Therefore no error
1043                          * handling, just an optional error message...
1044                          */
1045                         dev_dbg(&spi->dev, "write 0x%x to 0x%x FAILED\n",
1046                                 value,
1047                                 addr);
1048                 else
1049                         dev_dbg(&spi->dev, "wrote 0x%x to reg 0x%x\n",
1050                                 value,
1051                                 addr);
1052         #endif
1053
1054         return retval;
1055 }
1056
1057