Hi, On Wed, Aug 06, 2014 at 11:13:36AM +0100, Simon Vincent wrote: > The MRF24J40MC module has an external amplifier which should be enabled. > > Signed-off-by: Simon Vincent <simon.vinc...@xsilon.com> > --- > drivers/net/ieee802154/mrf24j40.c | 40 > +++++++++++++++++++++++++++++++++++++-- > 1 file changed, 38 insertions(+), 2 deletions(-) > > diff --git a/drivers/net/ieee802154/mrf24j40.c > b/drivers/net/ieee802154/mrf24j40.c > index 9e6a124..7950d01 100644 > --- a/drivers/net/ieee802154/mrf24j40.c > +++ b/drivers/net/ieee802154/mrf24j40.c > @@ -43,6 +43,8 @@ > #define REG_TXSTBL 0x2E /* TX Stabilization */ > #define REG_INTSTAT 0x31 /* Interrupt Status */ > #define REG_INTCON 0x32 /* Interrupt Control */ > +#define REG_GPIO 0x33 /* GPIO */ > +#define REG_TRISGPIO 0x34 /* GPIO direction */ > #define REG_RFCTL 0x36 /* RF Control Mode Register */ > #define REG_BBREG1 0x39 /* Baseband Registers */ > #define REG_BBREG2 0x3A /* */ > @@ -63,6 +65,7 @@ > #define REG_SLPCON1 0x220 > #define REG_WAKETIMEL 0x222 /* Wake-up Time Match Value Low */ > #define REG_WAKETIMEH 0x223 /* Wake-up Time Match Value High */ > +#define REG_TESTMODE 0x22F /* Test mode */ > #define REG_RX_FIFO 0x300 /* Receive FIFO */ > > /* Device configuration: Only channels 11-26 on page 0 are supported. */ > @@ -75,6 +78,8 @@ > #define RX_FIFO_SIZE 144 /* From datasheet */ > #define SET_CHANNEL_DELAY_US 192 /* From datasheet */ > > +enum modules { MRF24J40, MRF24J40MA, MRF24J40MC }; > + > /* Device Private Data */ > struct mrf24j40 { > struct spi_device *spi; > @@ -690,6 +695,35 @@ static int mrf24j40_hw_init(struct mrf24j40 *devrec) > if (ret) > goto err_ret; > > + if (spi_get_device_id(devrec->spi)->driver_data == MRF24J40MC) { > + /* Enable external amplifier */ > + ret = write_long_reg(devrec, REG_TESTMODE, 0xF); > + if (ret) > + goto err_ret; > + > + ret = read_short_reg(devrec, REG_TRISGPIO, &val); > + if (ret) > + goto err_ret; > + > + val |= 0x8; > + ret = write_short_reg(devrec, REG_TRISGPIO, val); > + if (ret) > + goto err_ret; > + > + ret = read_short_reg(devrec, REG_GPIO, &val); > + if (ret) > + goto err_ret; > + > + val |= 0x8; > + ret = write_short_reg(devrec, REG_GPIO, val); > + if (ret) > + goto err_ret; > + > + ret = write_long_reg(devrec, REG_RFCON3, 0x28); > + if (ret) > + goto err_ret; > + } > + > return 0; > > err_ret: > @@ -778,8 +813,9 @@ static int mrf24j40_remove(struct spi_device *spi) > } > > static const struct spi_device_id mrf24j40_ids[] = { > - { "mrf24j40", 0 }, > - { "mrf24j40ma", 0 }, > + { "mrf24j40", MRF24J40 }, > + { "mrf24j40ma", MRF24J40MA }, > + { "mrf24j40mc", MRF24J40MC }, > { }, > }; > MODULE_DEVICE_TABLE(spi, mrf24j40_ids);
this patch looks ok for me, can you please add "ieee802154: mrf24j40:" at beginning of the first line of this commit msg? For v2, please add linux-w...@vger.kernel.org in cc. Alan is this also okay for you? - Alex ------------------------------------------------------------------------------ Infragistics Professional Build stunning WinForms apps today! Reboot your WinForms applications with our WinForms controls. Build a bridge from your legacy apps to the future. http://pubads.g.doubleclick.net/gampad/clk?id=153845071&iu=/4140/ostg.clktrk _______________________________________________ Linux-zigbee-devel mailing list Linux-zigbee-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/linux-zigbee-devel