|
@@ -22,6 +22,8 @@
|
|
|
/* Private includes ----------------------------------------------------------*/
|
|
|
/* USER CODE BEGIN Includes */
|
|
|
#include<stdio.h>
|
|
|
+#include "oneWire.h"
|
|
|
+#include "oneWireDriver.h"
|
|
|
|
|
|
/* USER CODE END Includes */
|
|
|
|
|
@@ -42,6 +44,8 @@
|
|
|
/* Private variables ---------------------------------------------------------*/
|
|
|
ADC_HandleTypeDef hadc1;
|
|
|
|
|
|
+TIM_HandleTypeDef htim1;
|
|
|
+
|
|
|
UART_HandleTypeDef huart2;
|
|
|
|
|
|
/* USER CODE BEGIN PV */
|
|
@@ -55,6 +59,7 @@ void SystemClock_Config(void);
|
|
|
static void MX_GPIO_Init(void);
|
|
|
static void MX_USART2_UART_Init(void);
|
|
|
static void MX_ADC1_Init(void);
|
|
|
+static void MX_TIM1_Init(void);
|
|
|
static void MX_NVIC_Init(void);
|
|
|
/* USER CODE BEGIN PFP */
|
|
|
|
|
@@ -75,13 +80,20 @@ static void MX_NVIC_Init(void);
|
|
|
uint16_t getADCDiff() {
|
|
|
|
|
|
volatile uint32_t firstCnt;
|
|
|
- volatile uint16_t value;
|
|
|
- do {
|
|
|
- firstCnt = adcCounter;
|
|
|
- value = maxWaveDiff;
|
|
|
+ int32_t timeoutCnt = 20;
|
|
|
+
|
|
|
+ firstCnt = adcCounter;
|
|
|
+ ADC1->CR1 = ADC_IT_EOC; // Enable interrupts
|
|
|
+
|
|
|
+ while( timeoutCnt > 0 && adcCounter < (firstCnt+3) ) {
|
|
|
+ timeoutCnt--;
|
|
|
+ HAL_Delay(10); // Three measurements takes around 140mS. 20*10 = 200mS timeout
|
|
|
+ }
|
|
|
+ ADC1->CR1 = 0; // Disable interrupts
|
|
|
|
|
|
- } while( firstCnt != adcCounter );
|
|
|
- return value;
|
|
|
+ if( timeoutCnt == 0 ) return 0;
|
|
|
+
|
|
|
+ return maxWaveDiff;
|
|
|
}
|
|
|
|
|
|
|
|
@@ -117,21 +129,26 @@ int main(void)
|
|
|
MX_GPIO_Init();
|
|
|
MX_USART2_UART_Init();
|
|
|
MX_ADC1_Init();
|
|
|
+ MX_TIM1_Init();
|
|
|
|
|
|
/* Initialize interrupts */
|
|
|
MX_NVIC_Init();
|
|
|
/* USER CODE BEGIN 2 */
|
|
|
|
|
|
+ // Start TIM1 (used for uS delays)
|
|
|
+ HAL_TIM_Base_Start(&htim1);
|
|
|
+
|
|
|
// Enable USART1 Interrupts
|
|
|
USART2->CR1 |= USART_CR1_RXNEIE | USART_CR1_TXEIE;
|
|
|
|
|
|
-
|
|
|
+ // Enable OneWire sensors
|
|
|
+ init_gpio_pin();
|
|
|
|
|
|
// Start continous ADC-conversion
|
|
|
HAL_Delay(10);
|
|
|
ADC1->SR = 0;
|
|
|
ADC1->CR2 = ADC_CR2_ADON | ADC_CR2_CONT;
|
|
|
- ADC1->CR1 = ADC_IT_EOC;
|
|
|
+ //ADC1->CR1 = ADC_IT_EOC; // Only start IT_EOC when actually reading data
|
|
|
ADC1->CR2 |= ADC_CR2_ADON;
|
|
|
|
|
|
|
|
@@ -142,6 +159,8 @@ int main(void)
|
|
|
|
|
|
printf("VVB Energy Sensor\n");
|
|
|
|
|
|
+// testOneWireTimingFunc();
|
|
|
+
|
|
|
|
|
|
|
|
|
while (1)
|
|
@@ -151,10 +170,13 @@ int main(void)
|
|
|
/* USER CODE BEGIN 3 */
|
|
|
HAL_GPIO_TogglePin (GPIOC, GPIO_PIN_13);
|
|
|
HAL_Delay (500);
|
|
|
+ initReadTemp();
|
|
|
+ HAL_Delay(750);
|
|
|
+ float temp = readTemperature();
|
|
|
|
|
|
|
|
|
|
|
|
- printf("Cnt:%lu Diff:%u mV:%u \n",adcCounter, getADCDiff(), (getADCDiff()*805)/1000);
|
|
|
+ printf("Cnt:%lu Diff:%u mV:%u %f\n",adcCounter, getADCDiff(), (getADCDiff()*805)/1000, temp);
|
|
|
|
|
|
}
|
|
|
/* USER CODE END 3 */
|
|
@@ -285,6 +307,81 @@ static void MX_ADC1_Init(void)
|
|
|
|
|
|
}
|
|
|
|
|
|
+/**
|
|
|
+ * @brief TIM1 Initialization Function
|
|
|
+ * @param None
|
|
|
+ * @retval None
|
|
|
+ */
|
|
|
+static void MX_TIM1_Init(void)
|
|
|
+{
|
|
|
+
|
|
|
+ /* USER CODE BEGIN TIM1_Init 0 */
|
|
|
+
|
|
|
+ /* USER CODE END TIM1_Init 0 */
|
|
|
+
|
|
|
+ TIM_ClockConfigTypeDef sClockSourceConfig = {0};
|
|
|
+ TIM_MasterConfigTypeDef sMasterConfig = {0};
|
|
|
+ TIM_OC_InitTypeDef sConfigOC = {0};
|
|
|
+ TIM_BreakDeadTimeConfigTypeDef sBreakDeadTimeConfig = {0};
|
|
|
+
|
|
|
+ /* USER CODE BEGIN TIM1_Init 1 */
|
|
|
+
|
|
|
+ /* USER CODE END TIM1_Init 1 */
|
|
|
+ htim1.Instance = TIM1;
|
|
|
+ htim1.Init.Prescaler = 55;
|
|
|
+ htim1.Init.CounterMode = TIM_COUNTERMODE_UP;
|
|
|
+ htim1.Init.Period = 0xfffe;
|
|
|
+ htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
|
|
|
+ htim1.Init.RepetitionCounter = 0;
|
|
|
+ htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
|
|
|
+ if (HAL_TIM_Base_Init(&htim1) != HAL_OK)
|
|
|
+ {
|
|
|
+ Error_Handler();
|
|
|
+ }
|
|
|
+ sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
|
|
|
+ if (HAL_TIM_ConfigClockSource(&htim1, &sClockSourceConfig) != HAL_OK)
|
|
|
+ {
|
|
|
+ Error_Handler();
|
|
|
+ }
|
|
|
+ if (HAL_TIM_OC_Init(&htim1) != HAL_OK)
|
|
|
+ {
|
|
|
+ Error_Handler();
|
|
|
+ }
|
|
|
+ sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
|
|
|
+ sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
|
|
|
+ if (HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK)
|
|
|
+ {
|
|
|
+ Error_Handler();
|
|
|
+ }
|
|
|
+ sConfigOC.OCMode = TIM_OCMODE_FORCED_ACTIVE;
|
|
|
+ sConfigOC.Pulse = 0;
|
|
|
+ sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
|
|
|
+ sConfigOC.OCNPolarity = TIM_OCNPOLARITY_HIGH;
|
|
|
+ sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
|
|
|
+ sConfigOC.OCIdleState = TIM_OCIDLESTATE_RESET;
|
|
|
+ sConfigOC.OCNIdleState = TIM_OCNIDLESTATE_RESET;
|
|
|
+ if (HAL_TIM_OC_ConfigChannel(&htim1, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
|
|
|
+ {
|
|
|
+ Error_Handler();
|
|
|
+ }
|
|
|
+ sBreakDeadTimeConfig.OffStateRunMode = TIM_OSSR_DISABLE;
|
|
|
+ sBreakDeadTimeConfig.OffStateIDLEMode = TIM_OSSI_DISABLE;
|
|
|
+ sBreakDeadTimeConfig.LockLevel = TIM_LOCKLEVEL_OFF;
|
|
|
+ sBreakDeadTimeConfig.DeadTime = 0;
|
|
|
+ sBreakDeadTimeConfig.BreakState = TIM_BREAK_DISABLE;
|
|
|
+ sBreakDeadTimeConfig.BreakPolarity = TIM_BREAKPOLARITY_HIGH;
|
|
|
+ sBreakDeadTimeConfig.AutomaticOutput = TIM_AUTOMATICOUTPUT_DISABLE;
|
|
|
+ if (HAL_TIMEx_ConfigBreakDeadTime(&htim1, &sBreakDeadTimeConfig) != HAL_OK)
|
|
|
+ {
|
|
|
+ Error_Handler();
|
|
|
+ }
|
|
|
+ /* USER CODE BEGIN TIM1_Init 2 */
|
|
|
+
|
|
|
+ /* USER CODE END TIM1_Init 2 */
|
|
|
+ HAL_TIM_MspPostInit(&htim1);
|
|
|
+
|
|
|
+}
|
|
|
+
|
|
|
/**
|
|
|
* @brief USART2 Initialization Function
|
|
|
* @param None
|
|
@@ -342,6 +439,12 @@ static void MX_GPIO_Init(void)
|
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_MEDIUM;
|
|
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
|
|
+ /*Configure GPIO pin : PC14 */
|
|
|
+ GPIO_InitStruct.Pin = GPIO_PIN_14;
|
|
|
+ GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
|
+ GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
|
+ HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
+
|
|
|
}
|
|
|
|
|
|
/* USER CODE BEGIN 4 */
|