view 2014/January/memo/08th.txt @ 17:597d1487d3bc

add 08.txt
author Masataka Kohagura <e085726@ie.u-ryukyu.ac.jp>
date Thu, 23 Jan 2014 01:58:41 +0900
parents
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 加える。