123 lines
2.9 KiB
C
123 lines
2.9 KiB
C
#include <stdint.h>
|
|
#include "freertos/FreeRTOS.h"
|
|
#include "freertos/task.h"
|
|
#include "general.h"
|
|
#include <esp_log.h>
|
|
#include <driver/gpio.h>
|
|
#include <rom/ets_sys.h>
|
|
|
|
#include <hal/gpio_ll.h>
|
|
#include <esp_rom_gpio.h>
|
|
|
|
uint32_t swd_delay_cnt = 0;
|
|
// static const char* TAG = "gdb-platform";
|
|
|
|
void __attribute__((always_inline)) platform_swdio_mode_float(void) {
|
|
gpio_set_direction(SWDIO_PIN, GPIO_MODE_INPUT);
|
|
gpio_set_pull_mode(SWDIO_PIN, GPIO_FLOATING);
|
|
|
|
// That doesn't work, only gods know why
|
|
// gpio_ll_input_enable(&GPIO, SWDIO_PIN);
|
|
// gpio_ll_pullup_dis(&GPIO, SWDIO_PIN);
|
|
// gpio_ll_pulldown_dis(&GPIO, SWDIO_PIN);
|
|
}
|
|
|
|
void __attribute__((always_inline)) platform_swdio_mode_drive(void) {
|
|
// gpio_set_direction(SWDIO_PIN, GPIO_MODE_OUTPUT);
|
|
|
|
// Faster variant
|
|
// Supports only gpio less than 32
|
|
GPIO.enable_w1ts = (0x1 << SWDIO_PIN);
|
|
esp_rom_gpio_connect_out_signal(SWDIO_PIN, SIG_GPIO_OUT_IDX, false, false);
|
|
}
|
|
|
|
void __attribute__((always_inline)) platform_gpio_set_level(int32_t gpio_num, uint32_t value) {
|
|
// gpio_set_level(gpio_num, value);
|
|
|
|
// Faster variant
|
|
// Supports only gpio less than 32
|
|
if(value) {
|
|
GPIO.out_w1ts = (1 << gpio_num);
|
|
} else {
|
|
GPIO.out_w1tc = (1 << gpio_num);
|
|
}
|
|
}
|
|
|
|
void __attribute__((always_inline)) platform_gpio_set(int32_t gpio_num) {
|
|
// platform_gpio_set_level(gpio_num, 1);
|
|
|
|
// Faster variant
|
|
// Supports only gpio less than 32
|
|
GPIO.out_w1ts = (1 << gpio_num);
|
|
}
|
|
|
|
void __attribute__((always_inline)) platform_gpio_clear(int32_t gpio_num) {
|
|
// platform_gpio_set_level(gpio_num, 0);
|
|
|
|
// faster variant
|
|
// supports only gpio less than 32
|
|
GPIO.out_w1tc = (1 << gpio_num);
|
|
}
|
|
|
|
int __attribute__((always_inline)) platform_gpio_get_level(int32_t gpio_num) {
|
|
// int level = gpio_get_level(gpio_num);
|
|
|
|
// Faster variant
|
|
// Supports only gpio less than 32
|
|
int level = (GPIO.in >> gpio_num) & 0x1;
|
|
return level;
|
|
}
|
|
|
|
// init platform
|
|
void platform_init() {
|
|
}
|
|
|
|
// set reset target pin level
|
|
void platform_srst_set_val(bool assert) {
|
|
(void)assert;
|
|
}
|
|
|
|
// get reset target pin level
|
|
bool platform_srst_get_val(void) {
|
|
return false;
|
|
}
|
|
|
|
// target voltage
|
|
const char* platform_target_voltage(void) {
|
|
return NULL;
|
|
}
|
|
|
|
// platform time counter
|
|
uint32_t platform_time_ms(void) {
|
|
int64_t time_milli = esp_timer_get_time() / 1000;
|
|
return ((uint32_t)time_milli);
|
|
}
|
|
|
|
// delay ms
|
|
void platform_delay(uint32_t ms) {
|
|
vTaskDelay((ms) / portTICK_PERIOD_MS);
|
|
}
|
|
|
|
// hardware version
|
|
int platform_hwversion(void) {
|
|
return 0;
|
|
}
|
|
|
|
// set timeout
|
|
void platform_timeout_set(platform_timeout* t, uint32_t ms) {
|
|
t->time = platform_time_ms() + ms;
|
|
}
|
|
|
|
// check timeout
|
|
bool platform_timeout_is_expired(platform_timeout* t) {
|
|
return platform_time_ms() > t->time;
|
|
}
|
|
|
|
// set interface freq
|
|
void platform_max_frequency_set(uint32_t freq) {
|
|
}
|
|
|
|
// get interface freq
|
|
uint32_t platform_max_frequency_get(void) {
|
|
return 0;
|
|
} |