~ruther/qmk_firmware

b5bcd5b0a18079df1252a718588255c62d24a054 — Joel Challis 4 years ago 145d89a
Refactor some platform dependent logic (#13675)

M quantum/audio/luts.h => quantum/audio/luts.h +2 -8
@@ 16,14 16,8 @@

#pragma once

#if defined(__AVR__)
#    include <avr/io.h>
#    include <avr/interrupt.h>
#    include <avr/pgmspace.h>
#else
#    include <ch.h>
#    include <hal.h>
#endif
#include <float.h>
#include <stdint.h>

#define VIBRATO_LUT_LENGTH 20


M quantum/audio/voices.h => quantum/audio/voices.h +0 -3
@@ 18,9 18,6 @@

#include <stdint.h>
#include <stdbool.h>
#if defined(__AVR__)
#    include <avr/io.h>
#endif
#include "wait.h"
#include "luts.h"


M quantum/keymap_common.c => quantum/keymap_common.c +0 -4
@@ 19,10 19,6 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
#include "report.h"
#include "keycode.h"
#include "action_layer.h"
#if defined(__AVR__)
#    include <util/delay.h>
#    include <stdio.h>
#endif
#include "action.h"
#include "action_macro.h"
#include "debug.h"

M quantum/quantum.h => quantum/quantum.h +1 -10
@@ 15,16 15,7 @@
 */
#pragma once

#if defined(__AVR__)
#    include <avr/pgmspace.h>
#    include <avr/io.h>
#    include <avr/interrupt.h>
#endif
#if defined(PROTOCOL_CHIBIOS)
#    include <hal.h>
#    include "chibios_config.h"
#endif

#include "platform.h"
#include "wait.h"
#include "matrix.h"
#include "keymap.h"

M quantum/rgblight.c => quantum/rgblight.c +3 -11
@@ 16,17 16,6 @@
#include <math.h>
#include <string.h>
#include <stdlib.h>
#ifdef __AVR__
#    include <avr/eeprom.h>
#    include <avr/interrupt.h>
#endif
#ifdef EEPROM_ENABLE
#    include "eeprom.h"
#endif
#ifdef STM32_EEPROM_ENABLE
#    include <hal.h>
#    include "eeprom_stm32.h"
#endif
#include "wait.h"
#include "progmem.h"
#include "sync_timer.h"


@@ 35,6 24,9 @@
#include "debug.h"
#include "led_tables.h"
#include <lib/lib8tion/lib8tion.h>
#ifdef EEPROM_ENABLE
#    include "eeprom.h"
#endif
#ifdef VELOCIKEY_ENABLE
#    include "velocikey.h"
#endif

M quantum/rgblight.h => quantum/rgblight.h +1 -4
@@ 170,15 170,12 @@ enum RGBLIGHT_EFFECT_MODE {

#include <stdint.h>
#include <stdbool.h>
#include "progmem.h"
#include "eeconfig.h"
#include "ws2812.h"
#include "color.h"
#include "rgblight_list.h"

#if defined(__AVR__)
#    include <avr/pgmspace.h>
#endif

#ifdef RGBLIGHT_LAYERS
typedef struct {
    uint8_t index;  // The first LED to light

A tmk_core/common/arm_atsam/platform.h => tmk_core/common/arm_atsam/platform.h +18 -0
@@ 0,0 1,18 @@
/* Copyright 2021 QMK
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
#pragma once

// here just to please the build

A tmk_core/common/avr/platform.h => tmk_core/common/avr/platform.h +20 -0
@@ 0,0 1,20 @@
/* Copyright 2021 QMK
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
#pragma once

#include <avr/pgmspace.h>
#include <avr/io.h>
#include <avr/interrupt.h>

A tmk_core/common/chibios/platform.h => tmk_core/common/chibios/platform.h +19 -0
@@ 0,0 1,19 @@
/* Copyright 2021 QMK
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
#pragma once

#include <hal.h>
#include "chibios_config.h"

M tmk_core/common/print.h => tmk_core/common/print.h +1 -1
@@ 47,7 47,7 @@ void print_set_sendchar(sendchar_func_t func);
#        define uprintln(s) printf(s "\r\n")
#        define uprintf printf

#    endif /* __AVR__ / PROTOCOL_CHIBIOS / PROTOCOL_ARM_ATSAM */
#    endif /* __has_include_next("_print.h") */
#else      /* NO_PRINT */
#    undef xprintf
// Remove print defines

M tmk_core/common/timer.h => tmk_core/common/timer.h +0 -5
@@ 18,11 18,6 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
#pragma once

#include <stdint.h>
#include <stdbool.h>

#if defined(__AVR__)
#    include "avr/timer_avr.h"
#endif

#define TIMER_DIFF(a, b, max) ((max == UINT8_MAX) ? ((uint8_t)((a) - (b))) : ((max == UINT16_MAX) ? ((uint16_t)((a) - (b))) : ((max == UINT32_MAX) ? ((uint32_t)((a) - (b))) : ((a) >= (b) ? (a) - (b) : (max) + 1 - (b) + (a)))))
#define TIMER_DIFF_8(a, b) TIMER_DIFF(a, b, UINT8_MAX)