mirror of https://github.com/ARMmbed/mbed-os.git
Sync with Atmel RF driver v3.0.5
parent
fba0669194
commit
a215d9d856
|
|
@ -58,8 +58,8 @@ class RFBits;
|
|||
class NanostackRfPhyAtmel : public NanostackRfPhy {
|
||||
public:
|
||||
NanostackRfPhyAtmel(PinName spi_mosi, PinName spi_miso,
|
||||
PinName spi_sclk, PinName spi_cs, PinName spi_rst, PinName spi_slp, PinName spi_irq,
|
||||
PinName i2c_sda, PinName i2c_scl);
|
||||
PinName spi_sclk, PinName spi_cs, PinName spi_rst, PinName spi_slp, PinName spi_irq,
|
||||
PinName i2c_sda, PinName i2c_scl);
|
||||
virtual ~NanostackRfPhyAtmel();
|
||||
virtual int8_t rf_register();
|
||||
virtual void rf_unregister();
|
||||
|
|
|
|||
File diff suppressed because it is too large
Load Diff
|
|
@ -18,14 +18,14 @@
|
|||
#if DEVICE_I2C
|
||||
|
||||
/* Device addressing */
|
||||
#define AT24MAC_EEPROM_ADDRESS (0x0A<<4)
|
||||
#define AT24MAC_RW_PROTECT_ADDRESS (0x06<<4)
|
||||
#define AT24MAC_SERIAL_ADDRESS (0x0B<<4)
|
||||
#define AT24MAC_EEPROM_ADDRESS (0x0A<<4)
|
||||
#define AT24MAC_RW_PROTECT_ADDRESS (0x06<<4)
|
||||
#define AT24MAC_SERIAL_ADDRESS (0x0B<<4)
|
||||
|
||||
/* Known memory blocks */
|
||||
#define AT24MAC_SERIAL_OFFSET (0x80)
|
||||
#define AT24MAC_EUI64_OFFSET (0x98)
|
||||
#define AT24MAC_EUI48_OFFSET (0x9A)
|
||||
#define AT24MAC_SERIAL_OFFSET (0x80)
|
||||
#define AT24MAC_EUI64_OFFSET (0x98)
|
||||
#define AT24MAC_EUI48_OFFSET (0x9A)
|
||||
|
||||
#define SERIAL_LEN 16
|
||||
#define EUI64_LEN 8
|
||||
|
|
@ -33,7 +33,7 @@
|
|||
|
||||
using namespace mbed;
|
||||
|
||||
AT24Mac::AT24Mac(PinName sda, PinName scl) : _i2c(sda , scl)
|
||||
AT24Mac::AT24Mac(PinName sda, PinName scl) : _i2c(sda, scl)
|
||||
{
|
||||
// Do nothing
|
||||
}
|
||||
|
|
@ -41,25 +41,28 @@ AT24Mac::AT24Mac(PinName sda, PinName scl) : _i2c(sda , scl)
|
|||
int AT24Mac::read_serial(void *buf)
|
||||
{
|
||||
char offset = AT24MAC_SERIAL_OFFSET;
|
||||
if (_i2c.write(AT24MAC_SERIAL_ADDRESS, &offset, 1, true))
|
||||
return -1; //No ACK
|
||||
return _i2c.read(AT24MAC_SERIAL_ADDRESS, (char*)buf, SERIAL_LEN);
|
||||
if (_i2c.write(AT24MAC_SERIAL_ADDRESS, &offset, 1, true)) {
|
||||
return -1; //No ACK
|
||||
}
|
||||
return _i2c.read(AT24MAC_SERIAL_ADDRESS, (char *)buf, SERIAL_LEN);
|
||||
}
|
||||
|
||||
int AT24Mac::read_eui64(void *buf)
|
||||
{
|
||||
char offset = AT24MAC_EUI64_OFFSET;
|
||||
if (_i2c.write(AT24MAC_SERIAL_ADDRESS, &offset, 1, true))
|
||||
return -1; //No ACK
|
||||
return _i2c.read(AT24MAC_SERIAL_ADDRESS, (char*)buf, EUI64_LEN);
|
||||
if (_i2c.write(AT24MAC_SERIAL_ADDRESS, &offset, 1, true)) {
|
||||
return -1; //No ACK
|
||||
}
|
||||
return _i2c.read(AT24MAC_SERIAL_ADDRESS, (char *)buf, EUI64_LEN);
|
||||
}
|
||||
|
||||
int AT24Mac::read_eui48(void *buf)
|
||||
{
|
||||
char offset = AT24MAC_EUI48_OFFSET;
|
||||
if (_i2c.write(AT24MAC_SERIAL_ADDRESS, &offset, 1, true))
|
||||
return -1; //No ACK
|
||||
return _i2c.read(AT24MAC_SERIAL_ADDRESS, (char*)buf, EUI48_LEN);
|
||||
if (_i2c.write(AT24MAC_SERIAL_ADDRESS, &offset, 1, true)) {
|
||||
return -1; //No ACK
|
||||
}
|
||||
return _i2c.read(AT24MAC_SERIAL_ADDRESS, (char *)buf, EUI48_LEN);
|
||||
}
|
||||
|
||||
#endif /* DEVICE_I2C */
|
||||
|
|
|
|||
Loading…
Reference in New Issue