안녕하세요.

 

현재 라즈베리파이 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 22250
518 홈페이지 어떻습니까? [8] 백창우 2006.06.05 9722
517 u-boot 소스 분석에서 궁금한 점이 있습니다. [6] 원민수 2006.06.28 15196
516 알아볼 내용. [6] 원민수 2006.11.12 9892
515 ppc에서 preempt 완벽 지원여부 아시는분? [1] 최종환 2007.02.22 16131
514 i386의 i 와 386은 각각 어떤 의미인가요? [4] 이경호 2007.03.07 13685
513 아키텍쳐 바이블 책 문의입니다. [2] 이경호 2007.03.18 11958
512 다음 커널분석 스터디에 참가하고 싶습니다. [1] 김기태 2007.07.04 8820
511 커널 스터디에 관해서;;. 질문드립니다. [5] 한상은 2007.07.11 8693
510 커널 스터디는 어떻게 참여해야하느건가요? [1] 김태진 2007.08.10 8806
509 s3c2440기반의 리눅스 커널 분석 중 MM관련 질문입니다. 유태경 2007.09.02 21523
508 스터디 참여에 관해서 질문이있습니다. [1] 최대진 2007.09.12 8530
507 모집 공고 보고 참석 메일 보냈는데요. [1] 문경원 2007.10.17 8273
506 Linux kernel source 분석 study에 대하여 질문이 있습니다. [1] 온정상 2007.10.19 8712
505 arm 보드 구매에 대한 조언 부탁 드립니다. [1] 김성준 2007.10.27 8581
504 질문..음.. [2] 박은병 2007.12.14 6453
503 VMM 세미나중 디바이스 가상화 관련 질문^^.. [3] 박은병 2008.01.04 7252
502 PS/2 mouse port control 백창우 2008.01.17 7196
501 디버거 원리.. [6] 박은병 2008.01.31 13441
500 혼자서 커널공부하는데 조언을 부탁드립니다. [2] 김현중 2008.02.09 7800
499 이 문서 가지고 계시는 분 리형중 2008.02.25 6099
XE Login