2020-04-06 21:08:01 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
#include "unicore-mx/stm32/gpio.h"
|
|
|
|
#include "unicore-mx/stm32/rcc.h"
|
|
|
|
#include "system.h"
|
|
|
|
#include "led.h"
|
|
|
|
#include "pinout.h"
|
|
|
|
|
|
|
|
extern volatile uint32_t jiffies;
|
|
|
|
|
|
|
|
uint32_t p1_lvl, p0_lvl, master_lvl;
|
|
|
|
|
|
|
|
|
|
|
|
static int pot_cs[3] = { 8, 7, 6 }; // PC6, PC7, PC8
|
|
|
|
|
|
|
|
#define POT0 GPIO8 // C8
|
|
|
|
#define POT1 GPIO7 // C7
|
|
|
|
#define POTM GPIO6 // C6
|
2020-04-08 16:48:35 +02:00
|
|
|
#define POTINC GPIO14 // D14
|
|
|
|
#define POTUD GPIO15 // D15
|
2020-04-06 21:08:01 +02:00
|
|
|
|
|
|
|
#define NUM_POTS 3
|
|
|
|
#define POT_CS_PINS (POT0 | POT1 | POTM)
|
|
|
|
#define POT_CTRL_PINS (POTINC | POTUD)
|
|
|
|
|
|
|
|
|
|
|
|
static uint32_t Pots[NUM_POTS] = { POT0, POT1, POTM };
|
|
|
|
static int Levels[NUM_POTS] = { 0, 0, 0 };
|
|
|
|
|
|
|
|
|
|
|
|
static void p_offset(int p, int offset)
|
|
|
|
{
|
|
|
|
uint32_t cs;
|
|
|
|
int i;
|
|
|
|
int sign = 0;
|
|
|
|
int u_off = offset;
|
|
|
|
volatile uint32_t now;
|
|
|
|
if((p < 0) || (p > NUM_POTS))
|
|
|
|
return;
|
|
|
|
cs = Pots[p];
|
|
|
|
if (offset < 0) {
|
|
|
|
sign = 1;
|
|
|
|
u_off = 0 - offset;
|
|
|
|
}
|
|
|
|
/* U/!D setting */
|
|
|
|
if (sign)
|
|
|
|
gpio_clear(GPIOD, POTUD);
|
|
|
|
else
|
|
|
|
gpio_set(GPIOD, POTUD);
|
|
|
|
|
|
|
|
for (i = 0; i < u_off; i++) {
|
|
|
|
|
|
|
|
/* /CS on */
|
|
|
|
gpio_clear(GPIOC, cs);
|
|
|
|
DMB();
|
|
|
|
/* /INC on */
|
|
|
|
gpio_clear(GPIOD, POTINC);
|
|
|
|
DMB();
|
|
|
|
/* /INC off */
|
|
|
|
gpio_set(GPIOD, POTINC);
|
|
|
|
/* /CS off first (no store) */
|
|
|
|
gpio_set(GPIOC,cs);
|
|
|
|
//WFI();
|
|
|
|
for (int j = 0; j < 4000; j++)
|
|
|
|
;;
|
|
|
|
}
|
|
|
|
|
|
|
|
Levels[p] += offset;
|
|
|
|
if (Levels[p] > 100)
|
|
|
|
Levels[p] = 100;
|
|
|
|
if (Levels[p] < 0)
|
|
|
|
Levels[p] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void pot_offset(int p, int offset)
|
|
|
|
{
|
|
|
|
if ((Levels[p] + offset) > 100) {
|
|
|
|
offset = 100 - Levels[p];
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((Levels[p] + offset) < 0) {
|
|
|
|
offset = 0 - Levels[p];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (offset == 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
p_offset(p, offset);
|
|
|
|
}
|
|
|
|
|
|
|
|
void pot_init(void)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
rcc_periph_clock_enable(RCC_GPIOC);
|
|
|
|
rcc_periph_clock_enable(RCC_GPIOD);
|
|
|
|
|
|
|
|
gpio_mode_setup(GPIOC, GPIO_MODE_OUTPUT, GPIO_PUPD_PULLUP, POT_CS_PINS);
|
|
|
|
gpio_set_output_options(GPIOC, GPIO_OTYPE_OD, GPIO_OSPEED_100MHZ, POT_CS_PINS);
|
|
|
|
gpio_set(GPIOC, POT_CS_PINS);
|
|
|
|
|
2020-04-08 16:48:35 +02:00
|
|
|
gpio_mode_setup(GPIOD, GPIO_MODE_OUTPUT, GPIO_PUPD_NONE, POT_CTRL_PINS);
|
2020-04-06 21:08:01 +02:00
|
|
|
gpio_set_output_options(GPIOD, GPIO_OTYPE_OD, GPIO_OSPEED_100MHZ, POT_CTRL_PINS);
|
|
|
|
gpio_set(GPIOD, POT_CTRL_PINS);
|
|
|
|
|
|
|
|
for (i = 0; i < NUM_POTS; i++)
|
|
|
|
p_offset(i, -100);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int pot_get(int p)
|
|
|
|
{
|
|
|
|
return Levels[p];
|
|
|
|
}
|
|
|
|
|
|
|
|
void pot_set(int p, int val)
|
|
|
|
{
|
|
|
|
int old = Levels[p];
|
|
|
|
int off;
|
|
|
|
if (val < 0)
|
|
|
|
val = 0;
|
|
|
|
if (val > 100)
|
|
|
|
val = 100;
|
|
|
|
off = val - old;
|
|
|
|
if (off == 0)
|
|
|
|
return;
|
|
|
|
pot_offset(p, off);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|