CS1237 STM32控制程序以及原理图需要注意事项

CS1237供电为5V的时候STM32是3.3V这时候应该加不小于5.1K的上拉电阻,不然CS1237跟32通信不上,32设置为OD驱动,同时不需要设计通信引脚的限流电阻就可以

下面是驱动程序

 

----------------------------------------------------------MAIN----------------------------------------------------------

/* USER CODE BEGIN Header */
/**
  ******************************************************************************
  * @file           : main.c
  * @brief          : Main program body
  ******************************************************************************
  * @attention
  *
  * <h2><center>&copy; Copyright (c) 2020 STMicroelectronics.
  * All rights reserved.</center></h2>
  *
  * This software component is licensed by ST under BSD 3-Clause license,
  * the "License"; You may not use this file except in compliance with the
  * License. You may obtain a copy of the License at:
  *                        opensource.org/licenses/BSD-3-Clause
  *
  ******************************************************************************
  */
/* USER CODE END Header */

/* Includes ------------------------------------------------------------------*/
#include "main.h"
#include "dma.h"
#include "usart.h"
#include "gpio.h"

/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */
#include "string.h"
#include "mycs1237.h"
/* USER CODE END Includes */

/* Private typedef -----------------------------------------------------------*/
/* USER CODE BEGIN PTD */

/* USER CODE END PTD */

/* Private define ------------------------------------------------------------*/
/* USER CODE BEGIN PD */
/* USER CODE END PD */

/* Private macro -------------------------------------------------------------*/
/* USER CODE BEGIN PM */

/* USER CODE END PM */

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

/* USER CODE BEGIN PV */

/* USER CODE END PV */

/* Private function prototypes -----------------------------------------------*/
void SystemClock_Config(void);
/* USER CODE BEGIN PFP */

/* USER CODE END PFP */

/* Private user code ---------------------------------------------------------*/
/* USER CODE BEGIN 0 */
uint8_t mystrlen(uint8_t *tmp)
{
    uint8_t i=0;
    while(1)
    {
        if(tmp[i]!='\0')
            i++;
        else
            return i;
    }
}
    
/* USER CODE END 0 */

/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
  /* USER CODE BEGIN 1 */
    uint8_t buff[128]={0};
    uint8_t tmp=0;
    unsigned long mydata=0;
  /* USER CODE END 1 */

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();

  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();

  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
  MX_DMA_Init();
  MX_USART1_UART_Init();
  /* USER CODE BEGIN 2 */
    init_cs1237();
    tmp=CS1237_REF(1)|CS1237_SPEED(1)|CS1237_PGA(0)|CS1237_CH(0);
    sprintf(buff,"SET CF is:0x%X\n",tmp);
    HAL_UART_Transmit(&huart1,buff,mystrlen(buff),100);
    memset(buff,0,128);
    rw_cs1237_cofig(0x65,tmp);
    
    tmp=rw_cs1237_cofig(0x56,0);
    sprintf(buff,"GET CF is:0x%X\n",tmp);
    HAL_UART_Transmit(&huart1,buff,mystrlen(buff),100);
    memset(buff,0,128);
  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
        mydata=read_cs1237_data();
        sprintf(buff,"read adc:0x%lX\n",mydata);
        HAL_UART_Transmit(&huart1,buff,mystrlen(buff),100);
        memset(buff,0,128);
        mydata=0;
  }
  /* USER CODE END 3 */
}

/**
  * @brief System Clock Configuration
  * @retval None
  */
void SystemClock_Config(void)
{
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};

  /** Configure the main internal regulator output voltage 
  */
  __HAL_RCC_PWR_CLK_ENABLE();
  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
  /** Initializes the CPU, AHB and APB busses clocks 
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  RCC_OscInitStruct.PLL.PLLM = 4;
  RCC_OscInitStruct.PLL.PLLN = 168;
  RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
  RCC_OscInitStruct.PLL.PLLQ = 4;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    Error_Handler();
  }
  /** Initializes the CPU, AHB and APB busses clocks 
  */
  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
                              |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_5) != HAL_OK)
  {
    Error_Handler();
  }
}

/* USER CODE BEGIN 4 */

/* USER CODE END 4 */

/**
  * @brief  This function is executed in case of error occurrence.
  * @retval None
  */
void Error_Handler(void)
{
  /* USER CODE BEGIN Error_Handler_Debug */
  /* User can add his own implementation to report the HAL error return state */

  /* USER CODE END Error_Handler_Debug */
}

#ifdef  USE_FULL_ASSERT
/**
  * @brief  Reports the name of the source file and the source line number
  *         where the assert_param error has occurred.
  * @param  file: pointer to the source file name
  * @param  line: assert_param error line source number
  * @retval None
  */
void assert_failed(uint8_t *file, uint32_t line)

  /* USER CODE BEGIN 6 */
  /* User can add his own implementation to report the file name and line number,
     tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  /* USER CODE END 6 */
}
#endif /* USE_FULL_ASSERT */

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

 

----------------------------------------------------------CS1237.C----------------------------------------------------------

 

#include "mycs1237.h"

static GPIO_InitTypeDef GPIO_InitStruct = {0};

#define CS1237_PINSCLK GPIO_PIN_14
#define CS1237_PINDD GPIO_PIN_13

#define CS1237_SCLK(x) HAL_GPIO_WritePin(GPIOB, CS1237_PINSCLK,x)
#define CS1237_DD(x) HAL_GPIO_WritePin(GPIOB, CS1237_PINDD,x)

#define READ_SCLK HAL_GPIO_ReadPin(GPIOB,CS1237_PINSCLK)
#define READ_DD HAL_GPIO_ReadPin(GPIOB,CS1237_PINDD)

#define CS1237_GPIO_OUT(x)  GPIO_InitStruct.Pull = GPIO_NOPULL;GPIO_InitStruct.Pin = x;GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_OD;GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;HAL_GPIO_Init(GPIOB, &GPIO_InitStruct)
#define CS1237_GPIO_IN(x)  GPIO_InitStruct.Pull = GPIO_NOPULL;GPIO_InitStruct.Pin = x;GPIO_InitStruct.Mode = GPIO_MODE_INPUT;GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;HAL_GPIO_Init(GPIOB, &GPIO_InitStruct)

//SCLK高100uS会关闭ADC!!!

static void cs1237_nop(void)
{
    unsigned int i=0;
    for(i=0;i<20;i++)
__asm {
    nop
}
}

void init_cs1237(void)
{
    
    CS1237_DD(GPIO_PIN_SET);
    CS1237_SCLK(GPIO_PIN_RESET);
    
  CS1237_GPIO_OUT(CS1237_PINDD);
    CS1237_GPIO_OUT(CS1237_PINSCLK);
    
    CS1237_SCLK(GPIO_PIN_SET);
    HAL_Delay(500);//ms
    CS1237_SCLK(GPIO_PIN_RESET);
    HAL_Delay(500);//ms
}

unsigned long read_cs1237_data(void)
{
    unsigned short i=0;
    unsigned long tmp=0;
    

    CS1237_GPIO_IN(CS1237_PINDD);//输入数据
    CS1237_GPIO_OUT(CS1237_PINSCLK);//输出脉冲
    
  while((GPIO_PIN_SET==READ_DD)&&(i<320))
    {
        i++;
        HAL_Delay(1);//ms
    }
    if(i<320)
    {}
    else
    {
        return 0;
    }
    for(i=0;i<24;i++)//1-24读取数据
    {    
        tmp<<=1;
        CS1237_SCLK(GPIO_PIN_SET);
        cs1237_nop();//460ns
        CS1237_SCLK(GPIO_PIN_RESET);
        cs1237_nop();//460ns        
        if(GPIO_PIN_SET==READ_DD)
            tmp++;
    }
    for(i=0;i<3;i++)//25-27拉高数据脚
    {
        CS1237_SCLK(GPIO_PIN_SET);
        cs1237_nop();//ns
        CS1237_SCLK(GPIO_PIN_RESET);
        cs1237_nop();//ns
    }
    CS1237_GPIO_IN(CS1237_PINDD);
    tmp^=0x800000;
    return tmp;
}

unsigned char rw_cs1237_cofig(unsigned char cmd,unsigned char data)
{
    unsigned char tmp=0;
    unsigned short i=0;
    unsigned char rw_flag=0;
    unsigned char cnoo = 0;
    
    if(0x65==cmd)
        rw_flag=1;
    else
        rw_flag=0;
    
    CS1237_GPIO_IN(CS1237_PINDD);
    
    while((READ_DD==1)&&(i<320))
    {
        i++;
        HAL_Delay(1);//ms
    }
    if(i<320)
    {}
    else
    {
        return 0;
    }
    for(i=1;i<25;i++)//1-24脉冲
    {
        CS1237_SCLK(GPIO_PIN_SET);
        cs1237_nop();//ns
        CS1237_SCLK(GPIO_PIN_RESET);
        cs1237_nop();//ns
    }
    for(i=25;i<27;i++)//25-26
    {
        cnoo<<=1;
        CS1237_SCLK(GPIO_PIN_SET);
        cs1237_nop();//ns        
        CS1237_SCLK(GPIO_PIN_RESET);
        cs1237_nop();//ns    
        if(1==READ_DD)
            cnoo++;
    }
    CS1237_SCLK(GPIO_PIN_SET);//27
    cs1237_nop();//ns
    CS1237_SCLK(GPIO_PIN_RESET);
    cs1237_nop();//ns
    CS1237_SCLK(GPIO_PIN_SET);//28
    cs1237_nop();//ns
    CS1237_SCLK(GPIO_PIN_RESET);
    cs1237_nop();//ns
    CS1237_SCLK(GPIO_PIN_SET);//29
    cs1237_nop();//ns
    CS1237_SCLK(GPIO_PIN_RESET);
    cs1237_nop();//ns    
  CS1237_GPIO_OUT(CS1237_PINDD);
    for(i=30;i<37;i++)//30-36
    {
        CS1237_SCLK(GPIO_PIN_SET);
        cs1237_nop();//ns
        if((cmd&0x40)==(0x40))
            CS1237_DD(1);
        else
            CS1237_DD(0);
        CS1237_SCLK(GPIO_PIN_RESET);
        cs1237_nop();//ns
        cmd<<=1;
    }
    CS1237_SCLK(GPIO_PIN_SET);//37
    cs1237_nop();//ns
    CS1237_SCLK(GPIO_PIN_RESET);
    cs1237_nop();//ns        
    if(rw_flag==1)
    {
        for(i=38;i<46;i++)//38-45
        {
            CS1237_SCLK(GPIO_PIN_SET);
            cs1237_nop();//ns
            if((data&0x80)==0x80)
                CS1237_DD(1);
            else
                CS1237_DD(0);
            CS1237_SCLK(GPIO_PIN_RESET);
            cs1237_nop();//ns    
            data<<=1;
        }
    }
    else
    {
        CS1237_GPIO_IN(CS1237_PINDD);
        for(i=38;i<46;i++)//38-45
        {
            tmp<<=1;
            CS1237_SCLK(GPIO_PIN_SET);
            cs1237_nop();//ns
            CS1237_SCLK(GPIO_PIN_RESET);
            cs1237_nop();//ns    
            if(READ_DD==1)
                tmp++;
        }
    }
    CS1237_SCLK(GPIO_PIN_SET);//46
    cs1237_nop();//ns
    CS1237_SCLK(GPIO_PIN_RESET);
    cs1237_nop();//ns    
    CS1237_GPIO_IN(CS1237_PINDD);
    return tmp;
}

 

 

----------------------------------------------------------CS1237.H----------------------------------------------------------

 

#ifndef __MYCS1237__
#define __MYCS1237__

#include "stm32f4xx_hal.h"

#define CS1237_REF(x) (x<<6)//1off
#define CS1237_SPEED(x) (x<<4)//0\10hz 1\40hz 2\640hz 3\1280hz
#define CS1237_PGA(x)  (x<<2)//0\1 1\2 2\64 3\128
#define CS1237_CH(x)  (x<<0)//0\A 1\ 2\wd 3\nd 

void init_cs1237(void);
unsigned long read_cs1237_data(void);
unsigned char rw_cs1237_cofig(unsigned char cmd,unsigned char data);


#endif
 

 

 

 

  • 4
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: CS1237是一个STM32的程序。STM32是意法半导体公司开发的一款32位微控制器。CS1237程序是在STM32上运行的一段代码,用于实现特定功能。 STM32微控制器是一种功能强大的芯片,能够处理复杂的任务,并可用于各种应用领域。CS1237程序可能是基于特定的需求和目的编写的,可能包含了一系列指令和操作,用于控制STM32芯片的功能。 CS1237程序可能包括读取和写入寄存器值、配置IO口和外设、设置时钟、处理中断等操作。它可能还包括实现某些算法、数据处理或通信协议,如UART、SPI、I2C等。具体的功能和实现取决于CS1237程序的设计目标。 对于CS1237程序的详细内容和功能,还需要进一步的信息。可能需要查看程序的源代码,了解其中的逻辑和各个模块的功能。同时,还需要了解与该程序相关的硬件环境和外部设备接口。 总之,CS1237是一款运行在STM32微控制器上的程序,具体功能和实现取决于程序的设计需求和目标。需要进一步的信息和了解,才能给出更详细的回答。 ### 回答2: CS1237是一款使用STM32微控制器编写的程序。STM32是一系列高性能、低功耗的微控制器,广泛应用于各种领域,包括工业控制、通信设备、汽车电子等。CS1237是基于STM32的一款特定应用程序。 CS1237STM32程序主要实现了以下功能: 1. 数据采集:通过连接各种传感器和模块,实时采集所需的数据。STM32的丰富的外设接口,如ADC、UART、SPI等,可以实现不同类型数据的采集。 2. 数据处理:采集到的数据会通过STM32内部的算法进行处理,如滤波、校正、数据转换等。通过程序的逻辑,对数据进行相应的操作,以满足系统需求。 3. 控制与驱动:根据采集到的数据进行控制和驱动相应的外设。例如,通过控制电机驱动板,实现电机的转动控制;通过控制继电器,控制配电箱中的开关。 4. 通信与显示:程序还支持与外部设备进行通信,并通过不同的通信协议,如UART、SPI、I2C等,与其他设备进行数据交换和信息传递。通过连接显示屏,将处理后的数据进行显示。 5. 扩展功能:根据具体需求,CS1237STM32程序还可以扩展其他功能,如存储数据到SD卡、实现网络通信等。这些功能可以通过相关的外设和对应的驱动程序来实现。 总结来说,CS1237STM32程序通过数据采集、处理、控制与驱动、通信与显示等功能,实现了对特定应用的支持和控制。STM32的强大性能和丰富的外设接口,使得CS1237STM32程序能够高效地运行,并满足特定应用的要求。 ### 回答3: CS1237是一款基于STM32微控制器的程序。STM32是意法半导体(STMicroelectronics)公司推出的一种高性能32位微控制器系列,具有广泛的应用领域。 CS1237STM32程序的设计目的是实现某种功能或解决特定的问题。具体的实现方式可能包括编写代码、配置寄存器、使用外设等。 这个程序可能针对不同的应用场景进行了编写,比如可以是嵌入式系统、通信领域、物联网等。根据具体的需求,程序可能会包含不同的模块,比如系统初始化模块、外设驱动模块、任务调度模块等。 CS1237STM32程序往往会使用C语言进行编写,因为C语言是一种功能丰富、可移植性高的编程语言。同时,程序员也可以使用其他语言,如汇编语言,对关键的代码进行优化,提高程序的性能。 如果要了解CS1237STM32程序的具体实现细节,可以参考相关的技术资料、代码文档或咨询程序设计者。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值