5-16 kernel/fork.c copy_process 3clone 플래그에 따라 자원을 새로 할당하거나 공유// clone 인 경우 부모것을 공유if (clone_flags & CLONE_FILES) { atomic_inc(&oldf->count); goto out;}// clone 이 아닌경우 복사해서 새로 생성newf = dup_fd(oldf, &error);if (!newf) goto out;5-17 kernel/fork.c copy_process 4pid 구조체 & 정수형 pid 할당// global pidstatic inline pid_t pid_nr(struct pid *pid){ pid_t nr = 0; if (pid) nr = pid->number..
5-5 kernel/pid.c alloc_pidmappid namespace 에서 pid 를 할당여기서는 pid 를 보관할 수 있는 페이지가 없다면 페이지만 할당 해줌// pid 가 존재할수 있는 모든 페이지, offset 이 0이라면 1을 뺌// 그러나 페이지의 개념은 아니고, 실패시 offset 과 pid 를 새로 변경해서 할당max_scan = DIV_ROUND_UP(pid_max, BITS_PER_PAGE) - !offset;5-6 kernel/pid.c alloc_pidmap 2현재 page 에서 pid 할당이 가능한지 확인만약 안된다면 다음 페이지에서 할당 시도 or 다음페이지가 없다면 reserved pid 로 시도// 내껄 마지막에 등록하는걸 실패하더라도, 다른 더 뒤에있던 pid 가 쓰여..
4.9.5 per-cpu 동적 할당4-180 mm/percpu.c pcpu_alloc_areachunk 의 free entry 를 순회정렬들의 이유로 빈 공간이 생기는데 이를 head 라고 함 (실제로 사용하는지는 아직 모름)entry 에서 사용하고 남은 공간을 tail 이라고 함struct pcpu_chunk { int map_used; /* # of map entries used before the sentry */ int *map; /* allocation map */ int first_free; /* no free below this */};// map 에는 entry 의 주소들이 담겨있음for (i = chunk->first_free, p = chunk->map + i; i map_used..
- Total
- Today
- Yesterday
- 클래스 맴버 변수 출력하기
- it's called a vrpit
- Golang
- 카카오
- SuffixArray
- 봄날에 스케치
- set value
- 우리는 vr핏이라고 부릅니다
- mysql
- 잘못된 빨간줄
- cockroach db
- 에러 위치 찾기
- hole-punching
- Quest2
- vr핏
- vrpit
- boost
- print shared_ptr class member variable
- Reciprocal n-body Collision Avoidance
- 면접
- 코어 남기기
- chrome-extension
- RVO
- Visual Studio
- ad skip
- C++
- Obstacle Avoidance
- shared_from_this
- 영상 픽셀화 하기
- red underline
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |