mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-10-25 03:29:59 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			100 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Introduction
 | |
| 
 | |
| Your computer keyboard has a processor inside of it, not unlike the one inside your computer. This processor runs software that is responsible for detecting button presses and sending reports about the state of the keyboard when they are pressed or released. QMK fills the role of that software, detecting button presses and passing that information on to the host computer. When you build your custom layout you are creating the equivalent of an .exe for your keyboard.
 | |
| 
 | |
| QMK tries to put a lot of power into your hands by making easy things easy, and hard things possible. You don't have to know how to program to create powerful layouts, you only have to follow a few simple syntax rules.
 | |
| 
 | |
| # Getting Started
 | |
| 
 | |
| Before you can build keymaps you need to install some software and setup your build environment. This only has to be done one time no matter how many keyboards you want to compile firmware for.
 | |
| 
 | |
| ## Download Software
 | |
| 
 | |
| ### Text Editor
 | |
| 
 | |
| You'll need a program that can edit and save **plain text** files. If you are on Windows you can make due with Notepad, and on Linux you can use Gedit, both of which are simple but functional text editors. On macOS be careful with TextEdit.app, it will not save plain text files unless you make sure to select "Make Plain text" from the "Format" menu, or you can use another program such as Sublime Text.
 | |
| 
 | |
| ?> Not sure which text editor to use? Laurence Bradford wrote [a great introduction](https://learntocodewith.me/programming/basics/text-editors/) to the subject.
 | |
| 
 | |
| ### QMK Toolbox
 | |
| 
 | |
| QMK Toolbox is an optional graphical Windows and macOS program that allows you to both program and debug your custom keyboard. You will likely prefer it to easily flash your keyboard and receive the debugging messages that your keyboard will print.
 | |
| 
 | |
| Download the files from the links below:
 | |
| 
 | |
| For Windows: "qmk_toolbox.exe" or "qmk_toolbox_install.exe" (with installer)
 | |
| 
 | |
| For Mac: "QMK.Toolbox.app.zip" or "QMK.Toolbox.pkg" (with installer)
 | |
| 
 | |
| * [Newest Release](https://github.com/qmk/qmk_toolbox/releases/latest)
 | |
| * [Source Code](https://github.com/qmk/qmk_toolbox/)
 | |
| 
 | |
| ## Environment Setup
 | |
| 
 | |
| We've tried to make QMK as easy to setup as possible. You only have to prepare your Linux or Unix environment and let QMK install the rest.
 | |
| 
 | |
| ?> If you haven't worked with the Linux/Unix command line before there are a few basic concepts and commands you should learn. These resources will teach you enough to work with QMK:<br>
 | |
| [Must Know Linux Commands](https://www.guru99.com/must-know-linux-commands.html)<br>
 | |
| [Some Basic Unix Commands](https://www.tjhsst.edu/~dhyatt/superap/unixcmd.html)
 | |
| 
 | |
| ### Windows
 | |
| 
 | |
| You will need to install msys2 and git.
 | |
| 
 | |
| * Follow the installation instructions on the msys2 homepage: http://www.msys2.org
 | |
| * Close any open msys2 terminals, and open a new terminal
 | |
| * Install git by running this command: `pacman -S git`
 | |
| 
 | |
| ### macOS
 | |
| 
 | |
| You will need to install homebrew. Follow the instructions on the homebrew homepage: https://brew.sh
 | |
| 
 | |
| After homebrew is installed continue with "Download QMK", following step "Setup QMK" runs a script that will install other packages.
 | |
| 
 | |
| ### Linux
 | |
| 
 | |
| You will need to install git. It's extremely likely you already have it, but if not one of the following commands should install it:
 | |
| 
 | |
| * Debian/Ubuntu/Devuan: `apt-get install git`
 | |
| * Fedora/Redhat/Centos: `yum install git`
 | |
| * Arch: `pacman -S git`
 | |
| 
 | |
| ## Download QMK
 | |
| 
 | |
| Once you have setup your Linux/Unix environment you are ready to download QMK. We will do this by using git to "clone" the QMK repository. Open a Terminal or MSYS2 Console window and leave it open for the remainder of this guide. Inside that window run these two commands:
 | |
| 
 | |
|     git clone https://github.com/qmk/qmk_firmware.git
 | |
|     cd qmk_firmware
 | |
| 
 | |
| ?> If you already know [how to use GitHub](getting_started_github.md) we recommend you create and clone your own fork instead. If you don't know what that means you can safely ignore this message.
 | |
| 
 | |
| ## Setup QMK
 | |
| 
 | |
| QMK comes with a script to help you setup the rest of what you'll need. You should run it now by typing in this command:
 | |
| 
 | |
|     ./util/qmk_install.sh
 | |
| 
 | |
| ## Test Your Build Environment
 | |
| 
 | |
| Now that your QMK build environment is setup you can build a firmware for your keyboard. Start by trying to build the default layout for your keyboard. You should be able to do that with a command in this format:
 | |
| 
 | |
|     make <keyboard>:default
 | |
| 
 | |
| For example, to build a firmware for a Clueboard 66% use:
 | |
| 
 | |
|     make clueboard/66/rev3:default
 | |
| 
 | |
| When it is done you should have a lot of output that ends similar to this:
 | |
| 
 | |
| ```
 | |
| Linking: .build/clueboard_66_rev2_default.elf                                                       [OK]
 | |
| Creating load file for flashing: .build/clueboard_66_rev2_default.hex                               [OK]
 | |
| Copying clueboard_66_rev2_default.hex to qmk_firmware folder                                        [OK]
 | |
| Checking file size of clueboard_66_rev2_default.hex                                                 [OK]
 | |
|  * File size is fine - 25174/28672
 | |
| ```
 | |
| 
 | |
| ## Creating Your Layout
 | |
| 
 | |
| Now you are ready to create your own personal layout. Move on to [Building Your First Firmware](newbs_building_firmware.md) for that.
 | 
