Maybe one day GCC will stop being shit at handling __attribute__s
This commit is contained in:
parent
1650820edb
commit
02f55d12d3
16
Core/apu.h
16
Core/apu.h
@ -171,14 +171,14 @@ void GB_set_interference_volume(GB_gameboy_t *gb, double volume);
|
|||||||
void GB_apu_set_sample_callback(GB_gameboy_t *gb, GB_sample_callback_t callback);
|
void GB_apu_set_sample_callback(GB_gameboy_t *gb, GB_sample_callback_t callback);
|
||||||
|
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
bool internal GB_apu_is_DAC_enabled(GB_gameboy_t *gb, unsigned index);
|
internal bool GB_apu_is_DAC_enabled(GB_gameboy_t *gb, unsigned index);
|
||||||
void internal GB_apu_write(GB_gameboy_t *gb, uint8_t reg, uint8_t value);
|
internal void GB_apu_write(GB_gameboy_t *gb, uint8_t reg, uint8_t value);
|
||||||
uint8_t internal GB_apu_read(GB_gameboy_t *gb, uint8_t reg);
|
internal uint8_t GB_apu_read(GB_gameboy_t *gb, uint8_t reg);
|
||||||
void internal GB_apu_div_event(GB_gameboy_t *gb);
|
internal void GB_apu_div_event(GB_gameboy_t *gb);
|
||||||
void internal GB_apu_div_secondary_event(GB_gameboy_t *gb);
|
internal void GB_apu_div_secondary_event(GB_gameboy_t *gb);
|
||||||
void internal GB_apu_init(GB_gameboy_t *gb);
|
internal void GB_apu_init(GB_gameboy_t *gb);
|
||||||
void internal GB_apu_run(GB_gameboy_t *gb);
|
internal void GB_apu_run(GB_gameboy_t *gb);
|
||||||
void internal GB_apu_update_cycles_per_sample(GB_gameboy_t *gb);
|
internal void GB_apu_update_cycles_per_sample(GB_gameboy_t *gb);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* apu_h */
|
#endif /* apu_h */
|
||||||
|
@ -20,7 +20,7 @@ int GB_save_cheats(GB_gameboy_t *gb, const char *path);
|
|||||||
#ifdef GB_DISABLE_CHEATS
|
#ifdef GB_DISABLE_CHEATS
|
||||||
#define GB_apply_cheat(...)
|
#define GB_apply_cheat(...)
|
||||||
#else
|
#else
|
||||||
void internal GB_apply_cheat(GB_gameboy_t *gb, uint16_t address, uint8_t *value);
|
internal void GB_apply_cheat(GB_gameboy_t *gb, uint16_t address, uint8_t *value);
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
#define GB_debugger_add_symbol(gb, bank, address, symbol) ((void)bank, (void)address, (void)symbol)
|
#define GB_debugger_add_symbol(gb, bank, address, symbol) ((void)bank, (void)address, (void)symbol)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
void internal GB_debugger_run(GB_gameboy_t *gb);
|
internal void GB_debugger_run(GB_gameboy_t *gb);
|
||||||
void internal GB_debugger_handle_async_commands(GB_gameboy_t *gb);
|
internal void GB_debugger_handle_async_commands(GB_gameboy_t *gb);
|
||||||
void internal GB_debugger_call_hook(GB_gameboy_t *gb, uint16_t call_addr);
|
internal void GB_debugger_call_hook(GB_gameboy_t *gb, uint16_t call_addr);
|
||||||
void internal GB_debugger_ret_hook(GB_gameboy_t *gb);
|
internal void GB_debugger_ret_hook(GB_gameboy_t *gb);
|
||||||
void internal GB_debugger_test_write_watchpoint(GB_gameboy_t *gb, uint16_t addr, uint8_t value);
|
internal void GB_debugger_test_write_watchpoint(GB_gameboy_t *gb, uint16_t addr, uint8_t value);
|
||||||
void internal GB_debugger_test_read_watchpoint(GB_gameboy_t *gb, uint16_t addr);
|
internal void GB_debugger_test_read_watchpoint(GB_gameboy_t *gb, uint16_t addr);
|
||||||
const GB_bank_symbol_t *internal GB_debugger_find_symbol(GB_gameboy_t *gb, uint16_t addr);
|
internal const GB_bank_symbol_t *GB_debugger_find_symbol(GB_gameboy_t *gb, uint16_t addr);
|
||||||
void internal GB_debugger_add_symbol(GB_gameboy_t *gb, uint16_t bank, uint16_t address, const char *symbol);
|
internal void GB_debugger_add_symbol(GB_gameboy_t *gb, uint16_t bank, uint16_t address, const char *symbol);
|
||||||
#endif /* GB_DISABLE_DEBUGGER */
|
#endif /* GB_DISABLE_DEBUGGER */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#define likely(x) __builtin_expect((x), 1)
|
#define likely(x) __builtin_expect((x), 1)
|
||||||
#define unlikely(x) __builtin_expect((x), 0)
|
#define unlikely(x) __builtin_expect((x), 0)
|
||||||
|
|
||||||
#define internal __attribute__((visibility("hidden")))
|
#define internal __attribute__((visibility("internal")))
|
||||||
|
|
||||||
#if __clang__
|
#if __clang__
|
||||||
#define unrolled _Pragma("unroll")
|
#define unrolled _Pragma("unroll")
|
||||||
|
@ -6,10 +6,10 @@
|
|||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
void internal GB_display_run(GB_gameboy_t *gb, uint8_t cycles);
|
internal void GB_display_run(GB_gameboy_t *gb, uint8_t cycles);
|
||||||
void internal GB_palette_changed(GB_gameboy_t *gb, bool background_palette, uint8_t index);
|
internal void GB_palette_changed(GB_gameboy_t *gb, bool background_palette, uint8_t index);
|
||||||
void internal GB_STAT_update(GB_gameboy_t *gb);
|
internal void GB_STAT_update(GB_gameboy_t *gb);
|
||||||
void internal GB_lcd_off(GB_gameboy_t *gb);
|
internal void GB_lcd_off(GB_gameboy_t *gb);
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
GB_OBJECT_PRIORITY_X,
|
GB_OBJECT_PRIORITY_X,
|
||||||
|
@ -856,7 +856,7 @@ void GB_get_rom_title(GB_gameboy_t *gb, char *title);
|
|||||||
uint32_t GB_get_rom_crc32(GB_gameboy_t *gb);
|
uint32_t GB_get_rom_crc32(GB_gameboy_t *gb);
|
||||||
|
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
void internal GB_borrow_sgb_border(GB_gameboy_t *gb);
|
internal void GB_borrow_sgb_border(GB_gameboy_t *gb);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* GB_h */
|
#endif /* GB_h */
|
||||||
|
@ -20,6 +20,6 @@ void GB_set_key_state_for_player(GB_gameboy_t *gb, GB_key_t index, unsigned play
|
|||||||
void GB_icd_set_joyp(GB_gameboy_t *gb, uint8_t value);
|
void GB_icd_set_joyp(GB_gameboy_t *gb, uint8_t value);
|
||||||
|
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
void internal GB_update_joyp(GB_gameboy_t *gb);
|
internal void GB_update_joyp(GB_gameboy_t *gb);
|
||||||
#endif
|
#endif
|
||||||
#endif /* joypad_h */
|
#endif /* joypad_h */
|
||||||
|
@ -26,8 +26,8 @@ typedef struct {
|
|||||||
|
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
extern const GB_cartridge_t GB_cart_defs[256];
|
extern const GB_cartridge_t GB_cart_defs[256];
|
||||||
void internal GB_update_mbc_mappings(GB_gameboy_t *gb);
|
internal void GB_update_mbc_mappings(GB_gameboy_t *gb);
|
||||||
void internal GB_configure_cart(GB_gameboy_t *gb);
|
internal void GB_configure_cart(GB_gameboy_t *gb);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* MBC_h */
|
#endif /* MBC_h */
|
||||||
|
@ -9,9 +9,9 @@ void GB_set_read_memory_callback(GB_gameboy_t *gb, GB_read_memory_callback_t cal
|
|||||||
uint8_t GB_read_memory(GB_gameboy_t *gb, uint16_t addr);
|
uint8_t GB_read_memory(GB_gameboy_t *gb, uint16_t addr);
|
||||||
void GB_write_memory(GB_gameboy_t *gb, uint16_t addr, uint8_t value);
|
void GB_write_memory(GB_gameboy_t *gb, uint16_t addr, uint8_t value);
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
void internal GB_dma_run(GB_gameboy_t *gb);
|
internal void GB_dma_run(GB_gameboy_t *gb);
|
||||||
void internal GB_hdma_run(GB_gameboy_t *gb);
|
internal void GB_hdma_run(GB_gameboy_t *gb);
|
||||||
void internal GB_trigger_oam_bug(GB_gameboy_t *gb, uint16_t address);
|
internal void GB_trigger_oam_bug(GB_gameboy_t *gb, uint16_t address);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* memory_h */
|
#endif /* memory_h */
|
||||||
|
@ -5,8 +5,8 @@
|
|||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
|
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
void internal GB_rewind_push(GB_gameboy_t *gb);
|
internal void GB_rewind_push(GB_gameboy_t *gb);
|
||||||
void internal GB_rewind_free(GB_gameboy_t *gb);
|
internal void GB_rewind_free(GB_gameboy_t *gb);
|
||||||
#endif
|
#endif
|
||||||
bool GB_rewind_pop(GB_gameboy_t *gb);
|
bool GB_rewind_pop(GB_gameboy_t *gb);
|
||||||
void GB_set_rewind_length(GB_gameboy_t *gb, double seconds);
|
void GB_set_rewind_length(GB_gameboy_t *gb, double seconds);
|
||||||
|
@ -10,7 +10,7 @@ typedef enum {
|
|||||||
} GB_rumble_mode_t;
|
} GB_rumble_mode_t;
|
||||||
|
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
void internal GB_handle_rumble(GB_gameboy_t *gb);
|
internal void GB_handle_rumble(GB_gameboy_t *gb);
|
||||||
#endif
|
#endif
|
||||||
void GB_set_rumble_mode(GB_gameboy_t *gb, GB_rumble_mode_t mode);
|
void GB_set_rumble_mode(GB_gameboy_t *gb, GB_rumble_mode_t mode);
|
||||||
|
|
||||||
|
@ -36,8 +36,8 @@ static inline uint32_t state_magic(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* For internal in-memory save states (rewind, debugger) that do not need BESS */
|
/* For internal in-memory save states (rewind, debugger) that do not need BESS */
|
||||||
size_t internal GB_get_save_state_size_no_bess(GB_gameboy_t *gb);
|
internal size_t GB_get_save_state_size_no_bess(GB_gameboy_t *gb);
|
||||||
void internal GB_save_state_to_buffer_no_bess(GB_gameboy_t *gb, uint8_t *buffer);
|
internal void GB_save_state_to_buffer_no_bess(GB_gameboy_t *gb, uint8_t *buffer);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* save_state_h */
|
#endif /* save_state_h */
|
||||||
|
@ -58,9 +58,9 @@ struct GB_sgb_s {
|
|||||||
uint8_t received_header[0x54];
|
uint8_t received_header[0x54];
|
||||||
};
|
};
|
||||||
|
|
||||||
void internal GB_sgb_write(GB_gameboy_t *gb, uint8_t value);
|
internal void GB_sgb_write(GB_gameboy_t *gb, uint8_t value);
|
||||||
void internal GB_sgb_render(GB_gameboy_t *gb);
|
internal void GB_sgb_render(GB_gameboy_t *gb);
|
||||||
void internal GB_sgb_load_default_data(GB_gameboy_t *gb);
|
internal void GB_sgb_load_default_data(GB_gameboy_t *gb);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
void GB_cpu_disassemble(GB_gameboy_t *gb, uint16_t pc, uint16_t count);
|
void GB_cpu_disassemble(GB_gameboy_t *gb, uint16_t pc, uint16_t count);
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
void internal GB_cpu_run(GB_gameboy_t *gb);
|
internal void GB_cpu_run(GB_gameboy_t *gb);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* sm83_cpu_h */
|
#endif /* sm83_cpu_h */
|
||||||
|
@ -27,12 +27,12 @@ typedef struct {
|
|||||||
} GB_reversed_symbol_map_t;
|
} GB_reversed_symbol_map_t;
|
||||||
|
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
void internal GB_reversed_map_add_symbol(GB_reversed_symbol_map_t *map, uint16_t bank, GB_bank_symbol_t *symbol);
|
internal void GB_reversed_map_add_symbol(GB_reversed_symbol_map_t *map, uint16_t bank, GB_bank_symbol_t *symbol);
|
||||||
const GB_symbol_t *internal GB_reversed_map_find_symbol(GB_reversed_symbol_map_t *map, const char *name);
|
internal const GB_symbol_t *GB_reversed_map_find_symbol(GB_reversed_symbol_map_t *map, const char *name);
|
||||||
GB_bank_symbol_t *internal GB_map_add_symbol(GB_symbol_map_t *map, uint16_t addr, const char *name);
|
internal GB_bank_symbol_t *GB_map_add_symbol(GB_symbol_map_t *map, uint16_t addr, const char *name);
|
||||||
const GB_bank_symbol_t *internal GB_map_find_symbol(GB_symbol_map_t *map, uint16_t addr);
|
internal const GB_bank_symbol_t *GB_map_find_symbol(GB_symbol_map_t *map, uint16_t addr);
|
||||||
GB_symbol_map_t *internal GB_map_alloc(void);
|
internal GB_symbol_map_t *GB_map_alloc(void);
|
||||||
void internal GB_map_free(GB_symbol_map_t *map);
|
internal void GB_map_free(GB_symbol_map_t *map);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* symbol_hash_h */
|
#endif /* symbol_hash_h */
|
||||||
|
@ -3,11 +3,11 @@
|
|||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
|
|
||||||
#ifdef GB_INTERNAL
|
#ifdef GB_INTERNAL
|
||||||
void internal GB_advance_cycles(GB_gameboy_t *gb, uint8_t cycles);
|
internal void GB_advance_cycles(GB_gameboy_t *gb, uint8_t cycles);
|
||||||
void internal GB_emulate_timer_glitch(GB_gameboy_t *gb, uint8_t old_tac, uint8_t new_tac);
|
internal void GB_emulate_timer_glitch(GB_gameboy_t *gb, uint8_t old_tac, uint8_t new_tac);
|
||||||
bool internal GB_timing_sync_turbo(GB_gameboy_t *gb); /* Returns true if should skip frame */
|
internal bool GB_timing_sync_turbo(GB_gameboy_t *gb); /* Returns true if should skip frame */
|
||||||
void internal GB_timing_sync(GB_gameboy_t *gb);
|
internal void GB_timing_sync(GB_gameboy_t *gb);
|
||||||
void internal GB_set_internal_div_counter(GB_gameboy_t *gb, uint16_t value);
|
internal void GB_set_internal_div_counter(GB_gameboy_t *gb, uint16_t value);
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
GB_TIMA_RUNNING = 0,
|
GB_TIMA_RUNNING = 0,
|
||||||
|
Loading…
Reference in New Issue
Block a user