#include "options.h"
#include "log.h"
+#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
}
if (cpid == 0) {
- close(pipefd[1]);
- return autosample_process(opt, pipefd[0]);
+ close(pipefd[0]);
+ return autosample_process(opt, pipefd[1]);
}
- close(pipefd[0]);
- return pipefd[1];
+ close(pipefd[1]);
+ return pipefd[0];
}
int autosample_process(options_t *opt, int pipefd)
{
log_printf(NOTICE, "autosample process just started");
- sleep(5);
+ int device_num = key_value_storage_length(&opt->autosampledevs_);
+ if(device_num <= 0) {
+ log_printf(WARNING, "autosample no devices to sample, exiting");
+ return 0;
+ }
+
+ autosample_device_t* devices = malloc(sizeof(autosample_device_t)*device_num);
+ if(!devices) {
+ log_printf(WARNING, "autosample memory error, exiting");
+ return -3;
+ }
+
+ int i = 0;
+ string_list_element_t* k = opt->autosampledevs_.keys_.first_;
+ string_list_element_t* v = opt->autosampledevs_.values_.first_;
+ while(k && v) {
+ devices[i].delay_ = atoi(v->string_);
+ devices[i].cnt_ = 0;
+ devices[i].device_name_ = k->string_;
+ k = k->next_;
+ v = v->next_;
+ }
+
+ int sig_fd = signal_init();
+ if(sig_fd < 0)
+ return -3;
+
+ fd_set readfds;
+ struct timeval timeout;
+ int return_value = 0;
+ while(!return_value) {
+ FD_SET(sig_fd, &readfds);
+ timeout.tv_sec = 0;
+ timeout.tv_usec = 1000000;
+ int ret = select(sig_fd+1, &readfds, NULL, NULL, &timeout);
+ if(ret == -1 && errno != EINTR) {
+ log_printf(ERROR, "autosample process select returned with error: %s", strerror(errno));
+ return_value = -3;
+ break;
+ }
+ if(ret == -1)
+ continue;
+ if(!ret) {
+ int i;
+ for(i = 0; i < device_num; i++) {
+ devices[i].cnt_++;
+ if(devices[i].cnt_ >= devices[i].delay_) {
+ log_printf(DEBUG, "autosample send sample command for '%s'", devices[i].device_name_);
+ // call send sample
+ devices[i].cnt_ = 0;
+ }
+ }
+ }
+
+ if(FD_ISSET(sig_fd, &readfds)) {
+ if(signal_handle()) {
+ return_value = -2;
+ break;
+ }
+ }
+ }
- return 0;
+ signal_stop();
+ free(devices);
+ return return_value;
}