안녕하세요.

 

현재 라즈베리파이 3 ethernet 드라이버에 accelerator 관련 기능을 넣는 개인 프로젝트를 하고 있습니다. 아래 그림과 같은 아키텍처로 설계한 다음 돌아가는 건 확인했는데 문제는 softirq와 일반 task context 간의 데이터 동기화가 제대로 이루어지는지 검증을 해보고 싶습니다. 어떠한 방식으로 하면 좋을지 조언 부탁드립니다.

 

* workq는 워크큐를 의미합니다.

 

Untitled Diagram(2).jpg

 

(1) 에서는 rx hook에서 가져온 데이터를 per-cpu 변수에다가 담습니다. 이때는 softirq 처리 도중이므로 아무런 lock도 사용하지 않습니다. (irq가 disable이고 non-preemptiable kernel이라 가정했습니다)

(2)가 critical section인데 main workq에서 생성된 4개의 per-cpu 처리용 workq는 irq을 disable하고 per-cpu 데이터를 빠르게 복사한다음 각 per-cpu 변수를 0으로 초기화합니다. 그리곤 irq을 다시 enable 합니다.

(3)에서는 spinlock 이용해 sum이란 하나의 변수에 4개의 per-cpu 데이터를 합칩니다.

 

제가 알고 싶은 부분은 다음과 같습니다.

1. 임계영역에서 데이터 동기화가 제대로 이루어지는 검증할 수 있는 방법

2. 위와 같이 설계할 때 주의해야 될 부분 (예, irq, rcu lock 등등)

 

추가로 프로젝트 링크도 첨부드리니 혹시 시간되시면 보시고 문제가 될 부분이나 검증 방법에 대해 조언해주시면 감사드립니다!

 

프로젝트 : https://github.com/net-rw/smsc95xx-drv

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22231
517 alloc과 free함수에 대해서 질문입니다. [1] 정재훈 2011.06.28 93594
516 안드로이드 system 폴더안의 파일을 인식못하는데.. [5] 김영일 2011.04.14 69660
515 x86에서 ZONE_DMA 영역의 사용 [1] 홍문화 2011.05.02 58174
514 커널에서 page alloc에 관해서 [1] 미다리로23 2017.02.05 34549
513 디바이스 드라이버 모듈에서 작성한 함수를 커널에서 사용하는 방법 [1] 개짖는소리 2017.02.06 27019
512 Linux kernel의 CFS(Completely Fair Scheduling) 스케줄러에서 time slice 구하는 방법? [10] 김재호 2010.04.30 25210
511 "만들면서 배우는 OS..." 4장 kernel.asm 중 idtr 설정 질문드립니다 쿨쿨 2013.06.18 24937
510 리눅스 스케줄러 관련 [9] 홍문화 2011.02.23 22940
509 NFS NAS SAN 이란 무엇인가? file 박은병 2010.04.13 21878
508 s3c2440기반의 리눅스 커널 분석 중 MM관련 질문입니다. 유태경 2007.09.02 21522
507 /dev 폴더에 있는 node파일 중에서 어떤 것을 open해야 플래쉬를 사용할 수 있을까요? [1] 박종주 2012.02.17 19849
506 sparsemem에 대한 질문이 있습니다. [5] 안정모 2010.03.20 19717
505 16기 리눅스 커널 스터디 C조 18주차 질문입니다. [3] cien 2019.10.12 18804
504 tty, tty0, console, vc 는 각각 뭐하는 디바이스인지? [3] 이창만 2008.12.04 18547
503 ARM A8 이상의 프로세서를 공부할 때 스터디 방향 [4] 유강희 2011.06.15 18506
502 임베디드 OS 만들기 내용과 관련하여 문의드립니다. [5] 송인재 2010.03.25 18321
501 far call 이란 무엇인가요? [4] 박한범 2010.04.13 17840
500 파일시스템에 관한 질문(Htree [6] 사앙조 2017.05.22 17061
499 SMP관련 질문입니다. [2] 컴퓨터 2017.04.13 16583
XE Login