Skip to content

ejfisc/SST-LuminOx-O2-Driver

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 

Repository files navigation

SST Sensing LuminOx O2 Sensor Driver

Getting Started

Create an luminox_handler_t instance in main. Implement the *luminox_tx in main. Call luminox_init().

Communicating With The Sensor

The luminox sensor uses a 9600 baudrate UART interface. The *luminox_tx function should use UART. The functions for retrieving data from the sensor are defined in the luminox.h file.

Recommended *luminox_tx implementation (this is psuedocode, modify to fit your specific uart implementation):

    void uart_write(unsigned char * tx, uint8_t size) {
        complete_uart_rx = false;
        uart_tx(tx, size);
        while(!complete_uart_rx) {} // set this flag to true in uart event handler
    }

If you are not using an interrupt based UART and cannot set that flag to true, get rid of that while true loop in the uart_write() implementation and uncomment the luminox_wait_for_response() function calls in each of the functions in the source code that talk with the sensor. The micro must wait and process each response before sending another request to the sensor because it can otherwise spam the UART bus with requests and the sensor will not recognize the command and respond with error. This might be solved with hardware flow control but I never tested this.

Add the following code to your super loop in order to process data when the sensor is in streaming mode.

    // process luminox data
	if(complete_uart_rx) {
	    luminox_process_response(&luminox);
	    complete_uart_rx = false;
	}

Debug Output

A precompiler directive is used to turn debug output on and off. Currently all of the outputs are using NRF_LOG_INFO which is a Nordic nRF5 SDK specific function, change these to printf or whatever your micro environment uses.

About

Driver for SST Sensing LuminOx O2 Sensor

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages