astra-sim-alibabacloud/astra-sim/network_frontend/analytical/AnaSim.cc (37 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"AnaSim.h"
using namespace std;
queue<struct CallTask> AnaSim::call_list = {};
uint64_t AnaSim::tick = 0;
void AnaSim::Run() {
while (!call_list.empty())
{
CallTask calltask = call_list.front();
while (true) {
if (calltask.time != tick) {
tick++;
} else {
break;
}
}
call_list.pop();
// std::cout << "after pop call_list: " << call_list.size() << std::endl;
calltask.fun_ptr(calltask.fun_arg);
// sleep(calltask.delay);
}
}
void AnaSim::Schedule(
uint64_t delay,
void (*fun_ptr)(void* fun_arg),
void* fun_arg) {
uint64_t time = tick + delay;
CallTask calltask = CallTask(time,fun_ptr,fun_arg);
// std::cout << "before push all_list: " << call_list.size() << std::endl;
call_list.push(calltask);
// std::cout << "after push of call_list: " << call_list.size() << std::endl;
}
void AnaSim::Stop(){
return;
}
void AnaSim::Destroy(){
return;
}
double AnaSim::Now(){
return tick;
}