修改的程序....

/******************** (C) COPYRIGHT 2007 STMicroelectronics ********************

* File Name          : stm32f10x_encoder.c

* Author             : IMS Systems Lab

* Date First Issued  : 21/11/07

* Description        : This file contains the software implementation for the

*                      encoder unit

********************************************************************************

* History:

* 21/11/07 v1.0

********************************************************************************

* THE PRESENT SOFTWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS

* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.

* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,

* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE

* CONTENT OF SUCH SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING

* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.

*******************************************************************************/

/* Includes ------------------------------------------------------------------*/

#include "stm32f10x_encoder.h"

#include "stm32f10x.h"

/* Private typedef -----------------------------------------------------------*/

/* Private define ------------------------------------------------------------*/

#define ENCODER_TIMER   TIM3  // Encoder unit connected to TIM3

#define ENCODER_PPR           (u16)(400)   // number of pulses per revolution

#define SPEED_BUFFER_SIZE 8

#define COUNTER_RESET   (u16)0

#define ICx_FILTER      (u8) 6 // 6 670nsec

#define TIMx_PRE_EMPTION_PRIORITY 1

#define TIMx_SUB_PRIORITY 0

#define SPEED_SAMPLING_FREQ (u16)(2000/(SPEED_SAMPLING_TIME+1))

#define U16_MAX ((u16)65535u)

#define U32_MAX ((u32)4294967295uL)

/* Private functions ---------------------------------------------------------*/

s16 ENC_Calc_Rot_Speed(void);

/* Private variables ---------------------------------------------------------*/

//static s16 hPrevious_angle/*, hSpeed_Buffer[SPEED_BUFFER_SIZE],hRot_Speed*/;

//static u8 bSpeed_Buffer_Index = 0;

//static bool bIs_First_Measurement = TRUE;

static volatile u16 hEncoder_Timer_Overflow;

/*******************************************************************************

* Function Name  : ENC_Init

* Description    : General Purpose Timer x set-up for encoder speed/position

*                  sensors

* Input          : None

* Output         : None

* Return         : None

*******************************************************************************/

void ENC_Init(void)

{

TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;

TIM_ICInitTypeDef TIM_ICInitStructure;

/* Encoder unit connected to TIM3, 4X mode */

GPIO_InitTypeDef GPIO_InitStructure;

NVIC_InitTypeDef NVIC_InitStructure;

/* TIM3 clock source enable */

RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE);

/* Enable GPIOA, clock */

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);

GPIO_StructInit(&GPIO_InitStructure);

/* Configure PA.06,07 as encoder input */

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6 | GPIO_Pin_7;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;

GPIO_Init(GPIOA, &GPIO_InitStructure);

/* Enable the TIM3 Update Interrupt */

NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn;

NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = TIMx_PRE_EMPTION_PRIORITY;

NVIC_InitStructure.NVIC_IRQChannelSubPriority = TIMx_SUB_PRIORITY;

NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;

NVIC_Init(&NVIC_InitStructure);

/* Timer configuration in Encoder mode */

TIM_DeInit(ENCODER_TIMER);

TIM_TimeBaseStructInit(&TIM_TimeBaseStructure);

TIM_TimeBaseStructure.TIM_Prescaler = 0x0;  // No prescaling

TIM_TimeBaseStructure.TIM_Period = (4*ENCODER_PPR)-1;

TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;

TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;

TIM_TimeBaseInit(ENCODER_TIMER, &TIM_TimeBaseStructure);

TIM_EncoderInterfaceConfig(ENCODER_TIMER, TIM_EncoderMode_TI12,

TIM_ICPolarity_Rising, TIM_ICPolarity_Rising);

TIM_ICStructInit(&TIM_ICInitStructure);

TIM_ICInitStructure.TIM_ICFilter = ICx_FILTER;

TIM_ICInit(ENCODER_TIMER, &TIM_ICInitStructure);

// Clear all pending interrupts

TIM_ClearFlag(ENCODER_TIMER, TIM_FLAG_Update);

TIM_ITConfig(ENCODER_TIMER, TIM_IT_Update, ENABLE);

//Reset counter

TIM2->CNT = COUNTER_RESET;

ENC_Clear_Speed_Buffer();

TIM_Cmd(ENCODER_TIMER, ENABLE);

}

/*******************************************************************************

* Function Name  : ENC_Get_Electrical_Angle

* Description    : Returns the absolute electrical Rotor angle

* Input          : None

* Output         : None

* Return         : Rotor electrical angle: 0 -> 0 degrees,

*                                          S16_MAX-> 180 degrees,

*                                          S16_MIN-> -180 degrees

*******************************************************************************/

s16 ENC_Get_Electrical_Angle(void)

{

s32 temp;

temp = (s32)(TIM_GetCounter(ENCODER_TIMER)) * (s32)(U32_MAX / (4*ENCODER_PPR));

return((s16)(temp/65536)); // s16 result

}

/*******************************************************************************

* Function Name  : ENC_Clear_Speed_Buffer

* Description    : Clear speed buffer used for average speed calculation

* Input          : None

* Output         : None

* Return         : None

*******************************************************************************/

//void ENC_Clear_Speed_Buffer(void)

//{

//  u32 i;

//  for (i=0;i

//  {

//    hSpeed_Buffer[i] = 0;

//  }

//  bIs_First_Measurement = TRUE;

//}

/*******************************************************************************

* Function Name  : ENC_Calc_Rot_Speed

* Description    : Compute return latest speed measurement

* Input          : None

* Output         : s16

* Return         : Return the speed in 0.1 Hz resolution.

*******************************************************************************/

//s16 ENC_Calc_Rot_Speed(void)

//{

//  s32 wDelta_angle;

//  u16 hEnc_Timer_Overflow_sample_one, hEnc_Timer_Overflow_sample_two;

//  u16 hCurrent_angle_sample_one, hCurrent_angle_sample_two;

//  signed long long temp;

//  s16 haux;

//

//  if (!bIs_First_Measurement)

//  {

//    // 1st reading of overflow counter

//    hEnc_Timer_Overflow_sample_one = hEncoder_Timer_Overflow;

//    // 1st reading of encoder timer counter

//    hCurrent_angle_sample_one = ENCODER_TIMER->CNT;

//    // 2nd reading of overflow counter

//    hEnc_Timer_Overflow_sample_two = hEncoder_Timer_Overflow;

//    // 2nd reading of encoder timer counter

//    hCurrent_angle_sample_two = ENCODER_TIMER->CNT;

//    // Reset hEncoder_Timer_Overflow and read the counter value for the next

//    // measurement

//    hEncoder_Timer_Overflow = 0;

//    haux = ENCODER_TIMER->CNT;

//

//    if (hEncoder_Timer_Overflow != 0)

//    {

//      haux = ENCODER_TIMER->CNT;

//      hEncoder_Timer_Overflow = 0;

//    }

//

//    if (hEnc_Timer_Overflow_sample_one != hEnc_Timer_Overflow_sample_two)

//    { //Compare sample 1 & 2 and check if an overflow has been generated right

//      //after the reading of encoder timer. If yes, copy sample 2 result in

//      //sample 1 for next process

//      hCurrent_angle_sample_one = hCurrent_angle_sample_two;

//      hEnc_Timer_Overflow_sample_one = hEnc_Timer_Overflow_sample_two;

//    }

//

//    if ( (ENCODER_TIMER->CR1 & TIM_CounterMode_Down) == TIM_CounterMode_Down)

//    {// encoder timer down-counting

//      wDelta_angle = (s32)(hCurrent_angle_sample_one - hPrevious_angle -

//                    (hEnc_Timer_Overflow_sample_one) * (4*ENCODER_PPR));

//    }

//    else

//    {//encoder timer up-counting

//      wDelta_angle = (s32)(hCurrent_angle_sample_one - hPrevious_angle +

//                    (hEnc_Timer_Overflow_sample_one) * (4*ENCODER_PPR));

//    }

//

//    // speed computation as delta angle * 1/(speed sempling time)

//    temp = (signed long long)(wDelta_angle * SPEED_SAMPLING_FREQ);

//    temp *= 10;  // 0.1 Hz resolution

//    temp /= (4*ENCODER_PPR);

//

//  } //is first measurement, discard it

//  else

//  {

//    bIs_First_Measurement = FALSE;

//    temp = 0;

//    hEncoder_Timer_Overflow = 0;

//    haux = ENCODER_TIMER->CNT;

//    // Check if Encoder_Timer_Overflow is still zero. In case an overflow IT

//    // occured it resets overflow counter and wPWM_Counter_Angular_Velocity

//    if (hEncoder_Timer_Overflow != 0)

//    {

//      haux = ENCODER_TIMER->CNT;

//      hEncoder_Timer_Overflow = 0;

//    }

//  }

//

//  hPrevious_angle = haux;

//

//  return((s16) temp);

//}

/*******************************************************************************

* Function Name  : TIM2_IRQHandler

* Description    : This function handles TIMx Update interrupt request.

Encoder unit connected to TIM2

* Input          : None

* Output         : None

* Return         : None

*******************************************************************************/

void TIM3_IRQHandler(void)

{

/* Clear the interrupt pending flag */

TIM_ClearFlag(ENCODER_TIMER, TIM_FLAG_Update);

if (hEncoder_Timer_Overflow != U16_MAX)

{

hEncoder_Timer_Overflow++;

}

}

/******************* (C) COPYRIGHT 2007 STMicroelectronics *****END OF FILE****/

u16 c语言在那个头文件下,关于官方编码器库函数问题U16_MAX,U32_MAX,s16相关推荐

  1. C语言两个同名头文件,C lang: C语言中两个头文件引入相同的头文件(Header.h)

    C lang: C语言中两个头文件引入相同的头文件(Header.h) C lang: C语言中两个头文件引入相同的头文件(Header.h) [var1] For example: Header.h ...

  2. c语言exit头文件,exit函数在那个头文件

    c语言 exit的头文件是什么? C语言exit函数的头文件是stdlib.h. exit的声明为 void exit(int value); exit的作用是,退出程序,并将参数value的值返回给 ...

  3. Linux下C语言的系统头文件

    Linux菜鸟初看Linux下编程的糗事. 前段时间琢磨着接触一下Linux下的C语言编程,就找了本书看.看到很多文件操作的程序要包含"sys/stat.h". 写程序前,我想先找 ...

  4. linux下各个头文件及作用总结

    #include <linux/***.h> 是在linux-2.6.29/include/linux下面寻找源文件. #include <asm/***.h> 是在linux ...

  5. c语言设置输出字符大小_C语言中常用的几个头文件及库函数

    点击上方"C语言中文社区",选择"设为星标★" 技术干货第一时间送达! 来源:https://www.jb51.net/article/124594.htm 这 ...

  6. Linux(Ubuntu)下,生成C语言可执行文件和汇编文件

    Linux(Ubuntu)下,生成C语言可执行文件和汇编文件 前言 一.一些Linux操作 二.编写C语言文件 三.生成可执行文件 1. 正常过程 2. 可能错误 四.直接生成汇编文件 五.反汇编 1 ...

  7. c语言所有库函数及其头文件,c语言中常用的几个头文件及库函数

    不完全统计,C语言标准库中的头文件有15个之多,所以我主要介绍常用的这四个头文件stdio.h,string.h,math.h,stdlib.h,以后用到其他的再做补充.下面上干货: 1.:定义了输入 ...

  8. 用c语言批量删除指定文件夹,C语言删除文件夹下所有代码的注释for Mac

    #include #include #include char b[1000000]; void delete(char a[]) { int i,j=0; for(i=0;a[i];i++) { i ...

  9. c语言windows.h头文件详解

    如果c语言库里没有某个头文件 只需要将下好的头文件放入下面的路径即可 windows.h头文件包含的函数及其用法 1.GetAsyncKeyState()()//通过函数来判断按键按下的状态 主要用法 ...

最新文章

  1. yum源及yum仓库服务搭建讲解
  2. 驭下术:如何让下属老实听话?用这3招,让你不怒自威
  3. 常见宽带路由器配置及口令清除技巧
  4. 【多线程】ThreadPoolExecutor类万字源码解析(注解超级详细)
  5. 树莓派3B用Ubuntu MATE安装ros
  6. java小程序设计一个国旗点击国旗唱国歌,看这篇足矣了!
  7. linux使用flock解决crontab任务冲突
  8. sendmail 常见报错总结
  9. JMeter 连接 sql server
  10. MATLAB神经网络应用之Elman神经网络
  11. 机器学习 第一节 第一课
  12. php中文数组,php数组的定义
  13. linux开发板2048游戏界面图,linux c 实现2048游戏
  14. 测试用例方法--错误推测法
  15. 使用java实现输出图形(三角形、菱形等四个图形)
  16. 【问题记录】js 更改数组中某字段名
  17. qq批量登录软件_把微信PC版越甩越远:QQ电脑版这些新功能太良心
  18. 微信公众号开发之接收与发送消息
  19. 零基础制作【武林外传】辅助工具(二)
  20. Python之基本扩展模块

热门文章

  1. 医学图像标注终极指南
  2. 解除Android封锁app,解除微信对app支付的封锁
  3. java png转gif_【ImageMagick】png序列转gif(适合处理带透明度的图片)
  4. IS-IS P2P网络下LSDB同步过程
  5. DataMining学习2_数据挖掘十大经典算法
  6. 视频剪辑app软件开发需要实现哪些功能
  7. 【paper reading】Uncalibrated Photometric Stereo under Natural Illumination
  8. HTML5里video标签支持哪些格式的视频文件
  9. 王富强散文诗集《天降斯人》自序
  10. 计算机网络实训报告,计算机网络技术实训报告范文