2023-08-09 23:00:44 +08:00
|
|
|
/* Copyright 2023 Dual Tachyon
|
|
|
|
* https://github.com/DualTachyon
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "ARMCM0.h"
|
|
|
|
|
|
|
|
#include "bsp/dp32g030/gpio.h"
|
|
|
|
#include "bsp/dp32g030/portcon.h"
|
|
|
|
#include "bsp/dp32g030/syscon.h"
|
|
|
|
#include "board.h"
|
|
|
|
#include "driver/crc.h"
|
2023-08-10 18:57:44 +08:00
|
|
|
#include "driver/bk4819.h"
|
2023-08-09 23:00:44 +08:00
|
|
|
#include "driver/eeprom.h"
|
|
|
|
#include "driver/flash.h"
|
|
|
|
#include "driver/gpio.h"
|
|
|
|
#include "driver/st7565.h"
|
2023-08-10 18:35:02 +08:00
|
|
|
#include "driver/system.h"
|
2023-08-09 23:00:44 +08:00
|
|
|
#include "driver/systick.h"
|
|
|
|
#include "driver/uart.h"
|
2023-08-11 00:51:57 +08:00
|
|
|
#include "misc.h"
|
2023-08-09 23:00:44 +08:00
|
|
|
|
|
|
|
static const char Version[] = "UV-K5 Firmware, v0.01 Open Edition\r\n";
|
|
|
|
|
|
|
|
static void FLASHLIGHT_Init(void)
|
|
|
|
{
|
2023-08-10 18:05:46 +08:00
|
|
|
PORTCON_PORTC_IE = PORTCON_PORTC_IE_C5_BITS_ENABLE;
|
|
|
|
PORTCON_PORTC_PU = PORTCON_PORTC_PU_C5_BITS_ENABLE;
|
|
|
|
GPIOC->DIR |= GPIO_DIR_3_BITS_OUTPUT;
|
2023-08-09 23:00:44 +08:00
|
|
|
|
|
|
|
GPIO_SetBit(&GPIOC->DATA, 10);
|
|
|
|
GPIO_SetBit(&GPIOC->DATA, 11);
|
|
|
|
GPIO_SetBit(&GPIOC->DATA, 12);
|
|
|
|
GPIO_SetBit(&GPIOC->DATA, 13);
|
|
|
|
}
|
|
|
|
|
2023-08-10 18:35:02 +08:00
|
|
|
static void FLASHLIGHT_TurnOff(void)
|
|
|
|
{
|
2023-08-10 19:30:41 +08:00
|
|
|
GPIO_ClearBit(&GPIOC->DATA, GPIOB_PIN_FLASHLIGHT);
|
2023-08-10 18:35:02 +08:00
|
|
|
}
|
|
|
|
|
2023-08-09 23:00:44 +08:00
|
|
|
static void FLASHLIGHT_TurnOn(void)
|
|
|
|
{
|
2023-08-10 19:30:41 +08:00
|
|
|
GPIO_SetBit(&GPIOC->DATA, GPIOB_PIN_FLASHLIGHT);
|
2023-08-09 23:00:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static void BACKLIGHT_TurnOn(void)
|
|
|
|
{
|
2023-08-10 19:30:41 +08:00
|
|
|
GPIO_SetBit(&GPIOB->DATA, GPIOB_PIN_BACKLIGHT);
|
2023-08-09 23:00:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void Main(void)
|
|
|
|
{
|
|
|
|
// Enable clock gating of blocks we need.
|
|
|
|
SYSCON_DEV_CLK_GATE = 0
|
2023-08-10 18:05:46 +08:00
|
|
|
| SYSCON_DEV_CLK_GATE_GPIOA_BITS_ENABLE
|
|
|
|
| SYSCON_DEV_CLK_GATE_GPIOB_BITS_ENABLE
|
|
|
|
| SYSCON_DEV_CLK_GATE_GPIOC_BITS_ENABLE
|
|
|
|
| SYSCON_DEV_CLK_GATE_UART1_BITS_ENABLE
|
|
|
|
| SYSCON_DEV_CLK_GATE_SPI0_BITS_ENABLE
|
|
|
|
| SYSCON_DEV_CLK_GATE_SARADC_BITS_ENABLE
|
|
|
|
| SYSCON_DEV_CLK_GATE_CRC_BITS_ENABLE
|
|
|
|
| SYSCON_DEV_CLK_GATE_AES_BITS_ENABLE
|
2023-08-09 23:00:44 +08:00
|
|
|
;
|
|
|
|
|
|
|
|
SYSTICK_Init();
|
|
|
|
BOARD_Init();
|
|
|
|
|
|
|
|
UART_Init();
|
|
|
|
UART_Send(Version, sizeof(Version));
|
|
|
|
|
2023-08-10 18:57:44 +08:00
|
|
|
// Not implementing authentic device checks
|
|
|
|
|
|
|
|
// TODO: EEPROM Init
|
|
|
|
|
|
|
|
BK4819_Init();
|
2023-08-11 00:51:57 +08:00
|
|
|
BOARD_ADC_GetBatteryInfo(&gADC_CH4_BootValue, &gADC_CH9);
|
|
|
|
BOARD_EEPROM_Init();
|
|
|
|
BOARD_EEPROM_LoadMoreSettings();
|
2023-08-10 18:57:44 +08:00
|
|
|
|
|
|
|
// Below this line is development/test area not conforming to the original firmware
|
|
|
|
|
2023-08-09 23:00:44 +08:00
|
|
|
// Show some signs of life
|
|
|
|
FLASHLIGHT_Init();
|
|
|
|
FLASHLIGHT_TurnOn();
|
|
|
|
BACKLIGHT_TurnOn();
|
|
|
|
|
|
|
|
static const uint8_t TestBitmap0[8] = { 0x80, 0x80, 0x80, 0x80, 0x08, 0x08, 0x08, 0x08 };
|
|
|
|
static const uint8_t TestBitmap1[8] = { 0x10, 0x10, 0x10, 0x10, 0x01, 0x01, 0x01, 0x01 };
|
|
|
|
ST7565_DrawLine(16, 1, 8, TestBitmap0, false);
|
|
|
|
ST7565_DrawLine(24, 3, 8, TestBitmap1, false);
|
|
|
|
|
|
|
|
uint8_t Test[8];
|
|
|
|
EEPROM_ReadBuffer(0x0EB0, Test, 8);
|
|
|
|
|
|
|
|
while (1) {
|
2023-08-10 18:35:02 +08:00
|
|
|
SYSTEM_DelayMs(500);
|
|
|
|
FLASHLIGHT_TurnOff();
|
|
|
|
SYSTEM_DelayMs(500);
|
|
|
|
FLASHLIGHT_TurnOn();
|
2023-08-09 23:00:44 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|