view 14/January/memo/08th.txt @ 51:d8f499590d82

rename 201* to 1*
author Masataka Kohagura <e085726@ie.u-ryukyu.ac.jp>
date Sun, 16 Mar 2014 13:36:04 +0900
parents 2014/January/memo/08th.txt@597d1487d3bc
children
line wrap: on
line source

Cerium 読み読み
    kernel/ppe/CpuThreads.h
        CpuThreads::~CpuThreads() にて cpu_num + io_num 分を send_mail 、 pthread_join 、 delete args[i].scheduler している。
        pthread_join は 指定 Threads が合流するまで動作をブロックし、その後 pthread_create したものを解放する。
        cpu_thread_arg_t をここで削除している。

        CpuThreads::send_mail(int cpuid, int num, memaddr *data) CERIUM_GPU のときと条件が違う。今回は not CERIUM_GPU を見ていく。
        args[cpuid-id_offset].scheduler->mail_write_from_host(*data);
        args は cpu_thread_arg_t であり、その中に宣言されている scheduler は MainScheduler である。
        scheduler->mail_write_from_host() は fifoDmaManager->mail_write_from_host(data) を返す。
        fifoDmaManager は・・・わからん・・・

        CpuThreads::has_mail(int cpuid, int count, memaddr *ret) は args[cpuid-id_offset].scheduler->has_mail_from_host() が
        0 でないときに get_mail する。
        args[cpuid-id_offset].scheduler->has_mail_from_host() (FifoDmaManager::has_mail_from_host() )は
        mail_queue->count() を返す。

        MainScheduler.h は ManyCore/MainScheduler.h にある。

        CpuThreads::cpu_thread_run(void *args) は SpeTaskManagerImpl を呼び出して、 c_scheduler ( Scheduler 型) に
        cpuid 、 mincpu 、 maxcpu を格納する。それらを TaskManagerImpl::set_scheduler に 初期設定した c_scheduler を渡す。
        argt->wait->sem_v() で、準備完了したスレッドができるたんびに、セマフォに 1 加える。