feat: add luckfox pico pro/max support

This commit is contained in:
eng33
2023-09-27 18:14:22 +08:00
parent 7e5e289d7e
commit e1dea8a98d
10 changed files with 695 additions and 13 deletions

View File

@@ -14,7 +14,7 @@ TARGET5 = luckfox_uart_test
TARGET6 = luckfox_spi_test
all: $(TARGET1) $(TARGET2) $(TARGET3) $(TARGET4) $(TARGET5) $(TARGET6)
all: $(TARGET1) $(TARGET2) $(TARGET3) $(TARGET4) $(TARGET5) $(TARGET6)
$(TARGET1): $(TARGET1).o $(OBJ)
@$(CC) $(CFLAGS) $(TARGET1).o $(OBJ) -o $@

View File

@@ -38,6 +38,37 @@
int GPIO_BEGIN_PIN, GPIO_END_PIN;
int *TEST_PIN;
int PICO_MAX_GPIOS[] = {
LUCKFOX_PICO_MAX_GPIO0,
LUCKFOX_PICO_MAX_GPIO1,
LUCKFOX_PICO_MAX_GPIO2,
LUCKFOX_PICO_MAX_GPIO3,
LUCKFOX_PICO_MAX_GPIO4,
LUCKFOX_PICO_MAX_GPIO5,
LUCKFOX_PICO_MAX_GPIO6,
LUCKFOX_PICO_MAX_GPIO7,
LUCKFOX_PICO_MAX_GPIO8,
LUCKFOX_PICO_MAX_GPIO9,
LUCKFOX_PICO_MAX_GPIO10,
LUCKFOX_PICO_MAX_GPIO11,
LUCKFOX_PICO_MAX_GPIO12,
LUCKFOX_PICO_MAX_GPIO13,
LUCKFOX_PICO_MAX_GPIO14,
LUCKFOX_PICO_MAX_GPIO15,
LUCKFOX_PICO_MAX_GPIO16,
LUCKFOX_PICO_MAX_GPIO17,
LUCKFOX_PICO_MAX_GPIO18,
LUCKFOX_PICO_MAX_GPIO19,
LUCKFOX_PICO_MAX_GPIO20,
LUCKFOX_PICO_MAX_GPIO21,
LUCKFOX_PICO_MAX_GPIO22,
/*23-25*/
LUCKFOX_PICO_MAX_GPIO26,
LUCKFOX_PICO_MAX_GPIO27,
LUCKFOX_PICO_MAX_GPIO28,
};
int PICO_PLUS_GPIOS[] = {
LUCKFOX_PICO_PLUS_GPIO0,
LUCKFOX_PICO_PLUS_GPIO1,
@@ -62,6 +93,7 @@ int PICO_PLUS_GPIOS[] = {
LUCKFOX_PICO_PLUS_GPIO20,
LUCKFOX_PICO_PLUS_GPIO21,
LUCKFOX_PICO_PLUS_GPIO22,
/*23-25*/
LUCKFOX_PICO_PLUS_GPIO26,
LUCKFOX_PICO_PLUS_GPIO27,
};
@@ -125,12 +157,13 @@ int main(int argc, char *argv[])
printf("Please select your test borad\r\n");
printf("* 1. LUCKFOX PICO\r\n");
printf("* 2. LUCKFOX PICO PLUS\r\n");
printf("* 3. LUCKFOX PICO MAX\r\n");
printf("-----------------------------\r\n");
while (1)
{
printf("Which would you like? :");
input_char = getchar();
if (input_char >= '1' && input_char <= '2')
if (input_char >= '1' && input_char <= '3')
{
break;
}
@@ -148,6 +181,12 @@ int main(int argc, char *argv[])
GPIO_END_PIN = 22;
TEST_PIN = PICO_PLUS_GPIOS;
}
else if (input_char == '3')
{
GPIO_BEGIN_PIN = 16;
GPIO_END_PIN = 22;
TEST_PIN = PICO_MAX_GPIOS;
}
else
{
exit(0);
@@ -155,7 +194,7 @@ int main(int argc, char *argv[])
printf("-----------------------------\r\n");
printf("Please select your test borad\r\n");
printf("* 1. Default part(GP%d-GP%d)\r\n", GPIO_BEGIN_PIN, GPIO_END_PIN);
printf("* 2. ALL(Except GP0 GP1)\r\n");
printf("* 2. ALL(GP2-GP%d)\r\n", GPIO_END_PIN);
printf("-----------------------------\r\n");
while (1)
{

View File

@@ -34,7 +34,9 @@
#include <signal.h> //signal()
#include "luckfox_pwm.h"
int PWMS[] = {0, 1, 10, 11};
int PICO_PWMS[] = {0, 1, 10, 11};
int PICO_MAX_PWMS[] = {5, 6, 10, 11};
int *TEST_PWM;
void Delay_ms(uint32_t xms)
{
@@ -51,9 +53,9 @@ void Handler(int signo)
printf("\r\nHandler:exit\r\n");
for (int x = 0; x < 4; x++)
{
luckfox_pwm_set_duty(PWMS[x], 0);
luckfox_pwm_deinit(PWMS[x]);
printf("PWM%dM0 deinit\r\n", PWMS[x]);
luckfox_pwm_set_duty(TEST_PWM[x], 0);
luckfox_pwm_deinit(TEST_PWM[x]);
printf("PWM%dM0 deinit\r\n", TEST_PWM[x]);
}
exit(0);
@@ -61,12 +63,43 @@ void Handler(int signo)
int main(int argc, char *argv[])
{
char input_char = '0';
signal(SIGINT, Handler);
printf("-----------------------------\r\n");
printf("----------PWM TEST----------\r\n");
printf("-----------------------------\r\n");
printf("Please select your test borad\r\n");
printf("* 1. LUCKFOX PICO & LUCKFOX PICO PLUS\r\n");
printf("* 2. LUCKFOX PICO MAX\r\n");
printf("-----------------------------\r\n");
while (1)
{
printf("Which would you like? :");
input_char = getchar();
if (input_char >= '1' && input_char <= '2')
{
break;
}
}
if (input_char == '1')
{
TEST_PWM = PICO_PWMS;
}
else if (input_char == '2')
{
TEST_PWM = PICO_MAX_PWMS;
}
else
{
exit(0);
}
for (int x = 0; x < 4; x++)
{
luckfox_pwm_init(PWMS[x], 100000, 15000 * (x + 1), PWM_POLARITY_NORMAL);
luckfox_pwm_set_enable(PWMS[x], true);
printf("PWM%dM0 period=%d duty=%d\r\n", PWMS[x], luckfox_pwm_get_period(PWMS[x]), luckfox_pwm_get_duty(PWMS[x]));
luckfox_pwm_init(TEST_PWM[x], 100000, 15000 * (x + 1), PWM_POLARITY_NORMAL);
luckfox_pwm_set_enable(TEST_PWM[x], true);
printf("PWM%dM0 period=%d duty=%d\r\n", TEST_PWM[x], luckfox_pwm_get_period(TEST_PWM[x]), luckfox_pwm_get_duty(TEST_PWM[x]));
}
while (1)
{

View File

@@ -76,6 +76,46 @@
#define GPIO(bank, pin) ((((bank) * 32) + (pin)))
/**********************************************/
#define LUCKFOX_PICO_MAX_GPIO0 GPIO(GPIO1,PB2)
#define LUCKFOX_PICO_MAX_GPIO1 GPIO(GPIO1,PB3)
#define LUCKFOX_PICO_MAX_GPIO2 GPIO(GPIO1,PC7)
#define LUCKFOX_PICO_MAX_GPIO3 GPIO(GPIO1,PC6)
#define LUCKFOX_PICO_MAX_GPIO4 GPIO(GPIO1,PC5)
#define LUCKFOX_PICO_MAX_GPIO5 GPIO(GPIO1,PC4)
#define LUCKFOX_PICO_MAX_GPIO6 GPIO(GPIO1,PD2)
#define LUCKFOX_PICO_MAX_GPIO7 GPIO(GPIO1,PD3)
#define LUCKFOX_PICO_MAX_GPIO8 GPIO(GPIO2,PB1)
#define LUCKFOX_PICO_MAX_GPIO9 GPIO(GPIO1,PC0)
#define LUCKFOX_PICO_MAX_GPIO10 GPIO(GPIO1,PC1)
#define LUCKFOX_PICO_MAX_GPIO11 GPIO(GPIO1,PC2)
#define LUCKFOX_PICO_MAX_GPIO12 GPIO(GPIO1,PC3)
#define LUCKFOX_PICO_MAX_GPIO13 GPIO(GPIO2,PB0)
#define LUCKFOX_PICO_MAX_GPIO14 GPIO(GPIO1,PD0)
#define LUCKFOX_PICO_MAX_GPIO15 GPIO(GPIO1,PD1)
/**********************************************/
#define LUCKFOX_PICO_MAX_GPIO28 GPIO(GPIO2,PA7)
#define LUCKFOX_PICO_MAX_GPIO27 GPIO(GPIO4,PC1)
#define LUCKFOX_PICO_MAX_GPIO26 GPIO(GPIO4,PC0)
#define LUCKFOX_PICO_MAX_GPIO22 GPIO(GPIO2,PA6)
#define LUCKFOX_PICO_MAX_GPIO21 GPIO(GPIO2,PA3)
#define LUCKFOX_PICO_MAX_GPIO20 GPIO(GPIO2,PA2)
#define LUCKFOX_PICO_MAX_GPIO19 GPIO(GPIO2,PA1)
#define LUCKFOX_PICO_MAX_GPIO18 GPIO(GPIO2,PA0)
#define LUCKFOX_PICO_MAX_GPIO17 GPIO(GPIO2,PA5)
#define LUCKFOX_PICO_MAX_GPIO16 GPIO(GPIO2,PA4)
/**********************************************/
#define LUCKFOX_PICO_PLUS_GPIO0 GPIO(GPIO1,PB2)
#define LUCKFOX_PICO_PLUS_GPIO1 GPIO(GPIO1,PB3)