Tool/software: TI C/C++ Compiler
HI, I am working with TM4C123GXl Launch pad for calculating Motor speed (RPM). Using Timer0 for calculating milliseconds , i am reset the millis count(variable) every 60000 counts once. After some time program gets hanging. I would like to calculate RPM can any one guide the by the proper steps. I have include my code below.
//*****************************************************************************
//
// timers.c - Timers example.
//
// Copyright (c) 2012-2017 Texas Instruments Incorporated. All rights reserved.
// Software License Agreement
//
// Texas Instruments (TI) is supplying this software for use solely and
// exclusively on TI's microcontroller products. The software is owned by
// TI and/or its suppliers, and is protected under applicable copyright
// laws. You may not combine this software with "viral" open-source
// software in order to form a larger program.
//
// THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
// NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
// NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
// CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
// DAMAGES, FOR ANY REASON WHATSOEVER.
//
// This is part of revision 2.1.4.178 of the EK-TM4C123GXL Firmware Package.
//
//*****************************************************************************
#include <stdint.h>
#include <stdbool.h>
#include "inc/hw_ints.h"
#include "inc/hw_memmap.h"
#include "inc/hw_types.h"
#include "driverlib/debug.h"
#include "driverlib/fpu.h"
#include "driverlib/gpio.h"
#include "driverlib/interrupt.h"
#include "driverlib/pin_map.h"
#include "driverlib/rom.h"
#include "driverlib/sysctl.h"
#include "driverlib/timer.h"
#include "driverlib/uart.h"
#include "utils/uartstdio.h"
//*****************************************************************************
//
//! \addtogroup example_list
//! <h1>Timer (timers)</h1>
//!
//! This example application demonstrates the use of the timers to generate
//! periodic interrupts. One timer is set up to interrupt once per second and
//! the other to interrupt twice per second; each interrupt handler will toggle
//! its own indicator on the display.
//!
//! UART0, connected to the Virtual Serial Port and running at 115,200, 8-N-1,
//! is used to display messages from this application.
//
//*****************************************************************************
//*****************************************************************************
//
// Flags that contain the current value of the interrupt indicator as displayed
// on the UART.
//
//*****************************************************************************
uint32_t g_ui32Flags;
volatile uint32_t millis,lastmillis=0,ms_millis=0;
int32_t Time_set;
//*****************************************************************************
//
// The error routine that is called if the driver library encounters an error.
//
//*****************************************************************************
#define Sensor_PERIPA SYSCTL_PERIPH_GPIOA
#define SensorBase GPIO_PORTA_BASE
#define Sensor GPIO_PIN_5
#define SensorInt GPIO_INT_PIN_5
#define Sensor_PERIPA1 SYSCTL_PERIPH_GPIOA
#define SensorBase1 GPIO_PORTA_BASE
#define Sensor1 GPIO_PIN_6
#define SensorInt1 GPIO_INT_PIN_6
#ifdef DEBUG
void
__error__(char *pcFilename, uint32_t ui32Line)
{
}
#endif
//*****************************************************************************
//
// The interrupt handler for the first timer interrupt.
//
//*****************************************************************************
int32_t count = 0,t_millis=0;
int32_t rpm = 0,x,;
uint32_t count1=0;
int32_t Drum_dia=90;
void delay (unsigned int x) {
while(x--);
}
void PortAIntHandler() {
GPIOIntStatus(SensorBase,true);
GPIOIntClear(GPIO_PORTA_BASE,GPIO_PIN_5);
if( GPIOPinRead(GPIO_PORTA_BASE,GPIO_PIN_5)==32) {
count1+=1;
}
GPIOIntEnable(GPIO_PORTA_BASE,GPIO_PIN_5);
}
void RPM_Cal( ) {
x=ms_millis - lastmillis;
if(count1>4)
if(x==30)
{
count1=(count1/3);
rpm = (int32_t) (count1/2) * 60; // calculating RPM ... Per rotation sensor counts 2 pulse.
// UARTprintf("\nrpm: %d ",rpm);
// UARTprintf("\n millis: %d \t lasmillis=%d ",millis,lastmillis);
// UARTprintf("\t mpm: %d ",mpm);
lastmillis = ms_millis;
count1 = 0;x=0;
}
}
void Timer0IntHandler(void)
{
char cOne;
//
// Clear the timer interrupt.
//
ROM_TimerIntClear(TIMER0_BASE, TIMER_TIMA_TIMEOUT);
//
// Toggle the flag for the first timer.
//
HWREGBITW(&g_ui32Flags, 0) ^= 1;
//
// Use the flags to Toggle the LED for this timer
//
// GPIOPinWrite(GPIO_PORTF_BASE, GPIO_PIN_1, g_ui32Flags << 1);
ROM_IntMasterDisable();
cOne = HWREGBITW(&g_ui32Flags, 0) ? '1' : '0';
millis += 1; // converting 1ms into 100 ms
if(millis == 100 || millis == t_millis) {
t_millis=millis+100;
ms_millis += 1; // Every 100ms once i will get this value ms_mills =1;
UARTprintf("\n millis:%d ",millis);
if(millis>60000) //setting for overflow by assumption keeping 5000000
{
ms_millis=0;
lastmillis=0;
millis=0;
t_millis=0;
}
}
ROM_IntMasterEnable();
}
//*****************************************************************************
//
// The interrupt handler for the second timer interrupt.
//
//*****************************************************************************
void
ConfigureUART(void)
{
//
// Enable the GPIO Peripheral used by the UART.
//
ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOA);
//
// Enable UART0
//
ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_UART0);
//
// Configure GPIO Pins for UART mode.
//
ROM_GPIOPinConfigure(GPIO_PA0_U0RX);
ROM_GPIOPinConfigure(GPIO_PA1_U0TX);
ROM_GPIOPinTypeUART(GPIO_PORTA_BASE, GPIO_PIN_0 | GPIO_PIN_1);
//
// Use the internal 16MHz oscillator as the UART clock source.
//
UARTClockSourceSet(UART0_BASE, UART_CLOCK_PIOSC);
//
// Initialize the UART for console I/O.
//
UARTStdioConfig(0, 115200, 16000000);
}
//*****************************************************************************
//
// This example application demonstrates the use of the timers to generate
// periodic interrupts.
//
//*****************************************************************************
void sensor_config(void)
{
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOA);
//
// Wait for the GPIOA module to be ready.
//
while(!SysCtlPeripheralReady(SYSCTL_PERIPH_GPIOA))
{
}
GPIOPinTypeGPIOInput(SensorBase, Sensor);
GPIOPadConfigSet(SensorBase ,Sensor,GPIO_STRENGTH_2MA,GPIO_PIN_TYPE_STD_WPU);
GPIOIntTypeSet(GPIO_PORTA_BASE,GPIO_PIN_5,GPIO_RISING_EDGE);
GPIOIntRegister(GPIO_PORTA_BASE,PortAIntHandler);
GPIOIntEnable(GPIO_PORTA_BASE, GPIO_INT_PIN_5);
}
int main(void)
{
Time_set=(16000000/1000); //set the value 1ms (1s=16000000, 1ms=16000000/1000) setting timer for 1ms delay
// Enable lazy stacking for interrupt handlers. This allows floating-point
// instructions to be used within interrupt handlers, but at the expense of
// extra stack usage.
//
ROM_FPULazyStackingEnable();
//akkaaa na call pannava?ok
// Set the clocking to run directly from the crystal.
//
ROM_SysCtlClockSet(SYSCTL_SYSDIV_1 | SYSCTL_USE_OSC | SYSCTL_OSC_MAIN |
SYSCTL_XTAL_16MHZ);
//
// Initialize the UART and write status.
//
ConfigureUART();
// UARTprintf("\033[2JTimers example\n");
//UARTprintf("T1: 0 T2: 0");
//
// Enable the GPIO port that is used for the on-board LED.
//
ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOF);
//
// Enable the GPIO pins for the LED (PF1 & PF2).
//
ROM_GPIOPinTypeGPIOOutput(GPIO_PORTF_BASE, GPIO_PIN_2 | GPIO_PIN_1);
//
// Enable the peripherals used by this example.
//
ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_TIMER0);
ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_TIMER1);
//
// Enable processor interrupts.
//
ROM_IntMasterEnable();
//
// Configure the two 32-bit periodic timers.
//
ROM_TimerConfigure(TIMER0_BASE, TIMER_CFG_PERIODIC);
ROM_TimerConfigure(TIMER1_BASE, TIMER_CFG_PERIODIC);
ROM_TimerLoadSet(TIMER0_BASE, TIMER_A, Time_set);
//ROM_TimerLoadSet(TIMER1_BASE, TIMER_A, ROM_SysCtlClockGet() / 2);
//
// Setup the interrupts for the timer timeouts.
//
ROM_IntEnable(INT_TIMER0A);
ROM_IntEnable(INT_TIMER1A);
ROM_TimerIntEnable(TIMER0_BASE, TIMER_TIMA_TIMEOUT);
ROM_TimerIntEnable(TIMER1_BASE, TIMER_TIMA_TIMEOUT);
//
// Enable the timers.
//
ROM_TimerEnable(TIMER0_BASE, TIMER_A);
ROM_TimerEnable(TIMER1_BASE, TIMER_A);
sensor_config();
while(1) {
RPM_Cal();
SysCtlDelay(50000);
}
return 0;
}