Compare commits

..

No commits in common. "ff801b378372ae30a8e402c4404ca8aff2b70018" and "f4a67151343fa51fee60de2de702cdefa9a0faec" have entirely different histories.

6 changed files with 1734 additions and 46 deletions

2
.ccls Normal file
View File

@ -0,0 +1,2 @@
%compile_commands.json
--sysroot=/usr/arm-none-eabi/

View File

@ -1,2 +1,5 @@
CompileFlags:
Compiler: /usr/toolchains/arm-none-eabi/13/bin/arm-none-eabi-g++
#Add: [--query-driver=/usr/bin/arm-none-eabi-g++]
Compiler: /usr/bin/arm-none-eabi-g++

1
grep Normal file
View File

@ -0,0 +1 @@
ccls: Unknown command line argument 'main.cc'. Try: 'ccls --help'

1711
profile.log Normal file

File diff suppressed because it is too large Load Diff

View File

@ -2,8 +2,7 @@ add_executable(main
main.cc
)
target_link_libraries(main pico_stdlib hardware_i2c hardware_uart hardware_irq
hardware_gpio)
target_link_libraries(main pico_stdlib hardware_i2c hardware_uart)
pico_enable_stdio_uart(main 0)
pico_enable_stdio_usb(main 1)

View File

@ -2,14 +2,11 @@
#include "hardware/gpio.h"
#include "hardware/i2c.h"
#include "pico/time.h"
#include "pico/types.h"
#include <pico/stdlib.h>
#include <pico/stdio.h>
#include <cstdio>
#include <cstring>
#include <stdio.h>
#include <string.h>
#define ADDR 0x3c
@ -48,30 +45,6 @@ static uint32_t charset[127] = {
0x7c90904c, 0x90b0d090, 0x81816618, 0x00ff0000, 0x81816618, 0x10081008, INVALID_CH,
};
static uint8_t encoder_pos = 0;
void irq_callback(uint gpio, uint32_t events) {
static absolute_time_t time_last = get_absolute_time();
static uint8_t prev = 0;
if (gpio == 19) {
absolute_time_t time_now = get_absolute_time();
if (time_now - time_last < 1000) return;
time_last = time_now;
uint8_t twenty = gpio_get(20);
if (twenty != prev) {
if (twenty == 0) {
if (events & GPIO_IRQ_EDGE_RISE) encoder_pos++;
else encoder_pos--;
} else {
if (events & GPIO_IRQ_EDGE_RISE) encoder_pos--;
else encoder_pos++;
}
prev = twenty;
}
}
}
int main(void) {
stdio_init_all();
@ -80,12 +53,6 @@ int main(void) {
gpio_init(25);
gpio_set_dir(25, GPIO_OUT);
gpio_init(19);
gpio_init(20);
gpio_set_dir(19, GPIO_IN);
gpio_set_dir(20, GPIO_IN);
gpio_set_irq_enabled_with_callback(19, GPIO_IRQ_EDGE_FALL | GPIO_IRQ_EDGE_RISE, true, &irq_callback);
i2c_init(i2c0, 400000);
gpio_init(0);
@ -98,12 +65,15 @@ int main(void) {
busy_wait_ms(100);
disp.fill(0);
while (true) {
disp.fill(0);
disp.put_char(4, 0, (encoder_pos & 0xF) >= 0xA ? (encoder_pos&0xf) - 0xA + 'A':(encoder_pos&0xf)+'0');
disp.put_char(0, 0, ((encoder_pos>>4) & 0xF) >= 0xA? ((encoder_pos>>4) & 0xf) - 0xA + 'A':((encoder_pos>>4)&0xf)+'0');
disp.puts(0, 0, "Hello, World!");
disp.flush();
busy_wait_ms(50);
while (true) {
/*
gpio_put(25, false);
busy_wait_ms(failure ? 50 : 500);
gpio_put(25, true);
busy_wait_ms(failure ? 50 : 500);
*/
}
return 0;
@ -114,9 +84,9 @@ static void write_cmd(uint8_t cmd) {
if (i2c_write_timeout_us(i2c0, ADDR, buf, 2, false, 1000000) < 0) {
failure = true;
std::printf("TX fail\n");
printf("TX fail\n");
} else {
std::printf("TX succ\n");
printf("TX succ\n");
}
}
@ -198,7 +168,9 @@ void ssd1306::flush() {
}
void ssd1306::put_char(uint8_t row, uint8_t col, char c) {
memcpy(m_display_buffer+(1+(row + (128*col))), &charset[c-1], 4);
if (row % 4 != 0) return;
memcpy(&m_display_buffer[1 + (row + (128*col))], &charset[c-1], 4);
}
void ssd1306::puts(uint8_t row, uint8_t col, const char *str) {