mirror of
https://github.com/nodemcu/nodemcu-firmware.git
synced 2025-01-16 20:52:57 +08:00
4e8ef87d03
Module creation & registration now made a lot simpler. In essence, each module file is now self-contained and only needs a NODEMCU_MODULE(MYNAME, "myname", myname_map, luaopen_myname); line to both be automatically recognised by the Lua initialization as well as honor the LUA_USE_MODULES_MYNAME #define.
128 lines
4.4 KiB
C
128 lines
4.4 KiB
C
/*
|
|
* tsl2561.c
|
|
*
|
|
* Created on: Aug 21, 2015
|
|
* Author: Michael Lucas (Aeprox @github)
|
|
*/
|
|
#include "module.h"
|
|
#include "lauxlib.h"
|
|
#include "platform.h"
|
|
#include "../tsl2561/tsl2561.h"
|
|
|
|
static uint16_t ch0;
|
|
static uint16_t ch1;
|
|
|
|
/* Initialises the device on pins sdapin and sclpin
|
|
* Lua: status = tsl2561.init(sdapin, sclpin, address(optional), package(optional))
|
|
*/
|
|
static int ICACHE_FLASH_ATTR tsl2561_init(lua_State* L) {
|
|
uint32_t sda;
|
|
uint32_t scl;
|
|
// check parameters
|
|
if (!lua_isnumber(L, 1) || !lua_isnumber(L, 2)) {
|
|
return luaL_error(L, "wrong arg range");
|
|
}
|
|
|
|
sda = luaL_checkinteger(L, 1);
|
|
scl = luaL_checkinteger(L, 2);
|
|
|
|
if (scl == 0 || sda == 0) {
|
|
return luaL_error(L, "no i2c for D0");
|
|
}
|
|
// init I2C
|
|
uint8_t error = tsl2561Init(sda, scl);
|
|
|
|
// Parse optional parameters
|
|
if (lua_isnumber(L, 3)) {
|
|
uint8_t address = luaL_checkinteger(L, 3);
|
|
if (!((address == TSL2561_ADDRESS_GND) || (address == TSL2561_ADDRESS_FLOAT) || (address == TSL2561_ADDRESS_VDD))) {
|
|
return luaL_error(L, "Invalid argument: address");
|
|
}
|
|
else{
|
|
tsl2561SetAddress(address);
|
|
}
|
|
}
|
|
if (lua_isnumber(L, 4)) {
|
|
uint8_t package = luaL_checkinteger(L, 4);
|
|
if (!((package == TSL2561_PACKAGE_T_FN_CL) || (package == TSL2561_PACKAGE_CS))) {
|
|
return luaL_error(L, "Invalid argument: package");
|
|
}
|
|
else{
|
|
tsl2561SetPackage(package);
|
|
}
|
|
}
|
|
lua_pushnumber(L, error);
|
|
return 1;
|
|
}
|
|
/* Sets the integration time and gain settings of the device
|
|
* Lua: status = tsl2561.settiming(integration, gain)
|
|
*/
|
|
static int ICACHE_FLASH_ATTR tsl2561_lua_settiming(lua_State* L) {
|
|
// check variables
|
|
if (!lua_isnumber(L, 1) || !lua_isnumber(L, 2)) {
|
|
return luaL_error(L, "wrong arg range");
|
|
}
|
|
uint8_t integration = luaL_checkinteger(L, 1);
|
|
if (!((integration == TSL2561_INTEGRATIONTIME_13MS) || (integration == TSL2561_INTEGRATIONTIME_101MS) || (integration == TSL2561_INTEGRATIONTIME_402MS))) {
|
|
return luaL_error(L, "Invalid argument: integration");
|
|
}
|
|
uint8_t gain = luaL_checkinteger(L, 2);
|
|
if (!((gain == TSL2561_GAIN_16X) || (gain == TSL2561_GAIN_1X))) {
|
|
return luaL_error(L, "Invalid argument: gain");
|
|
}
|
|
|
|
lua_pushnumber(L, tsl2561SetTiming(integration, gain));
|
|
return 1;
|
|
}
|
|
/* Reads sensor values from device and return calculated lux
|
|
* Lua: lux, status = tsl2561.getlux()
|
|
*/
|
|
static int ICACHE_FLASH_ATTR tsl2561_lua_calclux(lua_State* L) {
|
|
uint8_t error = tsl2561GetLuminosity(&ch0, &ch1);
|
|
if (error) {
|
|
lua_pushnumber(L, 0);
|
|
lua_pushnumber(L, error);
|
|
} else {
|
|
lua_pushnumber(L, tsl2561CalculateLux(ch0, ch1));
|
|
lua_pushnumber(L, error);
|
|
}
|
|
return 2;
|
|
}
|
|
/* Reads sensor values from device and returns them
|
|
* Lua: ch0, ch1, status = tsl2561.getrawchannels()
|
|
*/
|
|
static int ICACHE_FLASH_ATTR tsl2561_lua_getchannels(lua_State* L) {
|
|
uint8_t error = tsl2561GetLuminosity(&ch0, &ch1);
|
|
lua_pushnumber(L, ch0);
|
|
lua_pushnumber(L, ch1);
|
|
lua_pushnumber(L, error);
|
|
|
|
return 3;
|
|
}
|
|
|
|
// Module function map
|
|
static const LUA_REG_TYPE tsl2561_map[] = {
|
|
{ LSTRKEY( "settiming" ), LFUNCVAL( tsl2561_lua_settiming)},
|
|
{ LSTRKEY( "getlux" ), LFUNCVAL( tsl2561_lua_calclux )},
|
|
{ LSTRKEY( "getrawchannels" ), LFUNCVAL( tsl2561_lua_getchannels )},
|
|
{ LSTRKEY( "init" ), LFUNCVAL( tsl2561_init )},
|
|
{ LSTRKEY( "TSL2561_OK" ), LNUMVAL( TSL2561_ERROR_OK )},
|
|
{ LSTRKEY( "TSL2561_ERROR_I2CINIT" ), LNUMVAL( TSL2561_ERROR_I2CINIT )},
|
|
{ LSTRKEY( "TSL2561_ERROR_I2CBUSY" ), LNUMVAL( TSL2561_ERROR_I2CBUSY )},
|
|
{ LSTRKEY( "TSL2561_ERROR_NOINIT" ), LNUMVAL( TSL2561_ERROR_NOINIT )},
|
|
{ LSTRKEY( "TSL2561_ERROR_LAST" ), LNUMVAL( TSL2561_ERROR_LAST )},
|
|
{ LSTRKEY( "INTEGRATIONTIME_13MS" ), LNUMVAL( TSL2561_INTEGRATIONTIME_13MS )},
|
|
{ LSTRKEY( "INTEGRATIONTIME_101MS" ), LNUMVAL( TSL2561_INTEGRATIONTIME_101MS )},
|
|
{ LSTRKEY( "INTEGRATIONTIME_402MS" ), LNUMVAL( TSL2561_INTEGRATIONTIME_402MS )},
|
|
{ LSTRKEY( "GAIN_1X" ), LNUMVAL( TSL2561_GAIN_1X )},
|
|
{ LSTRKEY( "GAIN_16X" ), LNUMVAL( TSL2561_GAIN_16X )},
|
|
{ LSTRKEY( "PACKAGE_CS" ), LNUMVAL( TSL2561_PACKAGE_CS )},
|
|
{ LSTRKEY( "PACKAGE_T_FN_CL" ), LNUMVAL( TSL2561_PACKAGE_T_FN_CL )},
|
|
{ LSTRKEY( "ADDRESS_GND" ), LNUMVAL( TSL2561_ADDRESS_GND )},
|
|
{ LSTRKEY( "ADDRESS_FLOAT" ), LNUMVAL( TSL2561_ADDRESS_FLOAT )},
|
|
{ LSTRKEY( "ADDRESS_VDD" ), LNUMVAL( TSL2561_ADDRESS_VDD )},
|
|
{ LNILKEY, LNILVAL}
|
|
};
|
|
|
|
NODEMCU_MODULE(TSL2561, "tsl2561", tsl2561_map, NULL);
|