astra-sim-alibabacloud/astra-sim/network_frontend/phynet/PhySimAi.cc (46 lines of code) (raw):
/*
*Copyright (c) 2024, Alibaba Group;
*Licensed under the Apache License, Version 2.0 (the "License");
*you may not use this file except in compliance with the License.
*You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
*Unless required by applicable law or agreed to in writing, software
*distributed under the License is distributed on an "AS IS" BASIS,
*WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*See the License for the specific language governing permissions and
*limitations under the License.
*/
#include <unistd.h>
#include"PhySimAi.h"
#include"astra-sim/system/MockNcclLog.h"
using namespace std;
queue<struct CallTask> PhyNetSim::call_list = {};
int PhyNetSim::tick = 0;
void PhyNetSim::Run() {
while (!call_list.empty())
{
CallTask calltask = call_list.front();
while (true) {
if (calltask.time != tick) {
tick++;
} else {
break;
}
}
call_list.pop();
MockNcclLog* NcclLog = MockNcclLog::getInstance();
NcclLog->writeLog(
NcclLogLevel::DEBUG, "PhyNetSim::Run calltask begin tick %d",tick);
calltask.fun_ptr(calltask.fun_arg);
NcclLog->writeLog(
NcclLogLevel::DEBUG, "PhyNetSim::Run calltask end tick %d",tick);
}
}
void PhyNetSim::Schedule(
int delay,
void (*fun_ptr)(void* fun_arg),
void* fun_arg) {
int time = tick + delay;
CallTask calltask = CallTask(time,fun_ptr,fun_arg);
MockNcclLog* NcclLog = MockNcclLog::getInstance();
NcclLog->writeLog(
NcclLogLevel::DEBUG, "PhyNetSim::Schedule calltask ");
call_list.push(calltask);
}
void PhyNetSim::Stop(){
return;
}
void PhyNetSim::Destory(){
return;
}
double PhyNetSim::Now(){
return tick;
}