1 // SPDX-License-Identifier: GPL-2.0+
3 * abstraction of the spi interface of HopeRf rf69 radio module
5 * Copyright (C) 2016 Wolf-Entwicklungen
9 /* enable prosa debug info */
11 /* enable print of values on reg access */
13 /* enable print of values on fifo access */
14 #undef DEBUG_FIFO_ACCESS
16 #include <linux/types.h>
17 #include <linux/spi/spi.h>
20 #include "rf69_registers.h"
22 #define F_OSC 32000000 /* in Hz */
23 #define FIFO_SIZE 66 /* in byte */
25 /*-------------------------------------------------------------------------*/
27 static u8 rf69_read_reg(struct spi_device *spi, u8 addr)
31 retval = spi_w8r8(spi, addr);
36 * should never happen, since we already checked,
37 * that module is connected. Therefore no error
38 * handling, just an optional error message...
40 dev_dbg(&spi->dev, "read 0x%x FAILED\n", addr);
42 dev_dbg(&spi->dev, "read 0x%x from reg 0x%x\n", retval, addr);
48 static int rf69_write_reg(struct spi_device *spi, u8 addr, u8 value)
53 buffer[0] = addr | WRITE_BIT;
56 retval = spi_write(spi, &buffer, 2);
61 * should never happen, since we already checked,
62 * that module is connected. Therefore no error
63 * handling, just an optional error message...
65 dev_dbg(&spi->dev, "write 0x%x to 0x%x FAILED\n", value, addr);
67 dev_dbg(&spi->dev, "wrote 0x%x to reg 0x%x\n", value, addr);
73 /*-------------------------------------------------------------------------*/
75 static int rf69_set_bit(struct spi_device *spi, u8 reg, u8 mask)
79 tmp = rf69_read_reg(spi, reg);
81 return rf69_write_reg(spi, reg, tmp);
84 static int rf69_clear_bit(struct spi_device *spi, u8 reg, u8 mask)
88 tmp = rf69_read_reg(spi, reg);
90 return rf69_write_reg(spi, reg, tmp);
93 static inline int rf69_read_mod_write(struct spi_device *spi, u8 reg,
98 tmp = rf69_read_reg(spi, reg);
99 tmp = (tmp & ~mask) | value;
100 return rf69_write_reg(spi, reg, tmp);
103 /*-------------------------------------------------------------------------*/
105 int rf69_set_mode(struct spi_device *spi, enum mode mode)
107 static const u8 mode_map[] = {
108 [transmit] = OPMODE_MODE_TRANSMIT,
109 [receive] = OPMODE_MODE_RECEIVE,
110 [synthesizer] = OPMODE_MODE_SYNTHESIZER,
111 [standby] = OPMODE_MODE_STANDBY,
112 [mode_sleep] = OPMODE_MODE_SLEEP,
115 if (unlikely(mode >= ARRAY_SIZE(mode_map))) {
116 dev_dbg(&spi->dev, "set: illegal mode %u", mode);
120 return rf69_read_mod_write(spi, REG_OPMODE, MASK_OPMODE_MODE,
124 * we are using packet mode, so this check is not really needed
125 * but waiting for mode ready is necessary when going from sleep
126 * because the FIFO may not be immediately available from previous mode
127 * while (_mode == RF69_MODE_SLEEP && (READ_REG(REG_IRQFLAGS1) &
128 RF_IRQFLAGS1_MODEREADY) == 0x00); // Wait for ModeReady
132 int rf69_set_data_mode(struct spi_device *spi, u8 data_mode)
134 return rf69_read_mod_write(spi, REG_DATAMODUL, MASK_DATAMODUL_MODE,
138 int rf69_set_modulation(struct spi_device *spi, enum modulation modulation)
140 static const u8 modulation_map[] = {
141 [OOK] = DATAMODUL_MODULATION_TYPE_OOK,
142 [FSK] = DATAMODUL_MODULATION_TYPE_FSK,
145 if (unlikely(modulation >= ARRAY_SIZE(modulation_map))) {
146 dev_dbg(&spi->dev, "set: illegal modulation %u", modulation);
150 return rf69_read_mod_write(spi, REG_DATAMODUL,
151 MASK_DATAMODUL_MODULATION_TYPE,
152 modulation_map[modulation]);
155 static enum modulation rf69_get_modulation(struct spi_device *spi)
159 modulation_reg = rf69_read_reg(spi, REG_DATAMODUL);
161 switch (modulation_reg & MASK_DATAMODUL_MODULATION_TYPE) {
162 case DATAMODUL_MODULATION_TYPE_OOK:
164 case DATAMODUL_MODULATION_TYPE_FSK:
171 int rf69_set_modulation_shaping(struct spi_device *spi,
172 enum mod_shaping mod_shaping)
174 switch (rf69_get_modulation(spi)) {
176 switch (mod_shaping) {
178 return rf69_read_mod_write(spi, REG_DATAMODUL,
179 MASK_DATAMODUL_MODULATION_SHAPE,
180 DATAMODUL_MODULATION_SHAPE_NONE);
182 return rf69_read_mod_write(spi, REG_DATAMODUL,
183 MASK_DATAMODUL_MODULATION_SHAPE,
184 DATAMODUL_MODULATION_SHAPE_1_0);
186 return rf69_read_mod_write(spi, REG_DATAMODUL,
187 MASK_DATAMODUL_MODULATION_SHAPE,
188 DATAMODUL_MODULATION_SHAPE_0_5);
190 return rf69_read_mod_write(spi, REG_DATAMODUL,
191 MASK_DATAMODUL_MODULATION_SHAPE,
192 DATAMODUL_MODULATION_SHAPE_0_3);
194 dev_dbg(&spi->dev, "set: illegal mod shaping for FSK %u", mod_shaping);
198 switch (mod_shaping) {
200 return rf69_read_mod_write(spi, REG_DATAMODUL,
201 MASK_DATAMODUL_MODULATION_SHAPE,
202 DATAMODUL_MODULATION_SHAPE_NONE);
204 return rf69_read_mod_write(spi, REG_DATAMODUL,
205 MASK_DATAMODUL_MODULATION_SHAPE,
206 DATAMODUL_MODULATION_SHAPE_BR);
208 return rf69_read_mod_write(spi, REG_DATAMODUL,
209 MASK_DATAMODUL_MODULATION_SHAPE,
210 DATAMODUL_MODULATION_SHAPE_2BR);
212 dev_dbg(&spi->dev, "set: illegal mod shaping for OOK %u", mod_shaping);
216 dev_dbg(&spi->dev, "set: modulation undefined");
221 int rf69_set_bit_rate(struct spi_device *spi, u16 bit_rate)
230 bit_rate_min = F_OSC / 8388608; // 8388608 = 2^23;
231 if (bit_rate < bit_rate_min) {
232 dev_dbg(&spi->dev, "setBitRate: illegal input param");
236 // calculate reg settings
237 bit_rate_reg = (F_OSC / bit_rate);
239 msb = (bit_rate_reg & 0xff00) >> 8;
240 lsb = (bit_rate_reg & 0xff);
243 retval = rf69_write_reg(spi, REG_BITRATE_MSB, msb);
246 retval = rf69_write_reg(spi, REG_BITRATE_LSB, lsb);
253 int rf69_set_deviation(struct spi_device *spi, u32 deviation)
262 u64 factor = 1000000; // to improve precision of calculation
264 // calculate bit rate
265 bit_rate_reg = rf69_read_reg(spi, REG_BITRATE_MSB) << 8;
266 bit_rate_reg |= rf69_read_reg(spi, REG_BITRATE_LSB);
267 bit_rate = F_OSC / bit_rate_reg;
270 * frequency deviation must exceed 600 Hz but not exceed
271 * 500kHz when taking bitrate dependency into consideration
272 * to ensure proper modulation
274 if (deviation < 600 || (deviation + (bit_rate / 2)) > 500000) {
276 "set_deviation: illegal input param: %u", deviation);
281 f_step = F_OSC * factor;
282 do_div(f_step, 524288); // 524288 = 2^19
284 // calculate register settings
285 f_reg = deviation * factor;
286 do_div(f_reg, f_step);
288 msb = (f_reg & 0xff00) >> 8;
289 lsb = (f_reg & 0xff);
292 if (msb & ~FDEVMASB_MASK) {
293 dev_dbg(&spi->dev, "set_deviation: err in calc of msb");
298 retval = rf69_write_reg(spi, REG_FDEV_MSB, msb);
301 retval = rf69_write_reg(spi, REG_FDEV_LSB, lsb);
308 int rf69_set_frequency(struct spi_device *spi, u32 frequency)
317 u64 factor = 1000000; // to improve precision of calculation
320 f_step = F_OSC * factor;
321 do_div(f_step, 524288); // 524288 = 2^19
324 f_max = div_u64(f_step * 8388608, factor);
325 if (frequency > f_max) {
326 dev_dbg(&spi->dev, "setFrequency: illegal input param");
330 // calculate reg settings
331 f_reg = frequency * factor;
332 do_div(f_reg, f_step);
334 msb = (f_reg & 0xff0000) >> 16;
335 mid = (f_reg & 0xff00) >> 8;
336 lsb = (f_reg & 0xff);
339 retval = rf69_write_reg(spi, REG_FRF_MSB, msb);
342 retval = rf69_write_reg(spi, REG_FRF_MID, mid);
345 retval = rf69_write_reg(spi, REG_FRF_LSB, lsb);
352 int rf69_enable_amplifier(struct spi_device *spi, u8 amplifier_mask)
354 return rf69_set_bit(spi, REG_PALEVEL, amplifier_mask);
357 int rf69_disable_amplifier(struct spi_device *spi, u8 amplifier_mask)
359 return rf69_clear_bit(spi, REG_PALEVEL, amplifier_mask);
362 int rf69_set_output_power_level(struct spi_device *spi, u8 power_level)
364 u8 pa_level, ocp, test_pa1, test_pa2;
365 bool pa0, pa1, pa2, high_power;
368 // check register pa_level
369 pa_level = rf69_read_reg(spi, REG_PALEVEL);
370 pa0 = pa_level & MASK_PALEVEL_PA0;
371 pa1 = pa_level & MASK_PALEVEL_PA1;
372 pa2 = pa_level & MASK_PALEVEL_PA2;
374 // check high power mode
375 ocp = rf69_read_reg(spi, REG_OCP);
376 test_pa1 = rf69_read_reg(spi, REG_TESTPA1);
377 test_pa2 = rf69_read_reg(spi, REG_TESTPA2);
378 high_power = (ocp == 0x0f) && (test_pa1 == 0x5d) && (test_pa2 == 0x7c);
380 if (pa0 && !pa1 && !pa2) {
383 } else if (!pa0 && pa1 && !pa2) {
385 min_power_level = 16;
386 } else if (!pa0 && pa1 && pa2) {
391 min_power_level = 16;
397 if (power_level > 0x1f)
400 if (power_level < min_power_level)
404 return rf69_read_mod_write(spi, REG_PALEVEL, MASK_PALEVEL_OUTPUT_POWER,
407 dev_dbg(&spi->dev, "set: illegal power level %u", power_level);
411 int rf69_set_pa_ramp(struct spi_device *spi, enum pa_ramp pa_ramp)
413 static const u8 pa_ramp_map[] = {
414 [ramp3400] = PARAMP_3400,
415 [ramp2000] = PARAMP_2000,
416 [ramp1000] = PARAMP_1000,
417 [ramp500] = PARAMP_500,
418 [ramp250] = PARAMP_250,
419 [ramp125] = PARAMP_125,
420 [ramp100] = PARAMP_100,
421 [ramp62] = PARAMP_62,
422 [ramp50] = PARAMP_50,
423 [ramp40] = PARAMP_40,
424 [ramp31] = PARAMP_31,
425 [ramp25] = PARAMP_25,
426 [ramp20] = PARAMP_20,
427 [ramp15] = PARAMP_15,
428 [ramp10] = PARAMP_10,
431 if (unlikely(pa_ramp >= ARRAY_SIZE(pa_ramp_map))) {
432 dev_dbg(&spi->dev, "set: illegal pa_ramp %u", pa_ramp);
436 return rf69_write_reg(spi, REG_PARAMP, pa_ramp_map[pa_ramp]);
439 int rf69_set_antenna_impedance(struct spi_device *spi,
440 enum antenna_impedance antenna_impedance)
442 switch (antenna_impedance) {
444 return rf69_clear_bit(spi, REG_LNA, MASK_LNA_ZIN);
445 case two_hundred_ohm:
446 return rf69_set_bit(spi, REG_LNA, MASK_LNA_ZIN);
448 dev_dbg(&spi->dev, "set: illegal antenna impedance %u", antenna_impedance);
453 int rf69_set_lna_gain(struct spi_device *spi, enum lna_gain lna_gain)
455 static const u8 lna_gain_map[] = {
456 [automatic] = LNA_GAIN_AUTO,
457 [max] = LNA_GAIN_MAX,
458 [max_minus_6] = LNA_GAIN_MAX_MINUS_6,
459 [max_minus_12] = LNA_GAIN_MAX_MINUS_12,
460 [max_minus_24] = LNA_GAIN_MAX_MINUS_24,
461 [max_minus_36] = LNA_GAIN_MAX_MINUS_36,
462 [max_minus_48] = LNA_GAIN_MAX_MINUS_48,
465 if (unlikely(lna_gain >= ARRAY_SIZE(lna_gain_map))) {
466 dev_dbg(&spi->dev, "set: illegal lna gain %u", lna_gain);
470 return rf69_read_mod_write(spi, REG_LNA, MASK_LNA_GAIN,
471 lna_gain_map[lna_gain]);
474 static int rf69_set_bandwidth_intern(struct spi_device *spi, u8 reg,
475 enum mantisse mantisse, u8 exponent)
479 // check value for mantisse and exponent
481 dev_dbg(&spi->dev, "set: illegal bandwidth exponent %u", exponent);
485 if (mantisse != mantisse16 &&
486 mantisse != mantisse20 &&
487 mantisse != mantisse24) {
488 dev_dbg(&spi->dev, "set: illegal bandwidth mantisse %u", mantisse);
493 bandwidth = rf69_read_reg(spi, reg);
495 // "delete" mantisse and exponent = just keep the DCC setting
496 bandwidth = bandwidth & MASK_BW_DCC_FREQ;
501 bandwidth = bandwidth | BW_MANT_16;
504 bandwidth = bandwidth | BW_MANT_20;
507 bandwidth = bandwidth | BW_MANT_24;
512 bandwidth = bandwidth | exponent;
515 return rf69_write_reg(spi, reg, bandwidth);
518 int rf69_set_bandwidth(struct spi_device *spi, enum mantisse mantisse,
521 return rf69_set_bandwidth_intern(spi, REG_RXBW, mantisse, exponent);
524 int rf69_set_bandwidth_during_afc(struct spi_device *spi,
525 enum mantisse mantisse,
528 return rf69_set_bandwidth_intern(spi, REG_AFCBW, mantisse, exponent);
531 int rf69_set_ook_threshold_dec(struct spi_device *spi,
532 enum threshold_decrement threshold_decrement)
534 static const u8 td_map[] = {
535 [dec_every8th] = OOKPEAK_THRESHDEC_EVERY_8TH,
536 [dec_every4th] = OOKPEAK_THRESHDEC_EVERY_4TH,
537 [dec_every2nd] = OOKPEAK_THRESHDEC_EVERY_2ND,
538 [dec_once] = OOKPEAK_THRESHDEC_ONCE,
539 [dec_twice] = OOKPEAK_THRESHDEC_TWICE,
540 [dec_4times] = OOKPEAK_THRESHDEC_4_TIMES,
541 [dec_8times] = OOKPEAK_THRESHDEC_8_TIMES,
542 [dec_16times] = OOKPEAK_THRESHDEC_16_TIMES,
545 if (unlikely(threshold_decrement >= ARRAY_SIZE(td_map))) {
546 dev_dbg(&spi->dev, "set: illegal OOK threshold decrement %u", threshold_decrement);
550 return rf69_read_mod_write(spi, REG_OOKPEAK, MASK_OOKPEAK_THRESDEC,
551 td_map[threshold_decrement]);
554 int rf69_set_dio_mapping(struct spi_device *spi, u8 dio_number, u8 value)
561 switch (dio_number) {
565 dio_addr = REG_DIOMAPPING1;
570 dio_addr = REG_DIOMAPPING1;
575 dio_addr = REG_DIOMAPPING1;
580 dio_addr = REG_DIOMAPPING1;
585 dio_addr = REG_DIOMAPPING2;
590 dio_addr = REG_DIOMAPPING2;
593 dev_dbg(&spi->dev, "set: illegal dio number %u", dio_number);
598 dio_value = rf69_read_reg(spi, dio_addr);
600 dio_value = dio_value & ~mask;
602 dio_value = dio_value | value << shift;
604 return rf69_write_reg(spi, dio_addr, dio_value);
607 bool rf69_get_flag(struct spi_device *spi, enum flag flag)
610 case mode_switch_completed:
611 return (rf69_read_reg(spi, REG_IRQFLAGS1) & MASK_IRQFLAGS1_MODE_READY);
612 case ready_to_receive:
613 return (rf69_read_reg(spi, REG_IRQFLAGS1) & MASK_IRQFLAGS1_RX_READY);
615 return (rf69_read_reg(spi, REG_IRQFLAGS1) & MASK_IRQFLAGS1_TX_READY);
617 return (rf69_read_reg(spi, REG_IRQFLAGS1) & MASK_IRQFLAGS1_PLL_LOCK);
618 case rssi_exceeded_threshold:
619 return (rf69_read_reg(spi, REG_IRQFLAGS1) & MASK_IRQFLAGS1_RSSI);
621 return (rf69_read_reg(spi, REG_IRQFLAGS1) & MASK_IRQFLAGS1_TIMEOUT);
623 return (rf69_read_reg(spi, REG_IRQFLAGS1) & MASK_IRQFLAGS1_AUTOMODE);
624 case sync_address_match:
625 return (rf69_read_reg(spi, REG_IRQFLAGS1) & MASK_IRQFLAGS1_SYNC_ADDRESS_MATCH);
627 return (rf69_read_reg(spi, REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_FULL);
629 * case fifo_not_empty:
630 * return (rf69_read_reg(spi, REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_NOT_EMPTY);
633 return !(rf69_read_reg(spi, REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_NOT_EMPTY);
634 case fifo_level_below_threshold:
635 return (rf69_read_reg(spi, REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_LEVEL);
637 return (rf69_read_reg(spi, REG_IRQFLAGS2) & MASK_IRQFLAGS2_FIFO_OVERRUN);
639 return (rf69_read_reg(spi, REG_IRQFLAGS2) & MASK_IRQFLAGS2_PACKET_SENT);
641 return (rf69_read_reg(spi, REG_IRQFLAGS2) & MASK_IRQFLAGS2_PAYLOAD_READY);
643 return (rf69_read_reg(spi, REG_IRQFLAGS2) & MASK_IRQFLAGS2_CRC_OK);
645 return (rf69_read_reg(spi, REG_IRQFLAGS2) & MASK_IRQFLAGS2_LOW_BAT);
646 default: return false;
650 int rf69_set_rssi_threshold(struct spi_device *spi, u8 threshold)
652 /* no value check needed - u8 exactly matches register size */
654 return rf69_write_reg(spi, REG_RSSITHRESH, threshold);
657 int rf69_set_preamble_length(struct spi_device *spi, u16 preamble_length)
662 /* no value check needed - u16 exactly matches register size */
664 /* calculate reg settings */
665 msb = (preamble_length & 0xff00) >> 8;
666 lsb = (preamble_length & 0xff);
668 /* transmit to chip */
669 retval = rf69_write_reg(spi, REG_PREAMBLE_MSB, msb);
672 return rf69_write_reg(spi, REG_PREAMBLE_LSB, lsb);
675 int rf69_enable_sync(struct spi_device *spi)
677 return rf69_set_bit(spi, REG_SYNC_CONFIG, MASK_SYNC_CONFIG_SYNC_ON);
680 int rf69_disable_sync(struct spi_device *spi)
682 return rf69_clear_bit(spi, REG_SYNC_CONFIG, MASK_SYNC_CONFIG_SYNC_ON);
685 int rf69_set_fifo_fill_condition(struct spi_device *spi,
686 enum fifo_fill_condition fifo_fill_condition)
688 switch (fifo_fill_condition) {
690 return rf69_set_bit(spi, REG_SYNC_CONFIG,
691 MASK_SYNC_CONFIG_FIFO_FILL_CONDITION);
692 case after_sync_interrupt:
693 return rf69_clear_bit(spi, REG_SYNC_CONFIG,
694 MASK_SYNC_CONFIG_FIFO_FILL_CONDITION);
696 dev_dbg(&spi->dev, "set: illegal fifo fill condition %u", fifo_fill_condition);
701 int rf69_set_sync_size(struct spi_device *spi, u8 sync_size)
704 if (sync_size > 0x07) {
705 dev_dbg(&spi->dev, "set: illegal sync size %u", sync_size);
710 return rf69_read_mod_write(spi, REG_SYNC_CONFIG,
711 MASK_SYNC_CONFIG_SYNC_SIZE,
715 int rf69_set_sync_values(struct spi_device *spi, u8 sync_values[8])
719 retval += rf69_write_reg(spi, REG_SYNCVALUE1, sync_values[0]);
720 retval += rf69_write_reg(spi, REG_SYNCVALUE2, sync_values[1]);
721 retval += rf69_write_reg(spi, REG_SYNCVALUE3, sync_values[2]);
722 retval += rf69_write_reg(spi, REG_SYNCVALUE4, sync_values[3]);
723 retval += rf69_write_reg(spi, REG_SYNCVALUE5, sync_values[4]);
724 retval += rf69_write_reg(spi, REG_SYNCVALUE6, sync_values[5]);
725 retval += rf69_write_reg(spi, REG_SYNCVALUE7, sync_values[6]);
726 retval += rf69_write_reg(spi, REG_SYNCVALUE8, sync_values[7]);
731 int rf69_set_packet_format(struct spi_device *spi,
732 enum packet_format packet_format)
734 switch (packet_format) {
735 case packet_length_var:
736 return rf69_set_bit(spi, REG_PACKETCONFIG1,
737 MASK_PACKETCONFIG1_PACKET_FORMAT_VARIABLE);
738 case packet_length_fix:
739 return rf69_clear_bit(spi, REG_PACKETCONFIG1,
740 MASK_PACKETCONFIG1_PACKET_FORMAT_VARIABLE);
742 dev_dbg(&spi->dev, "set: illegal packet format %u", packet_format);
747 int rf69_enable_crc(struct spi_device *spi)
749 return rf69_set_bit(spi, REG_PACKETCONFIG1, MASK_PACKETCONFIG1_CRC_ON);
752 int rf69_disable_crc(struct spi_device *spi)
754 return rf69_clear_bit(spi, REG_PACKETCONFIG1, MASK_PACKETCONFIG1_CRC_ON);
757 int rf69_set_address_filtering(struct spi_device *spi,
758 enum address_filtering address_filtering)
760 static const u8 af_map[] = {
761 [filtering_off] = PACKETCONFIG1_ADDRESSFILTERING_OFF,
762 [node_address] = PACKETCONFIG1_ADDRESSFILTERING_NODE,
763 [node_or_broadcast_address] =
764 PACKETCONFIG1_ADDRESSFILTERING_NODEBROADCAST,
767 if (unlikely(address_filtering >= ARRAY_SIZE(af_map))) {
768 dev_dbg(&spi->dev, "set: illegal address filtering %u", address_filtering);
772 return rf69_read_mod_write(spi, REG_PACKETCONFIG1,
773 MASK_PACKETCONFIG1_ADDRESSFILTERING,
774 af_map[address_filtering]);
777 int rf69_set_payload_length(struct spi_device *spi, u8 payload_length)
779 return rf69_write_reg(spi, REG_PAYLOAD_LENGTH, payload_length);
782 int rf69_set_node_address(struct spi_device *spi, u8 node_address)
784 return rf69_write_reg(spi, REG_NODEADRS, node_address);
787 int rf69_set_broadcast_address(struct spi_device *spi, u8 broadcast_address)
789 return rf69_write_reg(spi, REG_BROADCASTADRS, broadcast_address);
792 int rf69_set_tx_start_condition(struct spi_device *spi,
793 enum tx_start_condition tx_start_condition)
795 switch (tx_start_condition) {
797 return rf69_clear_bit(spi, REG_FIFO_THRESH,
798 MASK_FIFO_THRESH_TXSTART);
800 return rf69_set_bit(spi, REG_FIFO_THRESH,
801 MASK_FIFO_THRESH_TXSTART);
803 dev_dbg(&spi->dev, "set: illegal tx start condition %u", tx_start_condition);
808 int rf69_set_fifo_threshold(struct spi_device *spi, u8 threshold)
812 /* check input value */
813 if (threshold & 0x80) {
814 dev_dbg(&spi->dev, "set: illegal fifo threshold %u", threshold);
819 retval = rf69_read_mod_write(spi, REG_FIFO_THRESH,
820 MASK_FIFO_THRESH_VALUE,
826 * access the fifo to activate new threshold
827 * retval (mis-) used as buffer here
829 return rf69_read_fifo(spi, (u8 *)&retval, 1);
832 int rf69_set_dagc(struct spi_device *spi, enum dagc dagc)
834 static const u8 dagc_map[] = {
835 [normal_mode] = DAGC_NORMAL,
836 [improve] = DAGC_IMPROVED_LOWBETA0,
837 [improve_for_low_modulation_index] = DAGC_IMPROVED_LOWBETA1,
840 if (unlikely(dagc >= ARRAY_SIZE(dagc_map))) {
841 dev_dbg(&spi->dev, "set: illegal dagc %u", dagc);
845 return rf69_write_reg(spi, REG_TESTDAGC, dagc_map[dagc]);
848 /*-------------------------------------------------------------------------*/
850 int rf69_read_fifo(struct spi_device *spi, u8 *buffer, unsigned int size)
852 #ifdef DEBUG_FIFO_ACCESS
855 struct spi_transfer transfer;
856 u8 local_buffer[FIFO_SIZE + 1];
859 if (size > FIFO_SIZE) {
861 "read fifo: passed in buffer bigger then internal buffer\n");
865 /* prepare a bidirectional transfer */
866 local_buffer[0] = REG_FIFO;
867 memset(&transfer, 0, sizeof(transfer));
868 transfer.tx_buf = local_buffer;
869 transfer.rx_buf = local_buffer;
870 transfer.len = size + 1;
872 retval = spi_sync_transfer(spi, &transfer, 1);
874 #ifdef DEBUG_FIFO_ACCESS
875 for (i = 0; i < size; i++)
876 dev_dbg(&spi->dev, "%d - 0x%x\n", i, local_buffer[i + 1]);
879 memcpy(buffer, &local_buffer[1], size);
884 int rf69_write_fifo(struct spi_device *spi, u8 *buffer, unsigned int size)
886 #ifdef DEBUG_FIFO_ACCESS
889 u8 local_buffer[FIFO_SIZE + 1];
891 if (size > FIFO_SIZE) {
893 "read fifo: passed in buffer bigger then internal buffer\n");
897 local_buffer[0] = REG_FIFO | WRITE_BIT;
898 memcpy(&local_buffer[1], buffer, size);
900 #ifdef DEBUG_FIFO_ACCESS
901 for (i = 0; i < size; i++)
902 dev_dbg(&spi->dev, "0x%x\n", buffer[i]);
905 return spi_write(spi, local_buffer, size + 1);