guowenxue
2021-04-21 eeb821fa6846e84c9fe3e80d58f41b7a5a418e70
update hal.x
3 files modified
32 ■■■■■ changed files
iotd/hal/gpio.c 25 ●●●●● patch | view | raw | blame | history
iotd/hal/gpio.h 3 ●●●● patch | view | raw | blame | history
iotd/main.c 4 ●●● patch | view | raw | blame | history
iotd/hal/gpio.c
@@ -24,9 +24,7 @@
    int                 i;
    gpio_info_t        *gpioinfo;
    s_gpio = gpio;
    if( !gpio )
    {
@@ -40,7 +38,6 @@
        log_warn("WARNNING: No GPIO pins configured\n");
        return 0;
    }
    /*  gpiod open chip */
    s_chip = gpiod_chip_open_by_name(RPI_GPIONAME);
@@ -150,21 +147,30 @@
}
#if 0
/* Return value: 1(HIGH): Sombody detected  0(LOW): Nobody detected */
int infrared_detect(void)
{
    int                      i;
    int                      rv;
    struct gpiod_line_event  event;
    /* This function will block, must call it to setup */
    if( gpiod_line_event_wait(s_infrared_lines, NULL) < 0 )
    for(i=0; i<s_gpio->incnt; i++)
    {
        //log_err("infrared gpiod line wait event failure!\n");
        if( strstr(s_gpio->input[i].name, "infrared"))
        {
            log_dbg("Start detect '%s' on pin[#%d]\n", s_gpio->input[i].name, s_gpio->input[i].pin);
            /* This function will block, must call it to setup */
            rv = gpiod_line_event_wait(s_gpio->input[i].line, NULL) ;
            if( rv< 0 )
            {
                log_err("infrared gpiod line wait event failure!\n");
        return 0;
    }
            log_err("infrared gpiod line wait event rv=%d!\n", rv);
    /* This function will block, must read to clear the event  */
    if (gpiod_line_event_read(s_infrared_lines, &event) < 0)
            if (gpiod_line_event_read(s_gpio->input[i].line, &event) < 0)
    {
        log_err("gpiod line event read failure!\n");
        return 0;
@@ -175,5 +181,6 @@
    else
        return 0;
}
    }
}
#endif
iotd/hal/gpio.h
@@ -41,9 +41,8 @@
extern int gpio_init(gpio_t *gpio);
extern void gpio_term(void);
/* turn which light on/off */
void gpio_out(char *name, char *cmd);
extern void gpio_out(char *name, char *cmd);
/* Return value: 0(LOW): Nobody detected, !0: Which infrared detect incoming */
extern int infrared_detect(void);
iotd/main.c
@@ -194,14 +194,12 @@
            }
        }
#if 0
        log_nrml("start infrared monitor detect...\n");
        if( infrared_detect() ) 
        {
            log_nrml("Someone incoming detected by infrared\n");
            log_nrml("Lux[%.3f] < Treshold[%.3f], auto light on now..\n", lux, hal_ctx->lux_threshold);
        }
#endif
        sleep(1);
    }
}