Difference between revisions of "Exercise - Using Interrupts"

From Flowcode Help
Jump to navigationJump to search
Line 40: Line 40:
 
: Go back to the beginning and repeat the process.
 
: Go back to the beginning and repeat the process.
 
: Whenever switch 2 is pressed, immediately make both LEDs flash quickly ten times and then go back to the main program.
 
: Whenever switch 2 is pressed, immediately make both LEDs flash quickly ten times and then go back to the main program.
 +
 +
==The main program==
  
  
Line 46: Line 48:
 
* Make sure that the [[System Panel]] is visible. If necessary, click on [[View]] and then select 'System Panel' a check-box will appear next to the option when enabled.
 
* Make sure that the [[System Panel]] is visible. If necessary, click on [[View]] and then select 'System Panel' a check-box will appear next to the option when enabled.
  
==The main program==
 
 
* Drag and drop a [[Loop Icon Properties|Loop icon]] between the BEGIN and END icons.
 
* Drag and drop a [[Loop Icon Properties|Loop icon]] between the BEGIN and END icons.
  
 
* Inside the loop, drag and drop an [[Input Icon Properties|Input icon]] from the [[Tools and Views#1) Icons Toolbar|Icons toolbar]].
 
* Inside the loop, drag and drop an [[Input Icon Properties|Input icon]] from the [[Tools and Views#1) Icons Toolbar|Icons toolbar]].
 +
 
* Drag and drop a [[Decision Icon Properties|Decision icon]] after the 'Input' icon.
 
* Drag and drop a [[Decision Icon Properties|Decision icon]] after the 'Input' icon.
  
 
Next, add icons to control what happens when switch is not pressed, (and so the program follows the 'No' branch):
 
Next, add icons to control what happens when switch is not pressed, (and so the program follows the 'No' branch):
 +
 
* Drag and drop an [[Output Icon Properties|Output icon]] in the 'No' branch.
 
* Drag and drop an [[Output Icon Properties|Output icon]] in the 'No' branch.
: This icon is going to turn the LED on.
+
: This icon is going to turn the red LED on.
 
 
  
 
* Drag and drop a [[Delay Icon Properties|Delay icon]] after the 'Output' icon.
 
* Drag and drop a [[Delay Icon Properties|Delay icon]] after the 'Output' icon.
 
: This will keep the LED on for three seconds.
 
: This will keep the LED on for three seconds.
 +
 
* Follow it with another [[Output Icon Properties|Output icon]].
 
* Follow it with another [[Output Icon Properties|Output icon]].
 
: This icon is going to turn the LED off.
 
: This icon is going to turn the LED off.
 +
 
* Add a second [[Delay Icon Properties|Delay icon]] next.
 
* Add a second [[Delay Icon Properties|Delay icon]] next.
 
: This will keep the LED off for three seconds.
 
: This will keep the LED off for three seconds.
Line 67: Line 71:
  
 
Next, add icons to control what happens when switch is pressed, and so the program follows the 'Yes' branch:
 
Next, add icons to control what happens when switch is pressed, and so the program follows the 'Yes' branch:
 +
 
* Drag and drop an [[Output Icon Properties|Output icon]] in the 'Yes' branch.
 
* Drag and drop an [[Output Icon Properties|Output icon]] in the 'Yes' branch.
  
 
* Drag and drop a [[Delay Icon Properties|Delay icon]] after the 'Output' icon.
 
* Drag and drop a [[Delay Icon Properties|Delay icon]] after the 'Output' icon.
: This will keep the LED on for three seconds.
+
 
 
* Follow it with another [[Output Icon Properties|Output icon]].
 
* Follow it with another [[Output Icon Properties|Output icon]].
: This icon is going to turn the LED off.
+
 
 
* Add a second [[Delay Icon Properties|Delay icon]] next.
 
* Add a second [[Delay Icon Properties|Delay icon]] next.
: This will keep the LED off for three seconds.
 
 
The program then loops back and checks the state of the switch again.
 
  
 +
The program then loops back, as before, and checks the state of the switch again.
  
: Finally we need to turn the lamp off, after the ten second delay.
 
: To do this we will need another 'Output' icon.
 
:* Drag and drop a second 'Output' icon after the 'Delay' icon.
 
==Set up the switch==
 
  
 +
==Add switch 1 and the LEDs ==
  
 
[[File:Exercise_Creating_a_Flowchart_Icons_Layout.png|right]]
 
[[File:Exercise_Creating_a_Flowchart_Icons_Layout.png|right]]
 
 
:* This is the icon which will allow us to delay the circuit for a specified period of time.
 
:* The delay will last for 10 seconds, in this time the circuit will not be able to carry out any other function until the delay is complete.
 
 
 
 
  
  

Revision as of 14:39, 12 August 2013

<sidebar>Sidebar: What Is an Interrupt?</sidebar>


Interrupts are a way of grabbing the microcontroller's attention immediately. They are very widely used, both in microcontrollers and microprocessors. For example, the keyboard and mouse in your computer probably use interrupts to talk to the CPU.

They can also be used to save energy. In many battery-powered applications, the microcontroller is 'put to sleep' when inactive, and so requires little energy. An interrupt is used to 'awaken' the controller, and bring it back into operation, when needed.

This exercise shows how to use an interrupt to sense when a switch is closed, (an external interrupt.)

Polling vs interrupt

The microcontroller is often connected to a large number of peripheral input devices - switches, sensors, memory, timers etc. There are two broad ways in which one of these devices can be serviced by the microcontroller:

  • polling - each device is 'asked' in turn if it has data to transfer to the controller;
  • interrupts - allow the device to interrupt the task being carried out by the controller.

The first exercise aims to show the difference between polling and using interrupts. The second section looks .......

Exercise 1

This exercise sets up a system with LEDs controlled by two switches:

  • Switch 1 is polled by the program, at regular intervals.
  • Switch 2 initiates an interrupt.


The polled switch, switch 1, is checked at regular (and predictable) intervals - every six seconds in this example. Switch 2 is connected so that as soon as it operates, the processor stops what it is doing and jumps to the Interrupt Service Routine (ISR). In the process, the return address is stored, so that at the end of the ISR, the processor can return to where it left the main program. In Flowcode, the ISR takes the form of a macro, configured like any other.


The flowchart

The flowchart sequence will be:

Check if switch 1 is pressed.
If it isn't, make the red LED flash slowly.
If it is, make the yellow LED flash slowly.
Go back to the beginning and repeat the process.
Whenever switch 2 is pressed, immediately make both LEDs flash quickly ten times and then go back to the main program.

The main program

  • Make sure that the System Panel is visible. If necessary, click on View and then select 'System Panel' a check-box will appear next to the option when enabled.
  • Drag and drop a Loop icon between the BEGIN and END icons.

Next, add icons to control what happens when switch is not pressed, (and so the program follows the 'No' branch):

This icon is going to turn the red LED on.
  • Drag and drop a Delay icon after the 'Output' icon.
This will keep the LED on for three seconds.
This icon is going to turn the LED off.
This will keep the LED off for three seconds.

The program then loops back and checks the state of the switch again.

Next, add icons to control what happens when switch is pressed, and so the program follows the 'Yes' branch:

  • Drag and drop a Delay icon after the 'Output' icon.

The program then loops back, as before, and checks the state of the switch again.


Add switch 1 and the LEDs

Exercise Creating a Flowchart Icons Layout.png


Your flowchart should now be set up to resemble the image to the right.

Set up the lamp=

Next we concentrate on the 'Yes' branch of the 'Decision' icon.

Set up the switch

This icon will be used to make the program perform what is known as a conditional branch.
Exercise Creating a Flowchart Icons Layout.png
When programmed, the current icons will be able to continually check if the switch is being pressed or not.
In the next step we will be adding icons which will allow us to control what happens if the switch is pressed.
Once the switch is pressed it will perform an the action or process and continue to check if it is being pressed again.
If the switch is not pressed it will follow the 'No' branch and keep looping to continue to check if the switch has been pressed.




You should now save the flowchart as "Lamp1.fcf", and close Flowcode.