By | 17/09/2018
Tutorial STM32 dengan Keil uVision dan STMcube

Pada Kesempatan Kali ini saya akan menulis Artikel tentang Tutorial STM32, Cara Memulai Program dengan STM32Cube dan Keil uVision 5.
saya tidak bisa menjelaskan secara detail mengenai kelebihan dan kekurangan Board STM32 dengan Arduino, karena secara Board dan IC juga sudah sangat berbeda, dan kali ini saya hanya ingin menjelaskan bagaimana kita dapat memprogram STM32 menggunakan STM32Cube dan Keil uVission 5.

Kita bisa anggap STM32Cube adalah CodeWizard yang membantu kita membuat program Setup nya. sedangkan Keil uVission 5 adalah editornya.

Download File Project Blink STM32 | DOWNLOAD

nah langsung saja kita siapkan terlebih dahulu bahan bahan yang diperlukan

1. Laptop yang Mumpuni
2. Sofware STM32Cube
3. Hardware Board STM32 dan pada tutorial ini saya menggunakan board tipe STM32F446RE.
4. Software Install Driver ST-Link
5. Software Keil uVission 5
6. Internet yang memadai. dan ini sangat diwajibkan, karena kita perlu install banyak package nya.dan mungkin agak lama.

untuk Software yang diperlukan tadi kamu bisa Download di bawah ini seluruhnya atau satu per satu, kalo internet nya lambat lebih baik satu per satu saja

Download Software

Program STM32 menggunakan Keil uVission 5 menggunakan Bahasa C, jadi jika kamu benar benar yakin untuk belajar dengan Keil uVission 5 kamu harus punya dasar pengetahuan tentang Bahasa C baiklah saya rasa itu saja saran nya, selanjutnya kita akan mencoba memulai nya.

Pertama Install dulu STM32Cube, jika diminta untuk Update, update terlebih dahulu, sehingga board yang kita butuhkan terinstall di dalamnya.

Kedua Install  Keil uVission 5 nya, dan jangan lupa install semua packaga dan tool lainya,, kalo diminta update, silahkan di update. pastikan kamu sabar, dan koneksi internet lancar jaya.

Ketiga Hubungkan Hardware STM32 ke Komputer kemudian Install Software Driver ST-Link
Karena saya menggunakan Board STM32F446RE yang sudah ada ST-Link dan tinggal colok, jadi tidak ada masalah, tapi jika kamu menggunakan Board yang hanya terdapat Sistem Minimumnya saja misal STM32F103. maka kamu butuh Hardware ST-Link tambahan. kamu bisa hubungkan degan keduanya seperti berikut :

  Intsall Software Drivernya sesuai bit Windows kamu, Saya menggunakan Windows 10 64bit.  

Saat Upload Program Tombol reset perlu ditekan dan sesaat sebelum selesei upload harus dilepas,
kalo sempet mungkin nanti saya akan membuatkan video tutorial untuk Cara Upload Program STM32F103.

kita lanjutkan, silahkan di install Driver nya, sehingga STM32 kamu kedeteksi Portnya,, untuk mengeceknys bisa dilihat pada Device Manager.

jika sudah selesei, dan sudah melewati perjalanan panjang, kita mulai memprogramnya.

1. Buka STM32Cube

Klik New Project

Pilih Board STM32 kamu, disini saya menggunakan STM32F446RE, gambarnya seperti berikut :

Selanjutnya jika sudah dipilih klik Start Porject, disini kamu bisa juga langsung lihat DataSheetnya,, dengan catatan ada Koneksi Internet.

kemudian, karena LED yang ada di Board STM32F446RE ini terhubung dengan PA_5 (PORTA 5) maka kita akan meng inisialisasikan PA_5 sebagai Port OUTPUT (GPIO Output)

kemudian klik Project > Generate Code
Silahkan diisi nama projectnya dan Editor yang kita gunakan, lebih jelasnya lihat di gambar berikut :

Pilih Oke. kemudian jika sudah selesai Open Project, dan otomatis akan membuka Software Keil uVission 5 kamu.

sekarang kita bisa membuka File main.c dan disitulah kita akan membuat programnya.

lihat gambar di atas, klik yang dilingkari warna merah tersebut kemudian pilih menu “debug

Klik tombol Setting yang dilingkari warna biru, kemudian akan tampil jendela seperti gambar dibawah ini. ikuti pengaturanya dan klik OK.

selanjtnya kita tinggal membuat program blink nya, Replace saja code dalam main.c nya dengan code berikut :

/**
  ******************************************************************************
  * @file           : main.c
  * @brief          : Main program body
  ******************************************************************************
  ** This notice applies to any and all portions of this file
  * that are not between comment pairs USER CODE BEGIN and
  * USER CODE END. Other portions of this file, whether
  * inserted by the user or by software development tools
  * are owned by their respective copyright owners.
  *
  * COPYRIGHT(c) 2018 STMicroelectronics
  *
  * Redistribution and use in source and binary forms, with or without modification,
  * are permitted provided that the following conditions are met:
  *   1. Redistributions of source code must retain the above copyright notice,
  *      this list of conditions and the following disclaimer.
  *   2. Redistributions in binary form must reproduce the above copyright notice,
  *      this list of conditions and the following disclaimer in the documentation
  *      and/or other materials provided with the distribution.
  *   3. Neither the name of STMicroelectronics nor the names of its contributors
  *      may be used to endorse or promote products derived from this software
  *      without specific prior written permission.
  *
  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  *
  ******************************************************************************
  */
/* Includes ------------------------------------------------------------------*/
#include "main.h"
#include "stm32f4xx_hal.h"
/* USER CODE BEGIN Includes */
/* USER CODE END Includes */
/* Private variables ---------------------------------------------------------*/
/* USER CODE BEGIN PV */
/* Private variables ---------------------------------------------------------*/
/* USER CODE END PV */
/* Private function prototypes -----------------------------------------------*/
void SystemClock_Config(void);
static void MX_GPIO_Init(void);
/* USER CODE BEGIN PFP */
/* Private function prototypes -----------------------------------------------*/
/* USER CODE END PFP */
/* USER CODE BEGIN 0 */
/* USER CODE END 0 */
/**
  * @brief  The application entry point.
  *
  * @retval None
  */
int main(void)
{
  /* USER CODE BEGIN 1 */
  /* 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();
  /* USER CODE BEGIN 2 */
  /* USER CODE END 2 */
  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
  /* USER CODE END WHILE */
  /* USER CODE BEGIN 3 */
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_SET);
HAL_Delay(1000);
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_RESET);
HAL_Delay(1000);
  }
  /* USER CODE END 3 */
}
/**
  * @brief System Clock Configuration
  * @retval None
  */
void SystemClock_Config(void)
{
  RCC_OscInitTypeDef RCC_OscInitStruct;
  RCC_ClkInitTypeDef RCC_ClkInitStruct;
    /**Configure the main internal regulator output voltage
    */
  __HAL_RCC_PWR_CLK_ENABLE();
  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE3);
    /**Initializes the CPU, AHB and APB busses clocks
    */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  RCC_OscInitStruct.HSICalibrationValue = 16;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    _Error_Handler(__FILE__, __LINE__);
  }
    /**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_HSI;
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)
  {
    _Error_Handler(__FILE__, __LINE__);
  }
    /**Configure the Systick interrupt time
    */
  HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/1000);
    /**Configure the Systick
    */
  HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK);
  /* SysTick_IRQn interrupt configuration */
  HAL_NVIC_SetPriority(SysTick_IRQn, 0, 0);
}
/** Configure pins as
        * Analog
        * Input
        * Output
        * EVENT_OUT
        * EXTI
*/
static void MX_GPIO_Init(void)
{
  GPIO_InitTypeDef GPIO_InitStruct;
  /* GPIO Ports Clock Enable */
  __HAL_RCC_GPIOA_CLK_ENABLE();
  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_RESET);
  /*Configure GPIO pin : PA5 */
  GPIO_InitStruct.Pin = GPIO_PIN_5;
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  GPIO_InitStruct.Pull = GPIO_NOPULL;
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
}
/* USER CODE BEGIN 4 */
/* USER CODE END 4 */
/**
  * @brief  This function is executed in case of error occurrence.
  * @param  file: The file name as string.
  * @param  line: The line in file as a number.
  * @retval None
  */
void _Error_Handler(char *file, int line)
{
  /* USER CODE BEGIN Error_Handler_Debug */
  /* User can add his own implementation to report the HAL error return state */
  while(1)
  {
  }
  /* 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 %drn", file, line) */
  /* USER CODE END 6 */
}
#endif /* USE_FULL_ASSERT */
/**
  * @}
  */
/**
  * @}
  */
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/

kemudian BUILD dan UPLOAD/LOAD programnya, silahkan amati hasilnya,, jika LED sudah berkedip berarti anda sudah berhasil. selamat mencoba, dan jangan lupa terus berkunjung di blog www.anakkendali.com

karena Tutorialnya masih akan terus berlanjut 🙂 Follow untuk mendapat pemberitahuan.

Keyword

  1. Tutorial STM32 Keil uVision,
  2. Memulai Belajar STM32 dengan Keil uVision,
  3. Memulai Program STM32 dengan keil,

Leave a Reply

Your email address will not be published. Required fields are marked *