KwikStik Demo Lab (Rev 0.5)

Download as pdf or txt
Download as pdf or txt
You are on page 1of 11

Kinetis KwikStik Demo Software

Lab Guide
Rev. 0.5

Freescale Semiconductor Inc.

KWIKSTIKDEMOSWLG

Table of Contents
1 Purpose ............................................................................................................... 3 2 Demonstration Software Revisions ...................................................................... 3 3 Before You Start .................................................................................................. 3 4 Installing the Demonstration Software ................................................................ 3 5 Using IAR Embedded Workbench ........................................................................ 4 6 Using CodeWarrior 10.2 ....................................................................................... 5 7 Running the Demos ............................................................................................. 8
7.1 Sound Recorder.......................................................................................................................... 9 7.2 Remote Control .......................................................................................................................... 9 7.3 USB Mouse (HID) ........................................................................................................................ 9 7.4 Fretris ....................................................................................................................................... 10

KWIKSTIKDEMOSWLG

Kinetis KwikStik Demo Software Lab Guide Rev. 0.5

Page 2 of 11

Purpose

This lab document describes how to compile, program and run the Kinetis KwikStik Demo Software. The demonstration software includes projects for IAR Embedded Workbench for ARM version 6.10.5 and version 6.20.3, and CodeWarrior for Microcontrollers version 10.2. For information on the KwikStik hardware and software please refer to the KwikStik Quick Start Guide and the KwikStik Users Manual.

Demonstration Software Revisions

There have been several revisions of the KwikStik Demo Software. The current release is version 1.5. The changes are detailed below. Version 1.2 Original release; pre-flashed on Version 3 and Version 4 KwikStiks Version 1.3 Updated underlying software as follows: Updated to use Freescale MQX 3.7 Updated to use TSS 2.5 Added IAR 6.1X Project Added IAR 6.2X Project Added CodeWarrior 10.1 Project Version 1.4 Replaced USB Joystick demo with USB Mouse demo Version 1.5 Added Tetris clone, Fretris

Before You Start

The demonstration software is an application for the Freescale MQX RTOS. MQX 3.7 and the latest patches for the Kinetis KwikStik must be installed before the KwikStik Demo Software can be compiled. If you already have Freescale MQX 3.7 and the latest patches, please move to the next section. Otherwise: 1. Download and install Freescale MQX RTOS 3.7. 2. Download and install Freescale MQX RTOS 3.7 Patch for Kinetis KwikStik If you dont already have the IAR or CodeWarrior tools installed, you should do so before you process further. You can install evaluation versions of the tools from the links below. IAR Embedded Workbench for ARM CodeWarrior for Microcontrollers

Installing the Demonstration Software

The demonstration software is deployed as a zip file containing this Lab Guide and an executable containing the demonstration software source code. The executable will install the demonstration KWIKSTIKDEMOSWLG Kinetis KwikStik Demo Software Lab Guide Rev. 0.5 Page 3 of 11

software to the default MQX installation path of C:\Program Files\Freescale\Freescale MQX 3.7\demo in a folder named KwikStik_Demo. NOTE: The KwikStik_Demo folder must be installed inside the Freescale MQX 3.7\demo folder for the build paths to be found properly by CodeWarrior or IAR Embedded Workbench. If your installation path for MQX doesnt match the default (C:\Program Files\Freescale\Freescale MQX 3.7), you will need to change the install path during the installation process that of your MQX installation. NOTE: Installing the KwikStik Demo Software will overwrite any changes youve made to a previously installed version. Save off any changes youve made to the source or project files in your existing KwikStik_Demo folder before you install the latest version.

Using IAR Embedded Workbench

This section covers how to build the software and program it to the Kinetis K40 flash using IAR Embedded Workbench for ARM. 1) Open the appropriate IAR workspace file either Freescale MQX 3.7\demo\Kwikstik_Demo\iar\Kwikstik_Demo_6_10.eww or Freescale MQX 3.7\demo\Kwikstik_Demo\iar\Kwikstik_Demo_6_20.eww depending on the version of IAR you are using. 2) Click on the Make button to build the code. 3) Plug a USB cable from your PC to the J-Link micro USB connector on the KwikStik. NOTE: there are two micro USB connectors on the KwikStik. In order to connect to the board using the IAR tools you have to use the J-Link connector on the right side of the board.

KWIKSTIKDEMOSWLG

Kinetis KwikStik Demo Software Lab Guide Rev. 0.5

Page 4 of 11

4) After compilation completes, download the code to the board and start the debugger by pressing the Download and Debug button 5) The code will download Flash, and the debugger screen will come up and pause at the first instruction. Hit the Go button to start running.

6) Follow the instruction in section 7, Running the Demos.

Using CodeWarrior 10.2

This section covers how to build the software and program it to the Kinetis K40 flash using CodeWarrior for Microcontrollers. 1) If you havent already, you should make sure you have downloaded and installed the latest version of CodeWarrior for Microcontrollers v10.2. There are currently no further patches required. 2) Open CW for MCU v10.2 from the Start menu. 3) Depending on your preference settings in CodeWarrior, a dialog box may pop us asking you to select a workspace. Set the workspace to the MQX installation directory, which by default is: C:\Program Files\Freescale\Freescale MQX 3.7

Unless you have active projects already, CodeWarrior will open to the Welcome screen. Select Go to Workbench.

NOTE: If you already have CodeWarrior open, you can change the workspace by going to KWIKSTIKDEMOSWLG Kinetis KwikStik Demo Software Lab Guide Rev. 0.5 Page 5 of 11

File->Switch Workspace. This will restart CodeWarrior and open the new workspace location. 4) Click on File->Import in the menu bar. In the dialog box that comes up, select Existing Projects into Workspace under the General folder. Then click Next

5) On the next screen, select the Select root directory: option, and click on Browse 6) Navigate to the C:\Program Files\Freescale\Freescale MQX 3.7\demo\Kwikstik_Demo directory and hit OK. 7) NOTE: C:\Program Files\Freescale is the default installation location for Freescale MQX 3.7. Substitute your installation directory here if it is different. 8) Make sure Kwikstik_Demo is checked and Copy projects into workspace is unchecked. Hit Finish.

KWIKSTIKDEMOSWLG

Kinetis KwikStik Demo Software Lab Guide Rev. 0.5

Page 6 of 11

9) Build the project by clicking on the Hammer icon in the toolbar 10) Plug a USB cable from your PC to the J-Link micro USB connector on the KwikStik. NOTE: There are two micro USB connectors on the KwikStik. In order to connect to the board using the CodeWarrior tools you have to use the J-Link connector on the right side of the board.

11) Click Run->Debug Configurations in the menu bar, and select the KwikStik_Demo_kwikstikk40x256_Int_Flash_Debug_Segger_J-Link configuration in the CodeWarrior Download section. Then hit the debug button in the bottom of the window

KWIKSTIKDEMOSWLG

Kinetis KwikStik Demo Software Lab Guide Rev. 0.5

Page 7 of 11

12) The code will then be flashed to the board and the debugger started. This may take a several moments. 13) Once the code is done flashing, the code will pause at the start of the MQX main() function. 14) Hit the run icon to continue the program execution.

Running the Demos

The Kinetis Demonstration Software highlights some of the features of the K40X256 MCU and the KwikStik evaluation and development board. All of the applications run as tasks under the Freescale MQXTM RTOS. When the board is plugged in and powered on, a menu will allow selection of one of the applications. Use the top left and right electrodes (E1, E2) to navigate through the available options. To select an application, use either one of the bottom electrodes (E5, E6).
Navigate

Power ON

Sound Recorder

Navigate

Remote Control

Navigate

USB HID Mouse

Navigate

FreTris

Select

Select

Select

Select

Sound Recorder

Remote Control

USB Mouse

Play FreTris

Figure 1. Main menu navigation flow diagram for demo applications

Figure 2. KwikStik Electrode Map

KWIKSTIKDEMOSWLG

Kinetis KwikStik Demo Software Lab Guide Rev. 0.5

Page 8 of 11

7.1 Sound Recorder


Raw sound data can be recorded from the microphone, stored in the K40 internal memory, and reproduced using the audio output mini-plug connector. A pair of headphones or external speakers connected to the audio output jack of the KwikStik is required for this demo application. This demonstration utilizes an ADC signal to capture audio from the on-board microphone. The audio data is stored in the flash memory of the K40X256. The audio data can be played back through a DAC signal connected to an external amplifier and a 3.5mm audio jack. A FlexTimer channel is used to set the period of audio capture and playback. Refer to the source files Sound_Recorder.c/h for details.

Record

Exit

Play

Figure 3. Sound recorder demo application electrode layout

7.2 Remote Control


The remote control application uses the infrared transmitter (connected to a PWM signal) to send SIRC protocol commands that can control most Sony televisions. Commands for Power (E2), Channel Up (E4), and Channel Down (E6) are pre-stored and can be transmitted by pressing the corresponding electrode. Refer to the source files Remote_Control.c/h for details.

Power

Channel Up

Exit

Channel Down

Figure 4. Remote Control demo application electrode layout

7.3 USB Mouse (HID)


The KwikStik can be used as a USB mouse device when running this application. When this application is selected the K40X256 will enumerate as an HID-compliant mouse on the PC. Use the touch-sensing electrodes to send button commands to the PC. The MQX USB stack and HID class drivers are utilized for this application. Refer to mouse.c/h and usb_descriptor.c/h for application specific details.

KWIKSTIKDEMOSWLG

Kinetis KwikStik Demo Software Lab Guide Rev. 0.5

Page 9 of 11

Left Click

Right Click

Exit

Figure 5. USB mouse demo application electrode layout

7.4 Fretris
Fretris is a clone of the popular puzzle video game, Tetris (Freescale Tetris). See the Wikipedia entry for Tetris for information on the game, including rules and how to play. When the Fretris application is selected from the menu, a custom FRETRIS logo will appear on the segment LCD display. After the logo is displayed, rotate the KwikStik so that the J-Link USB connector is on the bottom. Start the game by pressing E1 (a cursor will blink near this electrode indicating that you should touch it). When a game is on-going, E1 can be pressed at any time to exit the game immediately. While playing a game, electrodes E6 and E2 can be used to move the descending blocks right and left. A block can be rotated by touching E4. When you have it aligned, you can make it drop faster by touching E5. While the block is dropping, a ghost row below the bottom of the game board will indicate where the piece will land. Score is maintained at the bottom of the screen using two rows of LCD segments. Each completed line on the game board will increment the top bar of the score (0 to 8). Each completed top bar of the score will increment the lower bar (0 to 8). The game is complete when 64 lines have been completed in the game board.

KWIKSTIKDEMOSWLG

Kinetis KwikStik Demo Software Lab Guide Rev. 0.5

Page 10 of 11

Drop

Start

Left Spin

Right

This application highlights the flexibility of the K40X256 Segment LCD controller. The sources files for controlling the LCD are in the MQX BSP and also in the application specific Driver_SLCD.c/h files. Explore the source files in the Fretris source directory for details on the game implementation.

KWIKSTIKDEMOSWLG

Kinetis KwikStik Demo Software Lab Guide Rev. 0.5

Page 11 of 11

You might also like