Merge branch 'keymap_section'
This commit is contained in:
		| @@ -68,6 +68,14 @@ ifdef BACKLIGHT_ENABLE | ||||
|     OPT_DEFS += -DBACKLIGHT_ENABLE | ||||
| endif | ||||
|  | ||||
| ifdef KEYMAP_SECTION_ENABLE | ||||
|     OPT_DEFS += -DKEYMAP_SECTION | ||||
|     EXTRALDFLAGS = -Wl,-L$(TOP_DIR),-Tldscript_keymap_avr5.x | ||||
| endif | ||||
|  | ||||
| # Version string | ||||
| OPT_DEFS += -DVERSION=$(shell (git describe --dirty || echo 'unknown') 2> /dev/null) | ||||
|  | ||||
|  | ||||
| # Search Path | ||||
| VPATH += $(TOP_DIR)/common | ||||
|   | ||||
| @@ -252,9 +252,10 @@ static bool command_common(uint8_t code) | ||||
|         case KC_V: // print version & information | ||||
|             print("\n\n----- Version -----\n"); | ||||
|             print(STR(DESCRIPTION) "\n"); | ||||
|             print(STR(MANUFACTURER) "(" STR(VENDOR_ID) ")/"); | ||||
|             print(STR(PRODUCT) "(" STR(PRODUCT_ID) ") "); | ||||
|             print("VERSION: " STR(DEVICE_VER) "\n"); | ||||
|             print("VID: " STR(VENDOR_ID) "(" STR(MANUFACTURER) ") PID: " STR(PRODUCT_ID) "(" STR(PRODUCT) ") VER: " STR(DEVICE_VER) "\n"); | ||||
|             print("SRC: " STR(VERSION) "\n"); | ||||
|             print("GCC: " STR(__GNUC__) "." STR(__GNUC_MINOR__) "." STR(__GNUC_PATCHLEVEL__) "\n"); | ||||
|             print("AVR-LIBC: " __AVR_LIBC_VERSION_STRING__ "\n"); | ||||
|             break; | ||||
|         case KC_T: // print timer | ||||
|             print_val_hex32(timer_count); | ||||
|   | ||||
| @@ -111,12 +111,13 @@ OPT_DEFS += -DBOOTLOADER_SIZE=4096 | ||||
| # Build Options | ||||
| #   comment out to disable the options. | ||||
| # | ||||
| BOOTMAGIC_ENABLE = yes	# Virtual DIP switch configuration | ||||
| MOUSEKEY_ENABLE = yes	# Mouse keys | ||||
| EXTRAKEY_ENABLE = yes	# Audio control and System control | ||||
| CONSOLE_ENABLE = yes	# Console for debug | ||||
| COMMAND_ENABLE = yes    # Commands for debug and configuration | ||||
| NKRO_ENABLE = yes	# USB Nkey Rollover | ||||
| BOOTMAGIC_ENABLE = yes		# Virtual DIP switch configuration | ||||
| MOUSEKEY_ENABLE = yes		# Mouse keys | ||||
| EXTRAKEY_ENABLE = yes		# Audio control and System control | ||||
| CONSOLE_ENABLE = yes		# Console for debug | ||||
| COMMAND_ENABLE = yes    	# Commands for debug and configuration | ||||
| NKRO_ENABLE = yes		# USB Nkey Rollover | ||||
| KEYMAP_SECTION_ENABLE = yes	# fixed address keymap for keymap editor | ||||
|  | ||||
|  | ||||
| # Search Path | ||||
| @@ -128,4 +129,5 @@ include $(TOP_DIR)/common.mk | ||||
| include $(TOP_DIR)/rules.mk | ||||
|  | ||||
| debug-on: EXTRAFLAGS += -DDEBUG | ||||
| #debug-on: EXTRAFLAGS += -DDEBUG -DDEBUG_ACTION | ||||
| debug-on: all | ||||
|   | ||||
| @@ -48,8 +48,11 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|     { KC_##K70, KC_##K71, KC_##K72, KC_##K73, KC_##K74, KC_##K75, KC_##K76, KC_NO    } \ | ||||
| } | ||||
|  | ||||
|  | ||||
| static const uint8_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
| #ifdef KEYMAP_SECTION | ||||
| const uint8_t keymaps[][MATRIX_ROWS][MATRIX_COLS] __attribute__ ((section (".keymap.keymaps"))) = { | ||||
| #else | ||||
| static const uint8_t keymaps[][MATRIX_ROWS][MATRIX_COLS] PROGMEM = { | ||||
| #endif | ||||
|     /* Layer 0: Default Layer | ||||
|      * ,-----------------------------------------------------------. | ||||
|      * |Esc|  1|  2|  3|  4|  5|  6|  7|  8|  9|  0|  -|  =|  \|  `| | ||||
| @@ -186,7 +189,11 @@ enum macro_id { | ||||
| /* | ||||
|  * Fn action definition | ||||
|  */ | ||||
| static const uint16_t PROGMEM fn_actions[] = { | ||||
| #ifdef KEYMAP_SECTION | ||||
| const uint16_t fn_actions[] __attribute__ ((section (".keymap.fn_actions"))) = { | ||||
| #else | ||||
| static const uint16_t fn_actions[] PROGMEM = { | ||||
| #endif | ||||
|     [0] = ACTION_DEFAULT_LAYER_SET(0),                // Default layer(not used) | ||||
|     [1] = ACTION_LAYER_TAP_TOGGLE(1),                 // HHKB layer(toggle with 5 taps) | ||||
|     [2] = ACTION_LAYER_TAP_KEY(2, KC_SLASH),          // Cursor layer with Slash* | ||||
| @@ -310,10 +317,6 @@ uint8_t keymap_key_to_keycode(uint8_t layer, key_t key) | ||||
| action_t keymap_fn_to_action(uint8_t keycode) | ||||
| { | ||||
|     action_t action; | ||||
|     if (FN_INDEX(keycode) < sizeof(fn_actions) / sizeof(fn_actions[0])) { | ||||
|         action.code = pgm_read_word(&fn_actions[FN_INDEX(keycode)]); | ||||
|     } else { | ||||
|         action.code = ACTION_NO; | ||||
|     } | ||||
|     action.code = pgm_read_word(&fn_actions[FN_INDEX(keycode)]); | ||||
|     return action; | ||||
| } | ||||
|   | ||||
							
								
								
									
										268
									
								
								ldscript_keymap_avr5.x
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										268
									
								
								ldscript_keymap_avr5.x
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,268 @@ | ||||
| /*  | ||||
|  * linker script for configurable keymap | ||||
|  * | ||||
|  * This adds keymap section which places keymap at fixed address and | ||||
|  * is based on binutils-avr ldscripts(/usr/lib/ldscripts/avr5.x). | ||||
|  */ | ||||
| OUTPUT_FORMAT("elf32-avr","elf32-avr","elf32-avr") | ||||
| OUTPUT_ARCH(avr:5) | ||||
| MEMORY | ||||
| { | ||||
|   /* With keymap section  | ||||
|    * | ||||
|    * Flash Map of ATMega32U4(32KB) | ||||
|    * +------------+ 0x0000 | ||||
|    * | .vectors   | | ||||
|    * | .progmem   | | ||||
|    * | .init0-9   | > text region | ||||
|    * | .text      | | ||||
|    * | .fini9-0   | | ||||
|    * |            | | ||||
|    * |------------| _etext | ||||
|    * | .data      | | ||||
|    * | .bss       | > data region | ||||
|    * | .noinit    | | ||||
|    * |            | | ||||
|    * |------------| 0x6800 | ||||
|    * | .keymap    | > keymap region(2KB) | ||||
|    * |------------| 0x7000 | ||||
|    * | bootloader | 4KB | ||||
|    * +------------+ 0x7FFF | ||||
|    */ | ||||
|   text   (rx)   : ORIGIN = 0, LENGTH = 128K | ||||
|   keymap (rw!x) : ORIGIN = 0x6800, LENGTH = 2K | ||||
|   data   (rw!x) : ORIGIN = 0x800060, LENGTH = 0xffa0 | ||||
|   eeprom (rw!x) : ORIGIN = 0x810000, LENGTH = 64K | ||||
|   fuse      (rw!x) : ORIGIN = 0x820000, LENGTH = 1K | ||||
|   lock      (rw!x) : ORIGIN = 0x830000, LENGTH = 1K | ||||
|   signature (rw!x) : ORIGIN = 0x840000, LENGTH = 1K | ||||
| } | ||||
| SECTIONS | ||||
| { | ||||
|   /* Read-only sections, merged into text segment: */ | ||||
|   .hash          : { *(.hash)		} | ||||
|   .dynsym        : { *(.dynsym)		} | ||||
|   .dynstr        : { *(.dynstr)		} | ||||
|   .gnu.version   : { *(.gnu.version)	} | ||||
|   .gnu.version_d   : { *(.gnu.version_d)	} | ||||
|   .gnu.version_r   : { *(.gnu.version_r)	} | ||||
|   .rel.init      : { *(.rel.init)		} | ||||
|   .rela.init     : { *(.rela.init)	} | ||||
|   .rel.text      : | ||||
|     { | ||||
|       *(.rel.text) | ||||
|       *(.rel.text.*) | ||||
|       *(.rel.gnu.linkonce.t*) | ||||
|     } | ||||
|   .rela.text     : | ||||
|     { | ||||
|       *(.rela.text) | ||||
|       *(.rela.text.*) | ||||
|       *(.rela.gnu.linkonce.t*) | ||||
|     } | ||||
|   .rel.fini      : { *(.rel.fini)		} | ||||
|   .rela.fini     : { *(.rela.fini)	} | ||||
|   .rel.rodata    : | ||||
|     { | ||||
|       *(.rel.rodata) | ||||
|       *(.rel.rodata.*) | ||||
|       *(.rel.gnu.linkonce.r*) | ||||
|     } | ||||
|   .rela.rodata   : | ||||
|     { | ||||
|       *(.rela.rodata) | ||||
|       *(.rela.rodata.*) | ||||
|       *(.rela.gnu.linkonce.r*) | ||||
|     } | ||||
|   .rel.data      : | ||||
|     { | ||||
|       *(.rel.data) | ||||
|       *(.rel.data.*) | ||||
|       *(.rel.gnu.linkonce.d*) | ||||
|     } | ||||
|   .rela.data     : | ||||
|     { | ||||
|       *(.rela.data) | ||||
|       *(.rela.data.*) | ||||
|       *(.rela.gnu.linkonce.d*) | ||||
|     } | ||||
|   .rel.ctors     : { *(.rel.ctors)	} | ||||
|   .rela.ctors    : { *(.rela.ctors)	} | ||||
|   .rel.dtors     : { *(.rel.dtors)	} | ||||
|   .rela.dtors    : { *(.rela.dtors)	} | ||||
|   .rel.got       : { *(.rel.got)		} | ||||
|   .rela.got      : { *(.rela.got)		} | ||||
|   .rel.bss       : { *(.rel.bss)		} | ||||
|   .rela.bss      : { *(.rela.bss)		} | ||||
|   .rel.plt       : { *(.rel.plt)		} | ||||
|   .rela.plt      : { *(.rela.plt)		} | ||||
|   /* Internal text space or external memory.  */ | ||||
|   .text   : | ||||
|   { | ||||
|     *(.vectors) | ||||
|     KEEP(*(.vectors)) | ||||
|     /* For data that needs to reside in the lower 64k of progmem.  */ | ||||
|     *(.progmem.gcc*) | ||||
|     *(.progmem*) | ||||
|     . = ALIGN(2); | ||||
|      __trampolines_start = . ; | ||||
|     /* The jump trampolines for the 16-bit limited relocs will reside here.  */ | ||||
|     *(.trampolines) | ||||
|     *(.trampolines*) | ||||
|      __trampolines_end = . ; | ||||
|     /* For future tablejump instruction arrays for 3 byte pc devices. | ||||
|        We don't relax jump/call instructions within these sections.  */ | ||||
|     *(.jumptables) | ||||
|     *(.jumptables*) | ||||
|     /* For code that needs to reside in the lower 128k progmem.  */ | ||||
|     *(.lowtext) | ||||
|     *(.lowtext*) | ||||
|      __ctors_start = . ; | ||||
|      *(.ctors) | ||||
|      __ctors_end = . ; | ||||
|      __dtors_start = . ; | ||||
|      *(.dtors) | ||||
|      __dtors_end = . ; | ||||
|     KEEP(SORT(*)(.ctors)) | ||||
|     KEEP(SORT(*)(.dtors)) | ||||
|     /* From this point on, we don't bother about wether the insns are | ||||
|        below or above the 16 bits boundary.  */ | ||||
|     *(.init0)  /* Start here after reset.  */ | ||||
|     KEEP (*(.init0)) | ||||
|     *(.init1) | ||||
|     KEEP (*(.init1)) | ||||
|     *(.init2)  /* Clear __zero_reg__, set up stack pointer.  */ | ||||
|     KEEP (*(.init2)) | ||||
|     *(.init3) | ||||
|     KEEP (*(.init3)) | ||||
|     *(.init4)  /* Initialize data and BSS.  */ | ||||
|     KEEP (*(.init4)) | ||||
|     *(.init5) | ||||
|     KEEP (*(.init5)) | ||||
|     *(.init6)  /* C++ constructors.  */ | ||||
|     KEEP (*(.init6)) | ||||
|     *(.init7) | ||||
|     KEEP (*(.init7)) | ||||
|     *(.init8) | ||||
|     KEEP (*(.init8)) | ||||
|     *(.init9)  /* Call main().  */ | ||||
|     KEEP (*(.init9)) | ||||
|     *(.text) | ||||
|     . = ALIGN(2); | ||||
|     *(.text.*) | ||||
|     . = ALIGN(2); | ||||
|     *(.fini9)  /* _exit() starts here.  */ | ||||
|     KEEP (*(.fini9)) | ||||
|     *(.fini8) | ||||
|     KEEP (*(.fini8)) | ||||
|     *(.fini7) | ||||
|     KEEP (*(.fini7)) | ||||
|     *(.fini6)  /* C++ destructors.  */ | ||||
|     KEEP (*(.fini6)) | ||||
|     *(.fini5) | ||||
|     KEEP (*(.fini5)) | ||||
|     *(.fini4) | ||||
|     KEEP (*(.fini4)) | ||||
|     *(.fini3) | ||||
|     KEEP (*(.fini3)) | ||||
|     *(.fini2) | ||||
|     KEEP (*(.fini2)) | ||||
|     *(.fini1) | ||||
|     KEEP (*(.fini1)) | ||||
|     *(.fini0)  /* Infinite loop after program termination.  */ | ||||
|     KEEP (*(.fini0)) | ||||
|      _etext = . ; | ||||
|   }  > text | ||||
|   .data	  : AT (ADDR (.text) + SIZEOF (.text)) | ||||
|   { | ||||
|      PROVIDE (__data_start = .) ; | ||||
|     *(.data) | ||||
|     *(.data*) | ||||
|     *(.rodata)  /* We need to include .rodata here if gcc is used */ | ||||
|     *(.rodata*) /* with -fdata-sections.  */ | ||||
|     *(.gnu.linkonce.d*) | ||||
|     . = ALIGN(2); | ||||
|      _edata = . ; | ||||
|      PROVIDE (__data_end = .) ; | ||||
|   }  > data | ||||
|   .bss   : AT (ADDR (.bss)) | ||||
|   { | ||||
|      PROVIDE (__bss_start = .) ; | ||||
|     *(.bss) | ||||
|     *(.bss*) | ||||
|     *(COMMON) | ||||
|      PROVIDE (__bss_end = .) ; | ||||
|   }  > data | ||||
|    __data_load_start = LOADADDR(.data); | ||||
|    __data_load_end = __data_load_start + SIZEOF(.data); | ||||
|   /* Global data not cleared after reset.  */ | ||||
|   .noinit  : | ||||
|   { | ||||
|      PROVIDE (__noinit_start = .) ; | ||||
|     *(.noinit*) | ||||
|      PROVIDE (__noinit_end = .) ; | ||||
|      _end = . ; | ||||
|      PROVIDE (__heap_start = .) ; | ||||
|   }  > data | ||||
|   /* keymap region is located at end of flash | ||||
|    * .fn_actions        Fn actions definitions | ||||
|    * .keymaps           Mapping layers | ||||
|    */ | ||||
|   .keymap : | ||||
|   { | ||||
|     PROVIDE(__keymap_start = .) ; | ||||
|     *(.keymap.fn_actions)   /* 32*actions = 64bytes */ | ||||
|     . = ALIGN(0x40);  | ||||
|     *(.keymap.keymaps)      /* rest of .keymap section */ | ||||
|     *(.keymap*) | ||||
|     /* . = ALIGN(0x800); */ /* keymap section takes 2KB- */ | ||||
|   } > keymap = 0x00         /* zero fill */ | ||||
|   .eeprom  : | ||||
|   { | ||||
|     *(.eeprom*) | ||||
|      __eeprom_end = . ; | ||||
|   }  > eeprom | ||||
|   .fuse  : | ||||
|   { | ||||
|     KEEP(*(.fuse)) | ||||
|     KEEP(*(.lfuse)) | ||||
|     KEEP(*(.hfuse)) | ||||
|     KEEP(*(.efuse)) | ||||
|   }  > fuse | ||||
|   .lock  : | ||||
|   { | ||||
|     KEEP(*(.lock*)) | ||||
|   }  > lock | ||||
|   .signature  : | ||||
|   { | ||||
|     KEEP(*(.signature*)) | ||||
|   }  > signature | ||||
|   /* Stabs debugging sections.  */ | ||||
|   .stab 0 : { *(.stab) } | ||||
|   .stabstr 0 : { *(.stabstr) } | ||||
|   .stab.excl 0 : { *(.stab.excl) } | ||||
|   .stab.exclstr 0 : { *(.stab.exclstr) } | ||||
|   .stab.index 0 : { *(.stab.index) } | ||||
|   .stab.indexstr 0 : { *(.stab.indexstr) } | ||||
|   .comment 0 : { *(.comment) } | ||||
|   /* DWARF debug sections. | ||||
|      Symbols in the DWARF debugging sections are relative to the beginning | ||||
|      of the section so we begin them at 0.  */ | ||||
|   /* DWARF 1 */ | ||||
|   .debug          0 : { *(.debug) } | ||||
|   .line           0 : { *(.line) } | ||||
|   /* GNU DWARF 1 extensions */ | ||||
|   .debug_srcinfo  0 : { *(.debug_srcinfo) } | ||||
|   .debug_sfnames  0 : { *(.debug_sfnames) } | ||||
|   /* DWARF 1.1 and DWARF 2 */ | ||||
|   .debug_aranges  0 : { *(.debug_aranges) } | ||||
|   .debug_pubnames 0 : { *(.debug_pubnames) } | ||||
|   /* DWARF 2 */ | ||||
|   .debug_info     0 : { *(.debug_info) *(.gnu.linkonce.wi.*) } | ||||
|   .debug_abbrev   0 : { *(.debug_abbrev) } | ||||
|   .debug_line     0 : { *(.debug_line) } | ||||
|   .debug_frame    0 : { *(.debug_frame) } | ||||
|   .debug_str      0 : { *(.debug_str) } | ||||
|   .debug_loc      0 : { *(.debug_loc) } | ||||
|   .debug_macinfo  0 : { *(.debug_macinfo) } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user