리눅스가 work queue를 다양하게 사용한다. 나는 초짜라 DECLARE_WORK와 INIT_WORK를 구분할 수 없었다. DECLARE_WORK가 work struct를 전역 변수로 선언한다. 여러 work로 같은 데이터에 접근할 수 있다. workqueue funtion() 파라미터로 work struct를 넣는데, 여기로 work를 전달하면 된다. 코드가 넝마조각이 되고 있다. #include <linux/module.h> #include <linux/kernel.h> #include <linux/init.h> #include <linux/irq.h> #include <linux/interrupt.h> #include <linux/gpio.h> //GPIO #include <linux/cdev.h> #include…… workqueue 실습 계속 읽기
[태그:] raspberry
character device를 tasklet으로 테스트
tasklet을 배우고 실습하다 보니, 캐릭터 디바이스를 활용한 예제를 찾았다. 하다보니 강제로 character device를 등록, 열고, 닫고, 읽고, 쓰는 방법을 배웠다. 대충 이해한 다음 아래 동작을 구성했다. read: 앞쪽부터 읽음.write: 데이터가 있다면 뒤로 채워 넣음.인터럽트: gpio를 시물레이션하여 앞에서 한 글자씩 지움.버퍼 용량은 char 256개 사용. 전에 사용한 파일을 수정했고, 모듈을 만들기 위한 makefile을 그대로 사용했다. #include…… character device를 tasklet으로 테스트 계속 읽기
linux driver, softIrq 실습
인터럽트 후반부를 처리하는 soft irq를 배웠다. 자 이제 사용해 보자. 불행히도 요즘은 일반화된 tasklet을 사용하고 low level인 soft irq를 사용하지 않는다고 한다. 그래도 아래 사이트에서 강제로?? 사용할 수 있는 방법을 찾았다. 실습하고 쓰지 말아야 한다. 드라이버를 로딩 후 언로딩하면 시스템이 죽어버린다. https://embetronicx.com/tutorials/linux/device-drivers/softirq-in-linux-kernel/ 요점은 kernel에서 export_symbol로 raise_softirq, open_softiq 등 3개 함수를 내보내 사용할 수 있게한다. interrrupt.h에…… linux driver, softIrq 실습 계속 읽기
6장 IRQ thread ftrace log
코드를 분석한 내용을 자기의 것으로 만들기 위한 과정으로 실습이 중요합니다.p432. 디버깅을 통해 배우는 리눅스 커널의 구조와 원리. 프로그램을 디버깅을 통해 배워야 된다 생각했는데, 저자역시 같은 생각이다. 따라서 왜 코드만 보고 이해할 수 없었는지 명확하다. 사람이 코드만 보고 어떻게 동작하는지 이해할 수 없다. <idle>-0 [000] d.h. 43045.401470: irq_handler_exit: irq=37 ret=handled <idle>-0 [000] d.h. 43045.417578: irq_handler_entry: irq=36…… 6장 IRQ thread ftrace log 계속 읽기
5장 인터럽트 실습2
msi가 xhci 드라이버를 잘못 만들었는지 인터럽트를 너무 많이 발생시킨다. 왼쪽부터 36: 인터럽트 번호, 40080: cpu0 발생 횟수, 0: cpu 1, 2, 3 발생횟수, mmc1, mmc0 인터럽트 이름 정도? 모든 인터럽트가 충분하게 많이 일어난다. pi@raspberrypi:~ $ cat /proc/interrupts CPU0 CPU1 CPU2 CPU3 … 36: 40080 0 0 0 GICv2 158 Level mmc1, mmc0 37: 11075 0…… 5장 인터럽트 실습2 계속 읽기