4.【Orangepi Zero2】Linux定时器(signal、setitimer),软件PWM驱动舵机(SG90)

Linux定时器(signal、setitimer),软件PWM驱动舵机(SG90)

signal

详情请看Linux 3.进程间通信(shmget shmat shmdt shmctl 共享内存、signal signaction sigqueue 信号、semget semctl semop 信号量)

setitimer

setitimer 允许你设置定时器的初始值和重复间隔。一旦定时器启动,它将在到期时触发一个信号,通常是 SIGALRM 信号。你可以捕获这个信号并执行相应的操作。

#include <sys/time.h>

int setitimer(int which, const struct itimerval *new_value, struct itimerval *old_value);

参数说明

which:指定要设置的定时器类型,可以是 ITIMER_REALITIMER_VIRTUALITIMER_PROF 中的一个。
ITIMER_REAL:以实际时间计时,通常用于实现定时器功能。
ITIMER_VIRTUAL:以进程的虚拟时间(CPU时间)计时。
ITIMER_PROF:以进程的虚拟时间和系统时间(CPU和墙钟时间)计时。

new_value:一个 struct itimerval 结构,用于指定新的定时器值。
old_value:一个 struct itimerval 结构,用于存储旧的定时器值(可选参数)。

Timer values are defined by the following structures:

struct itimerval {
       struct timeval it_interval; /* Interval for periodic timer */
       struct timeval it_value;    /* Time until next expiration */
   };

   struct timeval {
       time_t      tv_sec;         /* seconds */
       suseconds_t tv_usec;        /* microseconds */
   };

示例

#include <stdio.h>
#include <sys/time.h>
#include <signal.h>
#include <unistd.h>

void signal_handler(int signum)
{
	printf("Hello!\n");
}

int main()
{
	struct itimerval timer;

	timer.it_interval.tv_sec = 1; /* Interval for periodic timer */
	timer.it_interval.tv_usec = 0;

	timer.it_value.tv_sec = 5; /* Time until next expiration */
	timer.it_value.tv_usec = 0;

	signal(SIGALRM, signal_handler);
	setitimer(ITIMER_REAL, &timer, NULL);

	while(1);

	return 0;
}

运行程序 5s 后开始输出 Hello! ,然后每隔 1s 输出 Hello!

在这里插入图片描述

软件PWM驱动舵机(SG90)

#include <stdio.h>
#include <sys/time.h>
#include <signal.h>
#include <unistd.h>
#include <wiringPi.h>

#define STEER 5

int angle = 0;
static int  cnt = 0;

void signal_handler(int signum)
{
	if(cnt <= angle)
	{
		digitalWrite(STEER, HIGH);
	}
	else
	{
		digitalWrite(STEER, LOW);
	}
	if(cnt == 40)
	{
		cnt = 0;
	}

	cnt++;
}

int main()
{
	delay(1);

	struct itimerval timer;

	timer.it_interval.tv_sec = 0; /* Interval for periodic timer */
	timer.it_interval.tv_usec = 500;

	timer.it_value.tv_sec = 1; /* Time until next expiration */
	timer.it_value.tv_usec = 0;
	
	signal(SIGALRM, signal_handler);
	setitimer(ITIMER_REAL, &timer, NULL);
	
	wiringPiSetup();
	pinMode(STEER, OUTPUT);

	while(1)
	{
		printf("please input 1-0 2-45 3-90 4-135 5-180\n");
		scanf("%d",&angle);
	}

	return 0;
}

  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
setitimer函数是Linux中实现高精度定时器的系统调用。它用于设置一个定时器,在指定的时间间隔内周期性地触发一个定时信号。函数原型如下: ```c int setitimer(int which, const struct itimerval *new_value, struct itimerval *old_value); ``` 其中,which参数指定了定时器的类型。常用的取值有: - ITIMER_REAL:使用系统的真实时间来计算定时器间隔,与系统的墙钟相关。 - ITIMER_VIRTUAL:使用进程的虚拟时间来计算定时器间隔,即进程在用户态运行的时间。 - ITIMER_PROF:使用进程在用户态和内核态运行的总时间来计算定时器间隔。 new_value参数是一个itimerval结构体指针,用于指定定时器的间隔和初始启动时间。该结构体定义如下: ```c struct itimerval { struct timeval it_interval; // 定时器的间隔 struct timeval it_value; // 定时器的初始启动时间 }; ``` 其中,timeval结构体定义如下: ```c struct timeval { time_t tv_sec; // 秒数 suseconds_t tv_usec; // 微秒数 }; ``` old_value参数是一个itimerval结构体指针,用于保存之前的定时器设置。 在使用setitimer函数之前,需要通过signal函数注册一个信号处理函数,用于处理定时器触发的信号。一般常用的信号是SIGALRM。 使用setitimer函数可以实现一些需要高精度定时的场景,比如周期性地刷新屏幕、定时采集传感器数据等。定时器的间隔可通过设置it_interval参数来调整,定时器的初始启动时间可通过设置it_value参数来设置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值