annotate core/PulseIn.cpp @ 224:97faaf985164 mergingClockSync

Added callback for Midi channel messages
author Giulio Moro <giuliomoro@yahoo.it>
date Tue, 08 Mar 2016 15:49:42 +0000
parents 3c3d14654b7f
children e4392164b458
rev   line source
giuliomoro@193 1 /*
giuliomoro@193 2 * PulseIn.cpp
giuliomoro@193 3 *
giuliomoro@193 4 * Created on: 4 Feb 2016
giuliomoro@193 5 * Author: giulio
giuliomoro@193 6 */
giuliomoro@193 7
giuliomoro@193 8 #include "../include/PulseIn.h"
giuliomoro@193 9
giuliomoro@193 10 void PulseIn::init(BeagleRTContext* context, unsigned int digitalInput, int direction){
giuliomoro@193 11 _digitalInput = digitalInput;
giuliomoro@193 12 _pulseIsOn = false;
giuliomoro@193 13 _pulseOnState = direction == 1 ? 1 : 0;
giuliomoro@193 14 _array.resize(context->digitalFrames);
giuliomoro@193 15 _lastContext = (uint64_t)-1;
giuliomoro@193 16 pinModeFrame(context, 0, digitalInput, INPUT); //context is used to allocate the number of elements in the array
giuliomoro@193 17 }
giuliomoro@193 18
giuliomoro@193 19 void PulseIn::check(BeagleRTContext* context){
giuliomoro@193 20 if(_digitalInput == -1){ //must be init'ed before calling check();
giuliomoro@193 21 throw(1);
giuliomoro@193 22 }
giuliomoro@193 23 for(unsigned int n = 0; n < context->digitalFrames; n++){
giuliomoro@193 24 _array[n] = 0; //maybe a few of these will be overwritten below
giuliomoro@193 25 }
giuliomoro@193 26 for(unsigned int n = 0; n < context->digitalFrames; n++){
giuliomoro@193 27 if(_pulseIsOn == false){ // look for start edge
giuliomoro@193 28 if(digitalReadFrame(context, n, _digitalInput) == _pulseOnState){
giuliomoro@193 29 _pulseStart = context->audioSampleCount + n; // store location of start edge
giuliomoro@193 30 _pulseIsOn = true;
giuliomoro@193 31 }
giuliomoro@193 32 } else { // _pulseIsOn == true;
giuliomoro@193 33 if(digitalReadFrame(context, n, _digitalInput) == !_pulseOnState){ // look for stop edge
giuliomoro@193 34 _array[n] = context->audioSampleCount + n - _pulseStart; // compute and store pulse duration
giuliomoro@193 35 _pulseIsOn = false;
giuliomoro@193 36 }
giuliomoro@193 37 }
giuliomoro@193 38 }
giuliomoro@193 39 _lastContext = context->audioSampleCount;
giuliomoro@193 40 };
giuliomoro@193 41
giuliomoro@193 42 PulseIn::~PulseIn() {
giuliomoro@193 43 // TODO Auto-generated destructor stub
giuliomoro@193 44 }
giuliomoro@193 45