INT J COMPUT COMMUN, ISSN 1841-9836 7(5):990-999, December, 2012. A Fault-Tolerant Scheduling Algorithm using Hybrid Overloading Technology for Dynamic Grouping based Multiprocessor Systems X.-B. Yu, J.-S. Zhao, C.-W. Zheng, X.-H. Hu Yu Xing-biao 1.Institute of Software Chinese Academy of Sciences 4# South Fourth Street, Zhongguancun, Beijing, P.R. China 2.Graduate University of Chinese Academy of Sciences 80# Zhongguancun East Road, Haidian District, Beijing, P.R. China E-mail: eliteman5317@hotmail.com Zhao Jun-suo, Zheng Chang-wen, Hu Xiao-hui Institute of Software Chinese Academy of Sciences 4# South Fourth Street, Zhongguancun, Beijing, P.R. China Abstract: In order to extend the application area of fault-tolerant scheduling algorithm based on hybrid overloading for multiprocessor and increase the fault-tolerant num- ber of processors, we propose a new fault-tolerant scheduling algorithm, which is based on hybrid overloading and dynamic grouping for multiprocessor by combining logic grouping strategy for processors in primary backup overloading and backup backup overloading.This algorithm presents the formalization of the dynamic grouping for processors in fault-tolerant scheduling based on hybrid overloading and enlarges the task number included in overloading task link. In the process of fault-tolerant schedul- ing the processors are dynamically divided into some groups based on overloading task link, so as to keep good scheduling success ratio and enhance the fault-tolerant per- formance of processors. Both theoretical analysis and simulation experiment prove this algorithm’s effectiveness respectively. Keywords: dynamic grouping; fault-tolerant; overloading; primary backup; backup backup 1 Introduction Real-time embedded system has been applied in many fields such as military, aeronautics, astronautics and communication, and the relevant research also has made important progress. The result of task scheduling in real-time system lies on not only scheduling correctness but also time restriction. The multiprocessor platform of real-time system takes advantage of the technology of resource redundancy and time redundancy in order to meet the demand of schedul- ing correctness and system reliability, among them primary-backup overloading(PB) [1, 2] and backup-backup overloading(BB) [2–4]approach is most important one. Supposing that there is just a processor fault in same period, the scheduling time of different versions of different tasks is overloaded in scheduling period of same processor for PB overloading , and the scheduling time of backup-backup versions of different tasks is overloaded in scheduling period of same proces- sor for BB overloading. The fault-tolerant scheduling technology of hybrid overloading [2, 6–8] is the combination of PB overloading and BB overloading with better scheduling efficiency and fault-tolerant performance of processor, but still supposing there is only a processor fault in same period. Logic grouping strategy [1] for processor based on PB overloading and BB overloading dynamically divides processors into groups in the process of task scheduling so as to tolerate a processor fault in every group, which is more adaptable to apply practically. But this strategy yet supposes the task number of overloading task chain is not more than two tasks, therefore the assigning of grouping size and group number is not enough flexible to be suited for hybrid Copyright c⃝ 2006-2012 by CCC Publications A Fault-Tolerant Scheduling Algorithm using Hybrid Overloading Technology for Dynamic Grouping based Multiprocessor Systems 991 overloading. In order to simplify the application of overloading method in scheduling algorithm, some basic application principles of overloading technology were introduced. [2] In this paper Dynamic Grouping PB-BB Algorithm(DG_PB-BB Algorithm) combines the advantage of two overloading scheduling technology and logic grouping in the precondition of application principle for overloading technology, not only efficiently improving the efficiency of task scheduling but also enlarging tolerance area of the process. DG_PB-BB Algorithm has better application value than no grouping algorithm and logic grouping algorithm. 2 System Model System is composed of m same processor nodes based on real time multiprocessor platform with shared memory, centralized dispatcher and processor communication medium without com- munication cost. Processor responsible for scheduling is dispatcher and responsible for execution is executer, which runs in parallel with dispatcher. New real time task is received by dispatcher and centralized dispatched to form assignment queue to execute on each processor. Real time tasks to be scheduled are independent aperiodic and nonpreemptalbe scheduling with primary-backup copy technology. Each task ti has two versions, namely primary copy(pri) and backup copy(bki) with identical attributes and resource requirements. Task sets τ = {ti|i = 1, 2, · · · , n}, ti=(ai,ri ,ci,di), ai is the start time of task ti, ri is the ready time of task ti, ci is the maximal execution time of task ti, di is the deadline time of task ti. Processor sets ω = {pi |i = 1, 2, · · · , m}. pri→bki is task chain, if other tasks are overloading scheduled on task ti, then it is overloading task chain. The parameters of system model are defined as follows: Definition 1. st(ti) is the start scheduling time of task ti. ft(ti) is the finish scheduling time of task ti. ri≤st(pri)≤ft(pri)≤st(bki)≤ft(bki)≤di. Definition 2. proc(pri) is the processor on which the primary task is scheduled, proc(bki) is the processor on which the backup task is scheduled, proc(pri)̸=proc(bki). Definition 3. s(ti) is the time interval on which the primary or backup task is scheduled. s(pri)∩s(bki)=ϕ. Definition 4. ncascade is the cascade number of overloaded tasks within a processor group and a time slot. groupsize(gi) is the processor number of a processor group gi. ncascade=1 represents the scheduling assignment of no task overloading, ncascade= groupsize(gi) represents the task can not be overloading scheduled.1≤ncascade≤groupsize(gi). Definition 5. toverload is the part time of a task overloaded on other tasks. 0≤toverload≤ci. 3 A Fault-tolerant Scheduling Algorithm Using Hybrid Overload- ing Technology for Dynamic Grouping Based Multiprocessor Systems(DG_PB-BB) This paper states the strategy of dynamic grouping of fault-tolerant processor based on fault-tolerant scheduling technology of hybrid overloading and the finishing of task scheduling with the help of AP(Allocation Parameter) [5,6]algorithm. In DG_PB-BB Algorithm the system can tolerate more than two processor faults at same moment and the tasks of overloading chain can not again be limited as two numbers. 992 X.-B. Yu, J.-S. Zhao, C.-W. Zheng, X.-H. Hu 3.1 Validity checking 1. Backups can be overloaded on any task. Primaries can be overloaded only on backups. 2. If a primary pri is overloaded on a backup bkj, then st(pri)≥ft(prj). 3. A overloading task chain should not be looped. A overloading task chain is relating to some processors and the maximal primary number of a overloading task chain is groupsize(gi)-1 in the group gi. 4. No more than one processor is belong to different processor groups. Every processor group has at least two processors. 5. The size of every processor group is possibly unequal and dynamically changes in the process of task scheduling. 6. The backups and primaries of same task are scheduled on same processor group. Over- loading scheduling of task copy can only happen within same processor group. 7. If proc(pri)=proc(prj) within same processor group, then s(bki)∩s(bkj)=ϕ, stating the scheduling time of task bki and bkj can not be overloading. 3.2 Scheduling algorithm Next specifically describing DG_PB-BB algorithm. In DG_PB-BB algorithm processor grouping is concluded as four conditions, formalizably described as following: 1. If the copy of task ti, pri and bki are not overloaded on other tasks,then the processors occupied by two copies form a new processor group ge. ge=form_group(proc(pri),proc(bki)). 2. If pri is not overloaded on other tasks, but bki is, then the task chain in which task tk overloaded on bki is situated links with the task chain in which pri→bki is situated to extend as a new processor group ge. (proc(prk),proc(bkk))∈group(ge), expand_group(ge,proc(pri)). 3. If bki is not overloaded on other tasks, but pri is, then the task chain in which task tk overloaded on pri is situated links with the task chain in which pri→bki is situated to extend as a new processor group ge. (proc(prk),proc(bkk))∈group(ge), expand_group(ge,proc(bki)). 4. If both of pri and bki is overloaded on other tasks, then the task chain in which task tk overloaded on bki is situated links with the task chain in which task tj overloaded on pri is situated to extend as a new processor group ge. (proc(prj),proc(bkj))∈group(ge), (proc(prk),proc(bkk))∈group(gf ), ge=expand_group(ge,gf ). Fig.1 states four conditions of dynamic processor grouping. OTC is overloading task chain. OTC(A) represents task chain pr1→bk1 and the processors occupied by it form a new processor group, which is the first condition of dynamic processor grouping. Within OTC(B1), the task chain t4 is situated in links with pr3→bk3 task chain and the processors occupied by it form A Fault-Tolerant Scheduling Algorithm using Hybrid Overloading Technology for Dynamic Grouping based Multiprocessor Systems 993 Figure 1: dynamic processor grouping a new processor group, showing the second condition of dynamic processor grouping. Within OTC(B2), the task chain t4 is situated in links with task chain pr2→bk2 and the processors occupied by it form a new processor group, expressing the third condition of dynamic processor grouping. Within OTC(B1), task chain pr3→bk3 links with both task chain t2 and t4, and the processors occupied by it form a new processor group, which is the fourth condition of dynamic processor grouping. DG_PB-BB algorithm is based on AP scheduling strategy of hybrid overloading. New tasks form ready scheduling queue according to FCFS(First Come First Server) method. Bigger The distance of start scheduling time between primaries and backups, smaller the effect of backups to task receiving ratio, and it means start scheduling time of primaries is as early as possible, st(pri)→ri, finish scheduling time of backups is as late as possible, ft(bki)→di. In order to increase task receiving ratio, tasks contained in task sets of hybrid overloading should be as much as possible and scheduling time occupied by them should be as few as possible. In the process of task scheduling the strategy of dynamic processor grouping is adopted to enhance tolerant level of the processor. The principle of processor grouping is the processors occupied by every overloading task chain constitute one group, if new overloading task chain has no relationship with old overloading task chain, then it should add a new processor to schedule new overloading task chain again to form a new processor group. If e=groupsize(ge),then: AP[pri, pj, ft(pri)] = { di−ft(pri) di−ri 1 e ncascade = 1 di−ft(pri)i di−ri ncascade e toverload ci 1 < ncascade ≤ e AP[pri, pj] = max {AP[pri, pj, ft(pri)]} AP[bki, pj, st(bki)] = { st(bki)−ri di−ri 1 e ncascade = 1 st(bki)−ri di−ri ncascade e toverload ci 1 < ncascade ≤ e AP[bki, pj] = max {AP[bki, pj, st(bki)]} AP[pri,pj,ft(pri)] is evaluation factor of scheduling scheme that a new primary pri is assigned to schedule on processor j. similarly,AP[bki,pj,ft(bki)] is evaluation factor of scheduling scheme that a new backup bki is assigned to schedule on processor j. AP is bigger, showing that the scheme of scheduling assignment is more optimal and scheduling efficiency is better. DG_PB-BB Algorithm 1. The copy of first task, pri and bki are assigned respectively processor p1 and p2 to form a new group ge. ge is present processor group, G is assigned processor group. schedule(pri)→p1,schedule(bki)→p2,ge=form_group(p1,p2),validity(),G=ge. 2. (1) Within assigned processor group G, next task ti finishes scheduling with the adoption 994 X.-B. Yu, J.-S. Zhao, C.-W. Zheng, X.-H. Hu of scheduling technology of hybrid overloading and allocation parameter. for task ti, while validity()̸= failed AP(pri,pj1)=next[max(AP(pri,pj))]or AP(bki,pj2)=next[max(AP(bki,pj))], pj ∈ group(G),j = 1, 2, · · · , m,j1 ̸=j2, schedule(pri)→pj1,schedule(bki)→pj2,validity(). (2) If task ti can not be scheduled within assigned processor group, then it should be to add a new processor into assigned processor group G to schedule task ti again and judge whether new and old overloading task chain can be united according to four conditions. Otherwise to judge whether task chain pri→bki and task chain included in processor group G are separated each other, and whether processor group ge formed by task chain in which task ti is situated is really contained in group G. If it is true, then group ge should be decomposed, otherwise task ti is dealt with according four conditions. After processors are assigned completely, if new task can not be scheduled, then fault-tolerant scheduling algorithm of dynamic grouping is started again according to principle of processor grouping. if schedule(ti)=failed in G then {for new processor pk, G=pk∪G,go to (1) (constraint pk=pj1∨pk=pj2) if (combine(link(pri → bki),(group(G) → link))=failed) then condition 1,validity() else condition i,validity(),go to (1) until j1∨ j2=m} else {if ((combine(link(pri→bki),(group(G) → link))=failed) and form_group(pri,bki)∈group(G)) then decompose(form_group(pri, bki)) else condition i,validity(),go to (1) until j1∨j2=m} Next giving an example of DG_PB-BB algorithm to express the thinking of algorithm.T1=(2, 2,2,7.5),T2=(4,4,2,8),T3=(4.5,4.5,2,9),T4=(5,5,2,10),T5=(5,5,4,13), T6=(6,6,3.5,14.5),m=6. Fig.2 describes DG_PB- BB algorithm scheduling example of above queue. Figure 2: DG_PB-BB algorithm Firstly m=2, processor p1 and p2 form group g1.St(pr2)=4 ,m=3 ,proc(bk2)=p3, pr2 and bk1 can be PB overloading ,p3 is added into group g1.st(pr3)=4.5,if m=3, pr3 and bk3 can not be scheduled within group g1, then m=4, bk3 and bk2 are BB overloading, proc(pr3)=p4, p4 is added into group g1. st(pr4)=5,m=4, pr4 and bk4 can be scheduled within group g1,proc(pr4)=p1, A Fault-Tolerant Scheduling Algorithm using Hybrid Overloading Technology for Dynamic Grouping based Multiprocessor Systems 995 proc(bk4)=p2,and task chain pr4→bk4 is separated from old overloading task chain within group g1 and really included in group g1, so that task chain pr4→bk4 is combined into group g1. st(pr5)=5,m=4,pr5 and bk5 can not be scheduled within group g1, so it is to extend a new processor p5 and rescheduling pr5 and bk5 within processor scheduling sets composed of p5 and group g1, proc(pr5)=p5, proc(bk5)=p4.As a result, task chain pr5→bk5 is separated from old overloading task chain within group g1 and not really included in group g1, therefore it is to extend task chain pr5→bk5 as group g2. st(pr6)=6, task ti can not be scheduled neither in group g1 nor group g2, so that a new processor p6 is added into group g2 and task ti is rescheduled within extended group g2, proc(pr6)=p6, proc(bk6)=p4, bk5 and bk6 is BB overloaded on processor p4. All processors have been assigned completely so that DG_PB-BB algorithm is restarted from processor p1 while there are new tasks arriving into scheduling queue. 3.3 Algorithm analysis If task sets showed in Fig.2 are scheduled by AP scheduling algorithm of hybrid overload- ing without grouping(PB-BB_AP Algorithm),although it only needs four processors to finish scheduling, but can just tolerate a processor fault and is too strict to apply widely. DG_PB-BB algorithm needs to increase two processors to finish scheduling, but new processor group g2 in system makes fault-tolerant number of processor extend as two processors so as to strengthen the reliability of system. Time complexity of PB-BB_AP algorithm is O[N2 · m · (m − 1)], N is average task number of task sets on which a processor has ever scheduled, m is processor number of the system. If in DG_PB-BB algorithm average processor number of group ge is k, then time complexity of DG_PB-BB algorithm is O[N2 · k · (k − 1)].In regard to DG_PB-BB algorithm, comparing with PB-BB_AP algorithm, the algorithm cost decreases and the system reliability increases, but the guarantee ratio decreases, because PB-BB_AP algorithm is an ideal method. 3.4 Theory testification The theory testification follows the methodology used in [8] and is based on the following assumptions: • All tasks have unit worst execution time, for example: ci=1. • Backup slots are preallocated in the schedule. • FIFO scheduling strategy is used. • Task deadlines follow uniform distribution [Wmin,Wmax],called deadline window. If Pwin(w) is the probability that an arriving task has a relative deadline w, then Pwin (w) = 1/(Wmax − Wmin + 1), Wmin ≤ w ≤ Wmax. • Task arrivals follow uniform distribution[0,Amax], with mean Aav=Amax/2. If Par(k) is the probability of k tasks arriving at a given time, then Par (k) = 1/(Amax + 1), 0 ≤ k ≤ Amax. A simple pre-allocation policy for BB overloading is to reserve a slot for backups every n time slots on each processor. Backup slots on the three processors can be staggered. For a task ti, bki is scheduled immediately after pri with probability 0.5 and is scheduled two slots later than pri with probability 0.5. In PB overloading there are three different types of time(0,1 and 2), if (t-1)mod 3=i, any time t has a type of i. At any time t, the number of primaries that can be scheduled to start at that time is s0 if t is of type 0, s1 if t is of type 1, s2 if t is of type 2. 996 X.-B. Yu, J.-S. Zhao, C.-W. Zheng, X.-H. Hu Using FIFO scheduling is equal to maintaining a task queue, to which arriving tasks are appended. Given that the number of task that can be scheduled on each time unit is known, then the position of a task in the Q indicates its scheduled start time. In BB overloading two tasks can be scheduled on each time (one slot is reserved for backups). If at the beginning of time slot t, a task ti is the qth task in Q, then ti is scheduled to execute at time slot t+g BB q . g BB q is the time at which a task, whose position in the Q is q (q = 1, 2, · · · , 2Wmax), will be executed and is defined as g BB q = ⌊ q 2 ⌋ . In PB overloading s0,s1 and s2 tasks can be scheduled on a given time slot t depending on whether t is of type 0,1,or 2 respectively. The time g P B q is defined as g P B q =(i+j+l), i∑ c=1 s0 + j∑ c=1 s1 + l∑ c=1 s2 ≤ q − 1, |i − j| ≤ 1, |j − l| ≤ 1, |l − i| ≤ 1. where i ≥ j ≥ l if t is of type 0, j ≥ l ≥ i if t is of type 1, and l ≥ i ≥ j if t is of type 2. When a task ti arrives at time t, its schedulability depends on the length of Q and on the relative deadline wi of the task. In BB overloading, if ti is appended at position q of Q and wi ≥ g BB q , then the primary task pri is guaranteed to execute before t+wi, Moreover, if wi ≥ g BB q + 2, then bki is also guaranteed to execute before time t+wi. In PB overloading, if ti is appended at position q of Q and wi ≥ g P B q , then the primary task pri is guaranteed to execute before t+wi, Moreover, if wi ≥ g P B q +2, then bki is also guaranteed to execute before time t+wi. Let pq,k be the probability that one of the k tasks is rejected when the queue size is q, and its value is the probability that the relative deadline of the task is smaller than g∗b +δ,*=PB or BB, δ=1 or 2. g logic b is the time at which a task, whose position in the Q is b, will be executed in the PB-BB overloading scheduling strategy of logic grouping, b = q + k/2. Showing as t0-t12 in Fig.3, processor p1-p12 are divided into 4 groups and every group has 3 processors, adopting with scheduling strategy of BB overloading, processor p13-p24 are also divided into 4 group and every group has 3 processors, adopting with scheduling strategy of PB overloading. Above method is described as PB-BB overloading scheduling strategy of logic grouping. g logic b = q+k/2⌊ (i+j+l)(n−n/3)+ i∑ c=1 s0+ j∑ c=1 s1+ l∑ c=1 s2 ⌋, i∑ c=1 s0 + j∑ c=1 s1 + l∑ c=1 s2 ≤ q + k/2 − 1, |i − j| ≤ 1, |j − l| ≤ 1, |l − i| ≤ 1. g dynamic b is the time at which a task, whose position in the Q is b, will be executed in the PB-BB overloading scheduling strategy of dynamic grouping, b = q + k/2. Different with logic grouping, in dynamic grouping s0=3, s1=4 and s2=2. Describe as t12-t24 in Fig.3, processor p1- p12 is divided into 3 groups and every group has 4 processors, adopting with scheduling strategy of BB overloading, processor p13-p24 are also divided 3 groups and every group has 4 proces- sors, adopting with scheduling strategy of PB overloading, Above method is described as PB-BB overloading scheduling strategy of dynamic grouping. g dynamic b = q+k/2⌊ (i+j+l)(n−n/4)+ i∑ c=1 s0+ j∑ c=1 s1+ l∑ c=1 s2 ⌋, i∑ c=1 s0 + j∑ c=1 s1 + l∑ c=1 s2 ≤ q + k/ 2 − 1, |i − j| ≤ 1, |j − l| ≤ 1, |l − i| ≤ 1. Obviously, gdynamicb < g logic b , g dynamic b decreases more quickly than g logic b with increasing n, therefore DG_PB-BB algorithm is more efficient than LG_PB-BB algorithm with increasing n. A Fault-Tolerant Scheduling Algorithm using Hybrid Overloading Technology for Dynamic Grouping based Multiprocessor Systems 997 Figure 3: theroy testification of LG_PB-BB and DG_PB-BB 4 Simulation Experiment Supposing LG_PB-BB represents fault-tolerant scheduling algorithm of hybrid overloading based on the strategy of logic grouping. Simulation experiment mainly compares with change sit- uation of the guarantee ratio(GR) in variety of fault-tolerant number of processor in circumstance of different task load for DG_PB-BB, LG_PB-BB and PB-BB_AP algorithm respectively. The guarantee ratio=the number of tasks guaranteed/the number of tasks arrived. Simulation pa- rameters as following: • The inter-arrival time of tasks follows exponential distribution with mean θ. θ=8. • The inter-arrival time of faults follows exponential distribution with mean λ. λ=200. • The execution time of a task is chosen uniformly [2,8]. • The deadline of a task is chosen uniformly [ri + ci, ri + R ∗ ci], whereR ≥ 1. • Processor number m=10, task number n=50. • R(task laxity) represents flexibility time task ti can stay in ready queue in precondition of finishing scheduling before deadline. R=3. • L (task load) is the expected number of task arrivals per mean service time. L =C/θ, C is the mean execution time, θ is the inter-arrival average time of tasks ti. Bigger L is, more the average load of processor is and lower the guarantee ratio is. In Fig.4 (a),(b) and (c) respectively show the relationship of processor fault and guarantee ratio in DG_PB-BB,LG_PB-BB and PB-BB_AP algorithm for the system of L=0.25,L=0.5 and L=1. Experiment results prove GR decreases along with L and processor faults increase. When there is only one processor fault in DG_PB-BB,LG_PB-BB and PB-BB_AP algorithm, the differences of GR for the system of L=0.25,L=0.5 and L=1 are small. When processor fault increases to more than two faults, GR for three kinds of task load in PB-BB_AP algorithm are all low and failure possibility of task scheduling is high. When L=0.25 and L=0.5 in DG_PB-BB algorithm GR enhances significantly comparing with LG_PB-BB algorithm, and for the system of L=1 the difference of GR between two algorithm is small, stating in the system of not full load task DG_PB-BB algorithm can tolerate processor fault better than LG_PB-BB and PB- BB_AP algorithm. 998 X.-B. Yu, J.-S. Zhao, C.-W. Zheng, X.-H. Hu (a) L=0.25 (b) L=0.5 (c) L=1 Fig.4. comparison with dynamic grouping, logic grouping and no group algorithm 5 Conclusions This paper improves task number and grouping strategy included in overloading task chain and proposes DG_PB-BB algorithm based on PB-BB_AP algorithm according to logic grouping strategy of PB overloading and BB overloading. Simulation experiment shows DG_PB-BB algorithm not only has good guarantee ratio of task scheduling, but also improves fault-tolerant level of processor, with better application valuation. A Fault-Tolerant Scheduling Algorithm using Hybrid Overloading Technology for Dynamic Grouping based Multiprocessor Systems 999 Main creative achievements include 1)introducing the formalization of processor dynamic grouping in fault-tolerant scheduling technology of hybrid overloading, 2)proposing the method of processor dynamic grouping based on overloading task chain,and 3)extending task number included in overloading task chain and increasing fault-tolerant level of processor by the adoption of processor dynamic grouping. Bibliography [1] R.Al-Omari,Arun K.Somani,G.Manimarna,Efficient overloading techniques for primary- backup scheduling in real-time systems, J.Parallel and Distributed Computing,64:629- 648,2004. [2] Wei Sun,Naixue Xiong,Laurence T.Yang,Chunming Rong, Towards free task overloading in passive replication based real-time multiprocessors, 10th IEEE International Conference on Computer and Information Technology, 1735-1742, 2010. [3] Bindu Mirle,Albert M.K.Cheng, Simulation fault-tolerant scheduling on real-time multipro- cessor systems using primary backup overloading, University of Houston, 1-10,2006. [4] R.Al-Omari,Arun K.Somani,G.Manimarna, An adaptive scheme for fault-tolerant schedul- ing of soft real-time tasks in multiprocessor systems, J.Parallel and Distributed Computing, 65:595-608, 2005. [5] W.Sun,Y.Zhang,C.Yu,X.Defago,Y.Inoguchi, Dynamic scheduling real-time task using primary-backup overloading strategy for multiprocessor systems, IEICE Transactions on In- formation and Systems, 796-806, 2008. [6] W.Sun,Y.Zhang,C.Yu,X.Defago,Y.Inoguchi,Real-time task scheduling using extended over- loading technique for multiprocessor system, 11th IEEE Symposium on Distributed Simula- tion and Real-time Applications, 95-102, 2007. [7] W.Sun,Y.Zhang,C.Yu,X.Defago,Y.Inoguchi,Hybrid overloading and stochastic analysis for re- dundant scheduling in real-time multiprocessor systems, 26th IEEE International Symposium on Reliable Distributed Systems, 265-274, 2007. [8] G. Manimaran, C. Siva Ram Murthy,A fault-tolerant dynamic scheduling algorithm for mul- tiprocessor real-time systems and its analysis, IEEE Trans. Parallel Distributed System , 9(11):1137-1152, 1998.