Alarm Clock - gon2gon2/pintos-kaist GitHub Wiki

๋ฌธ์ œ

  • ํ˜„์žฌ timer_sleep์€ ํ˜ธ์ถœ ์‹œ input์œผ๋กœ ์ค€ tick์„ ํ˜„์žฌ tick๊ณผ ๊ณ„์† ๋น„๊ตํ•˜์—ฌ while๋ฌธ์˜ ์กฐ๊ฑด์ด False๊ฐ€ ๋  ๋•Œ๊นŒ์ง€ ๋ฌดํ•œ์ • CPU๋ฅผ ์–‘๋ณดํ•œ๋‹ค. ์ด๋ ‡๊ฒŒ ๋˜๋ฉด CPU๋Š” ์˜๋ฏธ์—†๋Š” ์ปจํ…์ŠคํŠธ ์Šค์œ„์นญ์— ์‹œ๊ฐ„์„ ๋‚ญ๋น„ํ•˜๊ฒŒ ๋œ๋‹ค. ์ด๋Ÿฌํ•œ ๋ฐฉ์‹์„ ์Šคํ•€๋ฝ(busy wait)์ด๋ผ๊ณ  ํ•œ๋‹ค.

ํ•ด๊ฒฐ์ฑ…

  • ์Šค๋ ˆ๋“œ๋ฅผ blocked ์ƒํƒœ๋กœ ๋งŒ๋“ค์–ด CPU๊ฐ€ ํ•ด๋‹น ์Šค๋ ˆ๋“œ๋กœ ์ปจํ…์ŠคํŠธ ์Šค์œ„์นญ์„ ํ•˜์ง€ ์•Š๊ฒŒ ๋ง‰๋Š”๋‹ค. blockํ•˜๋ฉด์„œ sleep_list์— ํ•ด๋‹น ์Šค๋ ˆ๋“œ๋ฅผ ์ถ”๊ฐ€ํ•˜๊ณ , ์Šค๋ ˆ๋“œ๋ฅผ ๊นจ์›Œ์•ผ ํ•˜๋Š” ์ตœ์†Œ ์‹œ๊ฐ„์„ ๊ฐฑ์‹ ํ•œ๋‹ค. timer_interrupt๊ฐ€ ๋ฐœ์ƒํ–ˆ์„ ๋•Œ, ๋งŒ์•ฝ ์Šค๋ ˆ๋“œ๋ฅผ ๊นจ์›Œ์•ผ ํ•˜๋Š” ์ตœ์†Œ ์‹œ๊ฐ„์ด ์ง€๋‚ฌ๋‹ค๋ฉด thread_awakeํ•จ์ˆ˜๊ฐ€ sleep_list๋ฅผ ์ˆœํšŒํ•˜๋ฉฐ ๊นจ์›Œ์•ผ ํ•  ์Šค๋ ˆ๋“œ๋“ค์„ ๊นจ์›Œ์ค€๋‹ค.