Mercurial > hg > beaglert
changeset 75:8bd351ca8b46
Fixed direction in setPinMode functions, updated and fixed basic_blink
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Fri, 17 Jul 2015 20:59:43 +0100 (2015-07-17) |
parents | 0598731d3bef |
children | ff0f776415e4 |
files | core/Utilities.cpp projects/basic_blink/render.cpp |
diffstat | 2 files changed, 9 insertions(+), 13 deletions(-) [+] |
line wrap: on
line diff
--- a/core/Utilities.cpp Fri Jul 17 20:23:38 2015 +0100 +++ b/core/Utilities.cpp Fri Jul 17 20:59:43 2015 +0100 @@ -68,7 +68,7 @@ // Sets the direction of a digital pin for the current frame and all subsequent frames void pinModeFrame(BeagleRTContext *context, int frame, int channel, int mode) { for(unsigned int f = frame; f < context->digitalFrames; f++) { - if(mode == OUTPUT) + if(mode == INPUT) context->digital[f] |= (1 << channel); else context->digital[f] &= ~(1 << channel); @@ -79,7 +79,7 @@ // // Sets the direction of a digital pin for the current frame only void pinModeFrameOnce(BeagleRTContext *context, int frame, int channel, int mode) { - if(mode == OUTPUT) + if(mode == INPUT) context->digital[frame] |= (1 << channel); else context->digital[frame] &= ~(1 << channel);
--- a/projects/basic_blink/render.cpp Fri Jul 17 20:23:38 2015 +0100 +++ b/projects/basic_blink/render.cpp Fri Jul 17 20:59:43 2015 +0100 @@ -1,9 +1,3 @@ - /* - * - * Andrew McPherson and Victor Zappi - * Queen Mary, University of London - */ - #include <BeagleRT.h> #include <Utilities.h> #include <cmath> @@ -28,9 +22,13 @@ // ADCs and DACs (if available). If only audio is available, numAnalogFrames // will be 0. +/* basic_blink +* Connect an LED in series with a 470ohm resistor between P8_07 and ground. +* The LED will blink every @interval seconds. +*/ + void render(BeagleRTContext *context, void *userData) { - //connect an LED in series with a 470ohm resistor between P8_07 and ground static int count=0; //counts elapsed samples float interval=0.5; //how often to toggle the LED (in seconds) static int status=GPIO_LOW; @@ -42,11 +40,9 @@ status=GPIO_HIGH; else status=GPIO_LOW; - pinModeFrame(context, 0, P8_07, OUTPUT); - digitalWriteFrame(context, n, P8_07, status); //write the status to the LED - // rt_printf("there %d\n", context->digital[n]); + pinModeFrame(context, n, P8_07, OUTPUT); + digitalWriteFrameOnce(context, n, P8_07, status); //write the status to the LED } - context->digital[n]=status*0x00010000; count++; } }