diff options
| author | Vegard Storheil Eriksen <zyp@jvnv.net> | 2012-04-22 23:20:26 +0200 | 
|---|---|---|
| committer | Vegard Storheil Eriksen <zyp@jvnv.net> | 2012-04-22 23:20:26 +0200 | 
| commit | 55d20ed5c237c6e3864af472cdb350dced7913a0 (patch) | |
| tree | 8720d441b3bf77143c1d53a1b2368a7d4f7be064 | |
| parent | 63a58dcd75b7fb553dc79539da7582c2f521dbbb (diff) | |
Added L3GD20 driver.
| -rw-r--r-- | drivers/l3gd20.h | 40 | 
1 files changed, 40 insertions, 0 deletions
| diff --git a/drivers/l3gd20.h b/drivers/l3gd20.h new file mode 100644 index 0000000..c7e8935 --- /dev/null +++ b/drivers/l3gd20.h @@ -0,0 +1,40 @@ +#ifndef L3GD20_H +#define L3GD20_H + +#include "pin.h" +#include "spi.h" + +class L3GD20 { +	private: +		Pin& cs; +		SPI_t& spi; +	 +	public: +		int16_t x, y, z; +		 +		L3GD20(Pin& cs_pin, SPI_t& spi_bus) : cs(cs_pin), spi(spi_bus) {} +		 +		void init() { +			spi.reg.CR1 = 0x37f; +			cs.off(); +			spi.reg.DR = 0x40 | 0x20; while(!(spi.reg.SR & 0x01)); (void)spi.reg.DR; +			spi.reg.DR = 0x0f; while(!(spi.reg.SR & 0x01)); (void)spi.reg.DR; +			cs.on(); +		} +		 +		void update() { +			spi.reg.CR1 = 0x37f; +			cs.off(); +			spi.reg.DR = 0xc0 | 0x28; while(!(spi.reg.SR & 0x01)); (void)spi.reg.DR; +			spi.reg.DR = 0; while(!(spi.reg.SR & 0x01)); x  = spi.reg.DR; +			spi.reg.DR = 0; while(!(spi.reg.SR & 0x01)); x |= spi.reg.DR << 8; +			spi.reg.DR = 0; while(!(spi.reg.SR & 0x01)); y  = spi.reg.DR; +			spi.reg.DR = 0; while(!(spi.reg.SR & 0x01)); y |= spi.reg.DR << 8; +			spi.reg.DR = 0; while(!(spi.reg.SR & 0x01)); z  = spi.reg.DR; +			spi.reg.DR = 0; while(!(spi.reg.SR & 0x01)); z |= spi.reg.DR << 8; +			cs.on(); +		} +}; + + +#endif | 
