Merge pull request #478 from NodeUSB/dev096
Dev096 - 433MHz transmit code
This commit is contained in:
commit
9b7728160f
|
@ -32,6 +32,8 @@
|
|||
#define LUA_USE_MODULES_WS2812
|
||||
#define LUA_USE_MODULES_CJSON
|
||||
#define LUA_USE_MODULES_CRYPTO
|
||||
#define LUA_USE_MODULES_RC
|
||||
|
||||
#endif /* LUA_USE_MODULES */
|
||||
|
||||
#endif /* __USER_MODULES_H__ */
|
||||
|
|
|
@ -157,6 +157,14 @@
|
|||
#define ROM_MODULES_CRYPTO
|
||||
#endif
|
||||
|
||||
#if defined(LUA_USE_MODULES_RC)
|
||||
#define MODULES_RC "rc"
|
||||
#define ROM_MODULES_RC \
|
||||
_ROM(MODULES_RC, luaopen_rc, rc_map)
|
||||
#else
|
||||
#define ROM_MODULES_RC
|
||||
#endif
|
||||
|
||||
#define LUA_MODULES_ROM \
|
||||
ROM_MODULES_GPIO \
|
||||
ROM_MODULES_PWM \
|
||||
|
@ -176,7 +184,7 @@
|
|||
ROM_MODULES_BIT \
|
||||
ROM_MODULES_WS2812 \
|
||||
ROM_MODULES_CJSON \
|
||||
ROM_MODULES_CRYPTO
|
||||
ROM_MODULES_CRYPTO \
|
||||
ROM_MODULES_RC
|
||||
|
||||
#endif
|
||||
|
||||
|
|
|
@ -0,0 +1,96 @@
|
|||
#include "lualib.h"
|
||||
#include "lauxlib.h"
|
||||
#include "platform.h"
|
||||
#include "auxmods.h"
|
||||
#include "lrotable.h"
|
||||
//#include "driver/easygpio.h"
|
||||
//static Ping_Data pingA;
|
||||
#define defPulseLen 185
|
||||
#define defProtocol 1
|
||||
#define defRepeat 10
|
||||
#define defBits 24
|
||||
void transmit(int pin, int pulseLen, int nHighPulses, int nLowPulses) {
|
||||
platform_gpio_write(pin, 1);
|
||||
os_delay_us(pulseLen*nHighPulses);
|
||||
platform_gpio_write(pin, 0);
|
||||
os_delay_us(pulseLen*nLowPulses);
|
||||
}
|
||||
//rc.send(0,267715,24,185,1) --GPIO, code, bits, pulselen, protocol
|
||||
static int ICACHE_FLASH_ATTR rc_send(lua_State* L) {
|
||||
const uint8_t pin = luaL_checkinteger(L, 1);
|
||||
platform_gpio_mode(pin, PLATFORM_GPIO_OUTPUT, PLATFORM_GPIO_FLOAT);
|
||||
//platform_gpio_mode(pin, PLATFORM_GPIO_OUTPUT, PLATFORM_GPIO_PULLUP);
|
||||
//platform_gpio_mode(pin, PLATFORM_GPIO_OUTPUT, PLATFORM_GPIO_PULLDOWN);
|
||||
platform_gpio_write(pin, 0);
|
||||
long code = luaL_checklong(L, 2);
|
||||
//const uint8_t bits = luaL_checkinteger(L, 3);
|
||||
uint8_t bits = luaL_checkinteger(L, 3);
|
||||
const uint8_t pulseLen = luaL_checkinteger(L, 4);
|
||||
const uint8_t Protocol = luaL_checkinteger(L, 5);
|
||||
const uint8_t repeat = luaL_checkinteger(L, 6);
|
||||
NODE_ERR("pulseLen:%d\n",pulseLen);
|
||||
NODE_ERR("Protocol:%d\n",Protocol);
|
||||
NODE_ERR("repeat:%d\n",repeat);
|
||||
NODE_ERR("send:");
|
||||
int c,k,nRepeat;
|
||||
bits = bits-1;
|
||||
for (c = bits; c >= 0; c--)
|
||||
{
|
||||
k = code >> c;
|
||||
if (k & 1)
|
||||
NODE_ERR("1");
|
||||
else
|
||||
NODE_ERR("0");
|
||||
}
|
||||
NODE_ERR("\n");
|
||||
for (nRepeat=0; nRepeat<repeat; nRepeat++) {
|
||||
for (c = bits; c >= 0; c--)
|
||||
{
|
||||
k = code >> c;
|
||||
if (k & 1){
|
||||
//send1
|
||||
if(Protocol==1){
|
||||
transmit(pin,pulseLen,3,1);
|
||||
}else if(Protocol==2){
|
||||
transmit(pin,pulseLen,2,1);
|
||||
}else if(Protocol==3){
|
||||
transmit(pin,pulseLen,9,6);
|
||||
}
|
||||
}
|
||||
else{
|
||||
//send0
|
||||
if(Protocol==1){
|
||||
transmit(pin,pulseLen,1,3);
|
||||
}else if(Protocol==2){
|
||||
transmit(pin,pulseLen,1,2);
|
||||
}else if(Protocol==3){
|
||||
transmit(pin,pulseLen,4,11);
|
||||
}
|
||||
}
|
||||
}
|
||||
//sendSync();
|
||||
if(Protocol==1){
|
||||
transmit(pin,pulseLen,1,31);
|
||||
}else if(Protocol==2){
|
||||
transmit(pin,pulseLen,1,10);
|
||||
}else if(Protocol==3){
|
||||
transmit(pin,pulseLen,1,71);
|
||||
}
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
#define MIN_OPT_LEVEL 2
|
||||
#include "lrodefs.h"
|
||||
const LUA_REG_TYPE rc_map[] =
|
||||
{
|
||||
{ LSTRKEY( "send" ), LFUNCVAL( rc_send )},
|
||||
{ LNILKEY, LNILVAL}
|
||||
};
|
||||
|
||||
//LUALIB_API int luaopen_ultra(lua_State *L) {
|
||||
LUALIB_API int luaopen_rc(lua_State *L) {
|
||||
// TODO: Make sure that the GPIO system is initialized
|
||||
LREGISTER(L, "rc", rc_map);
|
||||
return 1;
|
||||
}
|
Loading…
Reference in New Issue