Mercurial > hg > Gears > GearsAgda
view src/parallel_execution/Todo @ 234:47588c28f189
TaskManager
author | mir3636 |
---|---|
date | Sun, 22 Jan 2017 20:17:11 +0900 |
parents | 578f283efb4a |
children | 18b43cdc8ee5 |
line wrap: on
line source
Sun Jan 22 20:11:28 JST 2017 TaskManagerから必要なCPUWorkerを生成する WorkerはcreateWorker時に新しくthreadを作る TaskManager->createTaskで新しいContextを生成する この時点でWorkerを番号で指定する このContextにGearefで値を設定していく 待ち合わせ用のDSを設定する taskManager->spawnでWorkerにcontextを送る Fri Jan 13 17:47:40 JST 2017 Task は contextを直接使うことにする DS には, まっているcontextをListを作る context に実行中断中のCS の番号をいれるフィールドを用意する 待っているDS のcount createTaskの手順 新しくcontextを作る allocate 用のheap も用意 もとのcontextを全部copyする or 必要なものだけcopyする 待ち合わせのDS群を指定する 終わったあとの行き先を指定する(default は task_exit) exception の行き先も必要な指定する 待っているDSが全部揃っていたら active Queueに入れる task の実行 taskの実行後、 goto meta する直前で code gear commit を呼んで, Reader list を消化する 複数から参照されるDSは一旦localに書き出して, その後atomic に書き出す 複数から参照されるDSは何かしら宣言が必要 つまり DS には 一つ一つ owner がいる Mon Nov 28 17:39:39 JST 2016 Task,TaskManager,Workerのインターフェースの実装を作成する Taskを一旦Treeに入れずに直接Queueに入れる Task CodeGen IDataSeg IDataSeg ... idsCount nextTask(can be C_exit) ODataSeg? TaskManager createWorker spawn (any,cpu,GPU) taskSend activeQueue shutdown deadlockDetectid SynchronizedQueue * Workerの数だけ Worker execute taskRecive shutdown