# Library prosa.implementation.refinements.EDF.preemptive_sched

Require Export prosa.analysis.facts.preemption.task.preemptive.

Require Export prosa.analysis.facts.preemption.rtc_threshold.preemptive.

Require Export prosa.analysis.facts.readiness.basic.

Require Export prosa.analysis.definitions.tardiness.

Require Export prosa.implementation.facts.ideal_uni.prio_aware.

Require Export prosa.implementation.definitions.task.

Require Export prosa.model.priority.edf.

Require Export prosa.analysis.facts.preemption.rtc_threshold.preemptive.

Require Export prosa.analysis.facts.readiness.basic.

Require Export prosa.analysis.definitions.tardiness.

Require Export prosa.implementation.facts.ideal_uni.prio_aware.

Require Export prosa.implementation.definitions.task.

Require Export prosa.model.priority.edf.

## Fully-Preemptive Earliest-Deadline-First Schedules

In this file, we adopt the Prosa standard implementation of jobs and tasks.

Consider any arrival sequence with consistent arrivals, ...

Variable arr_seq : arrival_sequence Job.

Hypothesis H_arrival_times_are_consistent : consistent_arrival_times arr_seq.

Hypothesis H_arrival_times_are_consistent : consistent_arrival_times arr_seq.

... assume basic readiness, ...

Instance basic_ready_instance : JobReady Job (ideal.processor_state Job) :=

basic.basic_ready_instance.

basic.basic_ready_instance.

... and consider any fully-preemptive, earliest-deadline-first schedule.

#[local] Existing Instance fully_preemptive_job_model.

#[local] Existing Instance EDF.

Definition sched := uni_schedule arr_seq.

#[local] Existing Instance EDF.

Definition sched := uni_schedule arr_seq.

First, we remark that such a schedule is valid.

Finally, we show that the fixed-priority policy is respected at each preemption point.