Include missing file
authorMichael McMaster <michael@codesrc.com>
Sat, 5 Nov 2016 06:20:34 +0000 (16:20 +1000)
committerMichael McMaster <michael@codesrc.com>
Sat, 5 Nov 2016 06:20:34 +0000 (16:20 +1000)
src/firmware/bsp.c [new file with mode: 0644]

diff --git a/src/firmware/bsp.c b/src/firmware/bsp.c
new file mode 100644 (file)
index 0000000..23da16a
--- /dev/null
@@ -0,0 +1,104 @@
+//     Copyright (C) 2016 Michael McMaster <michael@codesrc.com>
+//
+//     This file is part of SCSI2SD.
+//
+//     SCSI2SD is free software: you can redistribute it and/or modify
+//     it under the terms of the GNU General Public License as published by
+//     the Free Software Foundation, either version 3 of the License, or
+//     (at your option) any later version.
+//
+//     SCSI2SD is distributed in the hope that it will be useful,
+//     but WITHOUT ANY WARRANTY; without even the implied warranty of
+//     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+//     GNU General Public License for more details.
+//
+//     You should have received a copy of the GNU General Public License
+//     along with SCSI2SD.  If not, see <http://www.gnu.org/licenses/>.
+
+#include "bsp.h"
+#include "stm32f2xx_hal.h"
+
+
+static int usingFastClock = 0;
+
+// TODO keep clock routines consistent with those in STM32Cubemx main.c
+
+// The standard clock is 108MHz with 48MHz SDIO clock
+void s2s_setNormalClock()
+{
+       if (usingFastClock)
+       {
+               usingFastClock = 0;
+
+               // Stop using PLL as system clock
+               RCC_ClkInitTypeDef RCC_ClkInitStruct;
+               RCC_ClkInitStruct.ClockType =
+                       RCC_CLOCKTYPE_SYSCLK |
+                       RCC_CLOCKTYPE_PCLK1 |
+                       RCC_CLOCKTYPE_PCLK2;
+               RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSE;
+               RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
+               RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
+               RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;
+               HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3);
+
+               // Change PLL
+               RCC_OscInitTypeDef RCC_OscInitStruct;
+               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 = 20;
+               RCC_OscInitStruct.PLL.PLLN = 432;
+               RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV4;
+               RCC_OscInitStruct.PLL.PLLQ = 9; // 48MHz.
+               HAL_RCC_OscConfig(&RCC_OscInitStruct);
+
+               // Resume using PLL for system clock
+               RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
+               HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3);
+       }
+}
+
+// The fast clock is 108MHz with 72MHz SDIO clock
+// PLL needs to be between 67MHz and 75MHz.
+// USB will NOT work in this mode.
+// Unfortunately this is the only way to get faster SDIO transfers
+// on STM32F205 due to errata on the SDIO Bypass Clock mode.
+void s2s_setFastClock()
+{
+       if (!usingFastClock)
+       {
+               usingFastClock = 1;
+
+               // Stop using PLL as system clock
+               RCC_ClkInitTypeDef RCC_ClkInitStruct;
+               RCC_ClkInitStruct.ClockType =
+                       RCC_CLOCKTYPE_SYSCLK |
+                       RCC_CLOCKTYPE_PCLK1 |
+                       RCC_CLOCKTYPE_PCLK2;
+               RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSE;
+               RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
+               RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
+               RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;
+               HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3);
+
+               // Change PLL
+               RCC_OscInitTypeDef RCC_OscInitStruct;
+               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 = 20;
+               RCC_OscInitStruct.PLL.PLLN = 432;
+               RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV4;
+               RCC_OscInitStruct.PLL.PLLQ = 6; // 72MHz.
+               HAL_RCC_OscConfig(&RCC_OscInitStruct);
+
+               // Resume using PLL for system clock
+               RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
+               HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3);
+       }
+}
+
+