1 #include <frm_generic.h>
5 #include <fres_sa_scenario.h>
8 #include <frsh_distributed.h>
17 int admission_test(struct fres_sa_scenario *scenario, void *priv, bool *schedulable)
19 struct dummy_data *data = priv;
20 struct fres_sa_contract *c;
22 printf("Admission test:\n");
25 fres_sa_scenario_for_each_contract(scenario, c) {
26 fres_block_basic *basic;
28 fres_contract_id_to_string(id, &c->contract->id, sizeof(id));
29 basic = fres_contract_get_basic(c->contract);
31 printf(" processing: id=%s, period=%ld ms, budget=%ld ms\n",
33 fosa_rel_time_to_msec(basic->period),
34 fosa_rel_time_to_msec(basic->budget));
37 *schedulable = scenario->num_contracts <= 3;
38 printf("=> %s\n", schedulable?"schedulable":"not schedulable");
43 struct dummy_data dummy_data;
45 static const struct fres_res_manager frm = {
46 .res_type = FRSH_RT_NETWORK,
47 .res_id = FRSH_NETPF_FWP,
48 .admission_test = admission_test,
52 int main(int argc, char *argv[])
57 orb = forb_init(&argc, &argv, "frm_fwp");
58 if (!orb) error(1, errno, "forb_init");
60 ret = frm_register_and_run(orb, &frm);
63 error(1, errno, "frm_generic_run");