Library to read and write Azoteq IQS6xx device registers via I2C.

Dependents:   IQS620_HelloWorld IQS622_HelloWorld IQS624_HelloWorld IQS621_HelloWorld ... more

Library: IQS62x

Library to read and write Azoteq IQS6xx device registers via I2C.

Supported Devices

Components / IQS620A
Ultra low power sensor for magnetic field, capacitive touch and inductive proximity. Empowers next-generation user interfaces.

Components / IQS621
Azoteq IQS621 ultra low power sensor for ambient light, magnetic field, capacitance and inductive proximity. Empowers next-generation user interfaces.

Components / IQS622
Azoteq IQS622 ultra low power sensor for ambient light, active (reflective) IR, magnetic field, capacitance and inductive proximity. Empowers next-generation user interfaces.

Components / IQS624
Ultra low power sensor for rotating magnetic field, capacitive touch, and inductive proximity. Empowers next-generation user interfaces.

Handy Table of ProxFusion Device Features


ALS = Ambient Light Sensor PIR = Passive Infrared

/media/uploads/AzqDev/mbed-azoteq-proxfusion-handy-table-of-product-features.jpg

IQS62x.cpp

Committer:
AzqDev
Date:
2017-02-04
Revision:
0:ce75ae1e8fc7
Child:
2:c16cb655d4a4

File content as of revision 0:ce75ae1e8fc7:

// A class library for Azoteq IQS62x devices
#include "IQS62x.h"

// constructor
IQS62xIO::IQS62xIO() : 
    i2c( IQS_I2C_DATA_PIN, IQS_I2C_CLOCK_PIN ), // first run the constructor for mbed class I2C
    IQSready( IQS_READY_PIN )                   // first run the constructor for mbed class DigitalIn
{    
    registers = I2CBuffer; // pointer to the receive buffer
    I2CErrorCount = 0; // reset I2C error count
    i2c.frequency( I2Cspeed ); // I2C clock frequency
}    

// write some configuration data to the IQS62x
void IQS62xIO::configure() {
    const static char system_register_setup_data [] = { 0xd0, 0x40 }; 
    int numberOfBytes = sizeof( system_register_setup_data );
    waitForReady();
    // clear the reset bit in register 0xd0
    if(0!=i2c.write(I2C_ADR,system_register_setup_data,numberOfBytes,false)) 
        I2CErrorCount++;
}

// read all registers from the IQS62x
void IQS62xIO::readAll() {
    waitForReady();
    const static char i2c_start_address [] = { 0x0 };
    int numberOfBytes = sizeof( i2c_start_address );
    // write 0 to the IQS62x address register
    if(0!=i2c.write(I2C_ADR,i2c_start_address,numberOfBytes,false)) 
        I2CErrorCount++;
    waitForReady();
    memset(I2CBuffer,0x55,I2CBufferSize); // "clear" i2c receive buffer
    numberOfBytes = NUMBER_OF_REGISTERS;
    // read register values into a buffer
    if(0!=i2c.read(I2C_ADR,I2CBuffer,numberOfBytes,false))
        I2CErrorCount++;
}

// wait for IQS62x to provide a ready signal (low) on IQS62x_ready pin
void IQS62xIO::waitForReady() {
    int timeout=0; 
    while (1) {
        if(IQSready==1) break;
        if (timeout++ > 1000000) goto fatal_error; 
    }
    timeout=0;
    while (1) {
        if(IQSready==0) break;
        if (timeout++ > 1000000) goto fatal_error;
    }
    return;
    fatal_error:
        error ("Fatal Error: IQS62x ready pin is not toggling");
}