안녕하세요.

 

현재 라즈베리파이 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 22562
518 arm a53 아키텍처는 cache size를 configuration 할 수 없나요? [1] mnth 2023.12.03 394
517 Nested Interrupt on ARM64 [7] 아띨라 2022.07.24 752
516 러스트 언어나 리눅스커널+러스트 어떻게 생각하세요? 해볼만 할까요? [2] 김기오 2022.11.28 1232
515 리눅스 스케줄링에서 SCHED_FIFO에 대해 문의드립니다. [1] Neo2013 2023.02.09 923
514 __no_granule_support에서의 wfe, wfi 중복 사용 [2] min 2022.10.03 229
513 TLBi operation 질문 [5] 컴퓨터 2022.09.18 466
512 ARM64 CPU Context Switch [2] 아띨라 2022.07.24 604
511 vmcore 파일 생성방법 질문 드립니다. [2] sppedpower 2013.08.28 5336
510 인터럽트 발생 관련해서 질문 드리고 싶습니다. [6] 코딩의노예 2020.07.07 1003
509 커널 빌드시 최적화 관련 질문 [5] 김개미 2019.12.17 1830
508 mmap후 파일 올리기 [3] 읏짜 2022.01.13 1004
507 [질문-해결됨] compaction 후 기존 PTE 매핑에 뜬금 스왑 엔트리가 나와요! [12] 이파란 2021.05.17 1973
506 16기 리눅스 커널 스터디 C조 18주차 질문입니다. [3] cien 2019.10.12 19031
505 iamroot선배님들의 조언 부탁드립니다 [2] 이파란 2021.04.15 815
504 오드로이드에 관해 akqk13012 2021.03.26 466
» critical section에 대한 커널 코드 검증 방법 문의 [7] file mnth 2021.01.09 1505
502 RCU 관련해서 질문 하나 드려봅니다. [2] 코딩의노예 2020.07.03 683
501 멀티스레드 시간측정 질문 file 뇨뇸 2020.05.03 553
500 리눅스 소스 분석 관련 질문 [4] AlanWalker 2020.04.22 765
499 16기 리눅스 커널 스터디 39주차 질문입니다. [6] rnsscman 2020.03.22 790
XE Login