안녕하세요? 15기 코딩의 노예입니다.

 

RCU lock에 관해서 여쭙고 싶은 것이, multi writer가 존재할 때 어떻게 동작하는 지 알고싶어서 글을 쓰게 되었습니다.

찾아봐도 multi reader와 single writer의 관계의 설명밖에 잘 나오지 않는 것 같아서 여쭤봅니다.

 

Reader가 lock해제를 안 했을 때, writer가 data를 write하게 되면 copy해놨다가 GP(Grace period) 이후에 Reclaim한다고 알고 있습니다.

 

그런데 GP 기간동안 writer가 둘, 셋 이상 write를 하게 되면 어떻게 동작하는 지 알고 싶습니다.

 

예를 들어,

1st writer의 write가 끝나서 original을 copy 후, GP구간에 돌입합니다. 이 때, 모든 Reader의 QS(Quiescent State)가 발동하기 전에 2nd writer가 write를 수행할 때, 1st writer의 copied data를 또 copy 하게 되는 건가요?

 

두번 째 예는,

1st write가 write를 시작하고, write가 끝나기 전에 2nd writer가 write를 시작하게 된다면, 두 writer가 모두 original data를 copy하였을 텐데, 이 경우 reclaim 구간에서 update가 어떻게 진행되는 지 궁금합니다.

 

 

일단은 보장해주는 매커니즘이 없어서 writer간의 동기화는 안 하는 것으로 이해하고 있습니다. 맞을까요?

 

 

감사합니다.

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22245
517 alloc과 free함수에 대해서 질문입니다. [1] 정재훈 2011.06.28 93641
516 안드로이드 system 폴더안의 파일을 인식못하는데.. [5] 김영일 2011.04.14 69689
515 x86에서 ZONE_DMA 영역의 사용 [1] 홍문화 2011.05.02 58271
514 커널에서 page alloc에 관해서 [1] 미다리로23 2017.02.05 34574
513 디바이스 드라이버 모듈에서 작성한 함수를 커널에서 사용하는 방법 [1] 개짖는소리 2017.02.06 27040
512 Linux kernel의 CFS(Completely Fair Scheduling) 스케줄러에서 time slice 구하는 방법? [10] 김재호 2010.04.30 25222
511 "만들면서 배우는 OS..." 4장 kernel.asm 중 idtr 설정 질문드립니다 쿨쿨 2013.06.18 24954
510 리눅스 스케줄러 관련 [9] 홍문화 2011.02.23 22947
509 NFS NAS SAN 이란 무엇인가? file 박은병 2010.04.13 21880
508 s3c2440기반의 리눅스 커널 분석 중 MM관련 질문입니다. 유태경 2007.09.02 21523
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 18825
504 tty, tty0, console, vc 는 각각 뭐하는 디바이스인지? [3] 이창만 2008.12.04 18552
503 ARM A8 이상의 프로세서를 공부할 때 스터디 방향 [4] 유강희 2011.06.15 18515
502 임베디드 OS 만들기 내용과 관련하여 문의드립니다. [5] 송인재 2010.03.25 18321
501 far call 이란 무엇인가요? [4] 박한범 2010.04.13 17840
500 파일시스템에 관한 질문(Htree [6] 사앙조 2017.05.22 17069
499 SMP관련 질문입니다. [2] 컴퓨터 2017.04.13 16583
XE Login