This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
runtime_library:os:start [2020/12/10 18:38] – [Interrupts] ursgraf | runtime_library:os:start [2021/12/27 15:27] (current) – [System Sanity Checks] ursgraf | ||
---|---|---|---|
Line 2: | Line 2: | ||
You can program the processor either using interrupts in a foreground/ | You can program the processor either using interrupts in a foreground/ | ||
When choosing an operating system you can select a simple, robust and very efficient non-preemtive tasking system (class '' | When choosing an operating system you can select a simple, robust and very efficient non-preemtive tasking system (class '' | ||
- | The minimum task period is limited to one millisecond. For fast control applications you can use the decrementer on the PowerPC architecture as a fast running timer and produce exceptions at a very high frequency. | + | The minimum task period is limited to one millisecond. For fast control applications you can use the decrementer on the PowerPC architecture |
The basic modules are all written in Java. All the necessary hardware resources can be accessed through special built-in methods. | The basic modules are all written in Java. All the necessary hardware resources can be accessed through special built-in methods. | ||
Line 14: | Line 14: | ||
<code java> | <code java> | ||
- | public class TestTask extends Task{ | + | public class TestTask extends Task { |
- | public void action () { | + | |
- | // put task code here | + | // put task code here |
- | } | + | } |
- | static { | + | |
- | Task task1 = new TestTask(); | + | Task task1 = new TestTask(); |
- | task1.period = 500; // call twice per second | + | task1.period = 500; // call twice per second |
- | Task.install(task1); | + | Task.install(task1); |
- | } | + | } |
} | } | ||
</ | </ | ||
===== Interrupts ===== | ===== Interrupts ===== | ||
- | A processor might have some sort of a hardware priorization scheme when dealing with interrupts. Some of the potential internal and external interrupt sources use vectoring or get vectored to the same memory location and are dealt with by a software scheduler. You have to assign a priority level to each of the interrupts. A low level means a high priority. In order to achieve highest efficiency, interrupt nesting is switched off. That makes it necessary to write small interrupt service routines. | + | A processor might have some sort of a hardware priorization scheme when dealing with interrupts. Some of the potential internal and external interrupt sources use vectoring or get vectored to the same memory location and are dealt with by a software scheduler. You have to assign a priority level to each of the interrupts. A low level means a high priority. In order to achieve highest efficiency, interrupt nesting is switched off. That makes it necessary to write small interrupt service routines. |
+ | |||
+ | ==== Interrupts in the ARM Architecture ==== | ||
+ | === Zynq7000 Interrupts === | ||
+ | A Zynq7000 processor has private peripheral and shared peripheral interrupts and assigns each peripheral a interrupt number, see the [[https:// | ||
+ | |||
+ | <code java> | ||
+ | public class IntTest extends IrqInterrupt{ | ||
+ | |||
+ | public void action() { | ||
+ | // put your code here | ||
+ | US.PUT4(IsrReg, | ||
+ | } | ||
+ | |||
+ | static { | ||
+ | IntTest int = new IntTest(); | ||
+ | IrqInterrupt.install(int, | ||
+ | } | ||
+ | } | ||
+ | </ | ||
==== Interrupts in the PowerPC Architecture ==== | ==== Interrupts in the PowerPC Architecture ==== | ||
Line 38: | Line 57: | ||
public class IntTest extends Interrupt { | public class IntTest extends Interrupt { | ||
- | public void action() { | + | |
- | // put your code here | + | // put your code here |
- | } | + | } |
- | static { | + | |
- | IntTest int = new IntTest(); | + | IntTest int = new IntTest(); |
- | int.enableRegAdr = registername; | + | int.enableRegAdr = registername; |
- | int.flagRegAdr = registername; | + | int.flagRegAdr = registername; |
- | Interrupt.install(int, | + | Interrupt.install(int, |
- | } | + | } |
} | } | ||
</ | </ | ||
Line 57: | Line 76: | ||
public class ExtIntTest extends Interrupt { | public class ExtIntTest extends Interrupt { | ||
- | public void action() { | + | |
- | // put your code here | + | // put your code here |
- | } | + | } |
- | static { | + | |
- | ExtIntTest int5 = new ExtIntTest(); | + | ExtIntTest int5 = new ExtIntTest(); |
- | Interrupt.install(int5, | + | Interrupt.install(int5, |
- | } | + | } |
} | } | ||
</ | </ | ||
Line 75: | Line 94: | ||
<code java> | <code java> | ||
void MyExampleMethod () { | void MyExampleMethod () { | ||
- | ... | + | |
- | US.PUTSPR(EID, | + | US.PUTSPR(EID, |
- | ... // critical section | + | ... // critical section |
- | US.PUTSPR(EIE, | + | US.PUTSPR(EIE, |
- | ... | + | ... |
} | } | ||
</ | </ | ||
Line 88: | Line 107: | ||
<code java> | <code java> | ||
public class DecrementerTest extends Decrementer { | public class DecrementerTest extends Decrementer { | ||
- | static int count; | + | |
- | public void action() { | + | |
- | // put your code here | + | // put your code here |
- | } | + | } |
- | static { | + | |
- | DecrementerTest d = new DecrementerTest(); | + | DecrementerTest d = new DecrementerTest(); |
- | d.decPeriodUs = 1000000; // period is 1 s | + | d.decPeriodUs = 1000000; // period is 1 s |
- | Decrementer.install(d); | + | Decrementer.install(d); |
- | } | + | } |
} | } | ||
</ | </ | ||
Line 108: | Line 127: | ||
=====System Sanity Checks ===== | =====System Sanity Checks ===== | ||
- | | + | |
- | | + | |