Friday, April 9, 2010

Simple Keyboard Simulation Using SendInput function

Need to include <windows.h> header file
SendInput
INPUT structure
KEYBDINPUT structure

This function simulate a keyboard press to any active window

1. Create INPUT structure
INPUT *key; //pointer to INPUT structure

key=malloc(sizeof(INPUT));//allocate memory for INPUT structure pointed by key

key->type = INPUT_KEYBOARD;
key->ki.wVK = Virtual_Key_Code; //see Virtual Key Code list for the full key list
key->ki.wScan=0;
key->ki.dwFlags=0;
key->ki.time=0;
key->ki.dwExtraInfo=0;

2. Call SendInput function

SendInput(1,key,sizeof(INPUT));

3. Free memory

free(key);

4. Note
This function works with all active windows. If you need to send a key press to inactive windows (minimized or hidden windows), use SendMessage or PostMessage

PostMessage(hwndWindow, WM_KEYDOWN, Virtual_Key_Code,0);//Press the key down
PostMessage(hwndWindow, WM_KEYUP, Virtual_Key_Code,0);//Release the key

hwndWindow: Handle of the window you want to send a keyboard button to, hwndWindow can be obtained by using FindWindow or FindWindowEx
WM_KEYDOWN: constant = 0x100
WM_KEYUP: constant = 0x101

This method may not work with some applications especially games that use Direct Input.

Virtual Key Code List
VK_LBUTTON (0x01)
Left mouse button

VK_RBUTTON (0x02)
Right mouse button

VK_CANCEL (0x03)
Control-break processing

VK_MBUTTON (0x04)
Middle mouse button (three-button mouse)

VK_XBUTTON1 (0x05)
Windows 2000/XP: X1 mouse button

VK_XBUTTON2 (0x06)
Windows 2000/XP: X2 mouse button

- (0x07)
Undefined

VK_BACK (0x08)
BACKSPACE key

VK_TAB (0x09)
TAB key

- (0x0A-0B)
Reserved

VK_CLEAR (0x0C)
CLEAR key

VK_RETURN (0x0D)
ENTER key

- (0x0E-0F)
Undefined

VK_SHIFT (0x10)
SHIFT key

VK_CONTROL (0x11)
CTRL key

VK_MENU (0x12)
ALT key

VK_PAUSE (0x13)
PAUSE key

VK_CAPITAL (0x14)
CAPS LOCK key

VK_KANA (0x15)
Input Method Editor (IME) Kana mode

VK_HANGUEL (0x15)
IME Hanguel mode (maintained for compatibility; use VK_HANGUL)

VK_HANGUL (0x15)
IME Hangul mode

- (0x16)
Undefined

VK_JUNJA (0x17)
IME Junja mode

VK_FINAL (0x18)
IME final mode

VK_HANJA (0x19)
IME Hanja mode

VK_KANJI (0x19)
IME Kanji mode

- (0x1A)
Undefined

VK_ESCAPE (0x1B)
ESC key

VK_CONVERT (0x1C)
IME convert

VK_NONCONVERT (0x1D)
IME nonconvert

VK_ACCEPT (0x1E)
IME accept

VK_MODECHANGE (0x1F)
IME mode change request

VK_SPACE (0x20)
SPACEBAR

VK_PRIOR (0x21)
PAGE UP key

VK_NEXT (0x22)
PAGE DOWN key

VK_END (0x23)
END key

VK_HOME (0x24)
HOME key

VK_LEFT (0x25)
LEFT ARROW key

VK_UP (0x26)
UP ARROW key

VK_RIGHT (0x27)
RIGHT ARROW key

VK_DOWN (0x28)
DOWN ARROW key

VK_SELECT (0x29)
SELECT key

VK_PRINT (0x2A)
PRINT key

VK_EXECUTE (0x2B)
EXECUTE key

VK_SNAPSHOT (0x2C)
PRINT SCREEN key

VK_INSERT (0x2D)
INS key

VK_DELETE (0x2E)
DEL key

VK_HELP (0x2F)
HELP key

(0x30)
0 key

(0x31)
1 key

(0x32)
2 key

(0x33)
3 key

(0x34)
4 key

(0x35)
5 key

(0x36)
6 key

(0x37)
7 key

(0x38)
8 key

(0x39)
9 key

- (0x3A-40)
Undefined

(0x41)
A key

(0x42)
B key

(0x43)
C key

(0x44)
D key

(0x45)
E key

(0x46)
F key

(0x47)
G key

(0x48)
H key

(0x49)
I key

(0x4A)
J key

(0x4B)
K key

(0x4C)
L key

(0x4D)
M key

(0x4E)
N key

(0x4F)
O key

(0x50)
P key

(0x51)
Q key

(0x52)
R key

(0x53)
S key

(0x54)
T key

(0x55)
U key

(0x56)
V key

(0x57)
W key

(0x58)
X key

(0x59)
Y key

(0x5A)
Z key

VK_LWIN (0x5B)
Left Windows key (Microsoft Natural keyboard)

VK_RWIN (0x5C)
Right Windows key (Natural keyboard)

VK_APPS (0x5D)
Applications key (Natural keyboard)

- (0x5E)
Reserved

VK_SLEEP (0x5F)
Computer Sleep key

VK_NUMPAD0 (0x60)
Numeric keypad 0 key

VK_NUMPAD1 (0x61)
Numeric keypad 1 key

VK_NUMPAD2 (0x62)
Numeric keypad 2 key

VK_NUMPAD3 (0x63)
Numeric keypad 3 key

VK_NUMPAD4 (0x64)
Numeric keypad 4 key

VK_NUMPAD5 (0x65)
Numeric keypad 5 key

VK_NUMPAD6 (0x66)
Numeric keypad 6 key

VK_NUMPAD7 (0x67)
Numeric keypad 7 key

VK_NUMPAD8 (0x68)
Numeric keypad 8 key

VK_NUMPAD9 (0x69)
Numeric keypad 9 key

VK_MULTIPLY (0x6A)
Multiply key

VK_ADD (0x6B)
Add key

VK_SEPARATOR (0x6C)
Separator key

VK_SUBTRACT (0x6D)
Subtract key

VK_DECIMAL (0x6E)
Decimal key

VK_DIVIDE (0x6F)
Divide key

VK_F1 (0x70)
F1 key

VK_F2 (0x71)
F2 key

VK_F3 (0x72)
F3 key

VK_F4 (0x73)
F4 key

VK_F5 (0x74)
F5 key

VK_F6 (0x75)
F6 key

VK_F7 (0x76)
F7 key

VK_F8 (0x77)
F8 key

VK_F9 (0x78)
F9 key

VK_F10 (0x79)
F10 key

VK_F11 (0x7A)
F11 key

VK_F12 (0x7B)
F12 key

VK_F13 (0x7C)
F13 key

VK_F14 (0x7D)
F14 key

VK_F15 (0x7E)
F15 key

VK_F16 (0x7F)
F16 key

VK_F17 (0x80H)
F17 key

VK_F18 (0x81H)
F18 key

VK_F19 (0x82H)
F19 key

VK_F20 (0x83H)
F20 key

VK_F21 (0x84H)
F21 key

VK_F22 (0x85H)
F22 key

VK_F23 (0x86H)
F23 key

VK_F24 (0x87H)
F24 key

- (0x88-8F)
Unassigned

VK_NUMLOCK (0x90)
NUM LOCK key

VK_SCROLL (0x91)
SCROLL LOCK key

(0x92-96)
OEM specific

- (0x97-9F)
Unassigned

VK_LSHIFT (0xA0)
Left SHIFT key

VK_RSHIFT (0xA1)
Right SHIFT key

VK_LCONTROL (0xA2)
Left CONTROL key

VK_RCONTROL (0xA3)
Right CONTROL key

VK_LMENU (0xA4)
Left MENU key

VK_RMENU (0xA5)
Right MENU key

VK_BROWSER_BACK (0xA6)
Windows 2000/XP: Browser Back key

VK_BROWSER_FORWARD (0xA7)
Windows 2000/XP: Browser Forward key

VK_BROWSER_REFRESH (0xA8)
Windows 2000/XP: Browser Refresh key

VK_BROWSER_STOP (0xA9)
Windows 2000/XP: Browser Stop key

VK_BROWSER_SEARCH (0xAA)
Windows 2000/XP: Browser Search key

VK_BROWSER_FAVORITES (0xAB)
Windows 2000/XP: Browser Favorites key

VK_BROWSER_HOME (0xAC)
Windows 2000/XP: Browser Start and Home key

VK_VOLUME_MUTE (0xAD)
Windows 2000/XP: Volume Mute key

VK_VOLUME_DOWN (0xAE)
Windows 2000/XP: Volume Down key

VK_VOLUME_UP (0xAF)
Windows 2000/XP: Volume Up key

VK_MEDIA_NEXT_TRACK (0xB0)
Windows 2000/XP: Next Track key

VK_MEDIA_PREV_TRACK (0xB1)
Windows 2000/XP: Previous Track key

VK_MEDIA_STOP (0xB2)
Windows 2000/XP: Stop Media key

VK_MEDIA_PLAY_PAUSE (0xB3)
Windows 2000/XP: Play/Pause Media key

VK_LAUNCH_MAIL (0xB4)
Windows 2000/XP: Start Mail key

VK_LAUNCH_MEDIA_SELECT (0xB5)
Windows 2000/XP: Select Media key

VK_LAUNCH_APP1 (0xB6)
Windows 2000/XP: Start Application 1 key

VK_LAUNCH_APP2 (0xB7)
Windows 2000/XP: Start Application 2 key

- (0xB8-B9)
Reserved

VK_OEM_1 (0xBA)
Used for miscellaneous characters; it can vary by keyboard.

Windows 2000/XP: For the US standard keyboard, the ';:' key

VK_OEM_PLUS (0xBB)
Windows 2000/XP: For any country/region, the '+' key

VK_OEM_COMMA (0xBC)
Windows 2000/XP: For any country/region, the ',' key

VK_OEM_MINUS (0xBD)
Windows 2000/XP: For any country/region, the '-' key

VK_OEM_PERIOD (0xBE)
Windows 2000/XP: For any country/region, the '.' key

VK_OEM_2 (0xBF)
Used for miscellaneous characters; it can vary by keyboard.

Windows 2000/XP: For the US standard keyboard, the '/?' key

VK_OEM_3 (0xC0)
Used for miscellaneous characters; it can vary by keyboard.

Windows 2000/XP: For the US standard keyboard, the '`~' key

- (0xC1-D7)
Reserved

- (0xD8-DA)
Unassigned

VK_OEM_4 (0xDB)
Used for miscellaneous characters; it can vary by keyboard.

Windows 2000/XP: For the US standard keyboard, the '[{' key

VK_OEM_5 (0xDC)
Used for miscellaneous characters; it can vary by keyboard.

Windows 2000/XP: For the US standard keyboard, the '\|' key

VK_OEM_6 (0xDD)
Used for miscellaneous characters; it can vary by keyboard.

Windows 2000/XP: For the US standard keyboard, the ']}' key

VK_OEM_7 (0xDE)
Used for miscellaneous characters; it can vary by keyboard.

Windows 2000/XP: For the US standard keyboard, the 'single-quote/double-quote' key

VK_OEM_8 (0xDF)
Used for miscellaneous characters; it can vary by keyboard.

- (0xE0)
Reserved

(0xE1)
OEM specific

VK_OEM_102 (0xE2)
Windows 2000/XP: Either the angle bracket key or the backslash key on the RT 102-key keyboard

(0xE3-E4)
OEM specific

VK_PROCESSKEY (0xE5)
Windows 95/98/Me, Windows NT 4.0, Windows 2000/XP: IME PROCESS key

(0xE6)
OEM specific

VK_PACKET (0xE7)
Windows 2000/XP: Used to pass Unicode characters as if they were keystrokes. The VK_PACKET key is the low word of a 32-bit Virtual Key value used for non-keyboard input methods. For more information, see Remark in KEYBDINPUT, SendInput, WM_KEYDOWN, and WM_KEYUP

- (0xE8)
Unassigned

(0xE9-F5)
OEM specific

VK_ATTN (0xF6)
Attn key

VK_CRSEL (0xF7)
CrSel key

VK_EXSEL (0xF8)
ExSel key

VK_EREOF (0xF9)
Erase EOF key

VK_PLAY (0xFA)
Play key

VK_ZOOM (0xFB)
Zoom key

VK_NONAME (0xFC)
Reserved

VK_PA1 (0xFD)
PA1 key

VK_OEM_CLEAR (0xFE)
Clear key

Monday, April 5, 2010

LPC17xx GPIO basic

Depend on LPC17xx version the pinouts may be different. I am using 100-pin LPC1768 as an example.
Reference document: LPC17xx User manual
Require #include header lpc17xx.h
Pins on LPC1768 are divided into 5 groups (PORT) starting from 0 to 4.
Pin naming convention: P0.0 (group 0, pin 0) or (Port 0, Pin 0)
Note: if I refer to a page number, that page number is from LPC17xx User manual
Each pin has 4 operating modes: GPIO(default), 1st alternate function, 2nd alternate function, 3rd alternate function.
All GPIO pins are powered automatically so we do not need to turn on the pin power supply.

1. Pin function setting
The register LPC_PINCON control operating mode of these pins. LPC_PINCON->PINSEL0[1:0] control PIN 0.0 operating mode (page 106/835)
...
LPC_PINCON->PINSEL0[31:30] control PIN 0.15 operating mode
LPC_PINCON->PINSEL1[1:0] control PIN 0.16 operating mode
...
LPC_PINCON->PINSEL1[29:28] control PIN 0.30 operating mode
LPC_PINCON->PINSEL2[1:0] control PIN 1.0 operating mode
...
LPC_PINCON->PINSEL2[31:30] control PIN 1.15 operating mode
LPC_PINCON->PINSEL3[1:0] control PIN 1.16 operating mode
...
LPC_PINCON->PINSEL3[31:30] control PIN 1.31 operating mode
...
LPC_PINCON->PINSEL9[25:24] control PIN 4.28 operating mode
LPC_PINCON->PINSEL9[27:26] control PIN 4.29 operating mode

Note: Some register bits are reserved and are not used to control a pin. For example,
LPC_PINCON->PINSEL9[23:0] are reserved
LPC_PINCON->PINSEL9[31:28] are reserved

Bit Values Function
00 GPIO function
01 1st alternate function
10 2nd alternate function
11 3rd alternate function

Example:
To set pin 0.3 as GPIO (set corresponding bit to 00)
LPC_PINCON->PINSEL0 &=~((1 <<7)|(1<<6));

To set pin 0.3 as ADC channel 0.6 (2nd alternate function, set corresponding bit to 10)
LPC_PINCON->PINSEL0 |=((1 <<7)|(0<<6)); // you may omit (0<<6)

2. Pin direction setting
Register LPC_GPIOn->FIODIR[31:0] control the pin input/output where n is the pin group (0-4)
To set a pin as output, set the corresponding bit to 1. To set a pin as input, set the corresponding bit to 0. By default, all pins are set as input (all bits are 0).

Example:
To set pin 0.3 as output
LPC_GPIO0->FIODIR |= (1<<3);

3. A pin is set as output
Pin digital high/low setting
LPC_GPIOn->FIOSET is used to turn a pin to HIGH (page 122/835)
Register LPC_GPIOn->FIOCLR is used to turn a pin to LOW
To turn a pin to digital 1 (high), set the corresponding bit of LPC_GPIOn->FIOSET to 1. To turn a pin to digital 0 (low), set the corresponding bit of LPC_GPIOn->FIOCLR to 1.

Example:
Turn pin 0.3 to high
LPC_GPIO0->FIOSET |= (1<<3);
If we set LPC_GPIOn->FIOSET bit to 0, there is no effect
Turn pin 0.3 to low
LPC_GPIO0->FIOCLR |= (1<<3);
If we set LPC_GPIOn->FIOCLR bit to 0, there is no effect

4. A pin is set to input
a. Read a pin value
Register LPC_GPIOn->FIOPIN stores the current pin state. (page 125/835)
The corresponding bit is 1 indicates that the pin is driven high

Example:
To read current pin 0.3 state
value = ((LPC_GPIO0->FIOPIN & (1 <<3))>> 3);

Note:
Write a 1/0 to a corresponding bit in LPC_GPIOn->FIOPIN can change the output of the pin to 1/0 but it is not recommended. We should use LPC_GPIOn->FIOSET and LPC_GPIOn->FIOCLR instead.

b. Pin internal pull up setting
Register LPC_PINCON->PINMODEn is used to set up a pin internal pull up
LPC_PINCON->PINMODE0[1:0] control P0.0 internal pull up
...
LPC_PINCON->PINMODE0[31:30] control P0.15 internal pull up

Please see LPC_PINCON->PINSELn for the full list or page 110/835

Bit values Pin mode
00 on-chip pull-up resistor enabled
01 repeater mode,see page 103/835
10 tri-state mode, neither pull-up nor pull-down resistor enabled
11 on-chip pull-down resistor enabled

Example
By default all pins which are set as input has internal pull-up on (00)
To disable internal pull-up on pin 0.3
LPC_PINCON->PINSEL0 |= (1 << 7);

5. Using GPIO interrupt, only pin group 0 and 2 are used with pin interrupt
a. Falling edge interrupt
Register LPC_GPIOINT->IOxIntEnF is used to enable falling edge detected interrupt, in which x is the group number, either 0 or 2. To turn on falling edge interrupt of a pin, set the corresponding pin to 1.

Example

To enable pin 0.3 falling edge interrupt
LPC_GPIOINT->IO0IntEnF |= (1 << 3);

b. Raising edge interrupt
Register LPC_GPIOINT->IOxIntEnR is used to enable raising edge detected interrupt, in which x is the group number. To turn on raising edge interrupt of a pin, set the corresponding pin to 1.

Example

To enable pin 0.3 and 0.5 raising edge interrupt
LPC_GPIOINT->IO0IntEnR |= ((1 << 3)| (1 << 5));


c. All GPIO interrupts are connected to to EINT3 interrupt source. You need to turn EINT3_IRQn on in order to use GPIO interrupt.
NVIC_EnableIRQ(EINT3_IRQn);

d. Interrupt handler subroutine
Add this subroutine to your code. Every time the GPIO interrupts are fired (regardless of which pin), this subroutine is called.
void EINT3_IRQHandler (void)
{

}

Register LPC_GPIOINT->IOxIntStatF[31:0] has the status of which pin falling edge interrupt was fired.
Register LPC_GPIOINT->IOxIntStatR[31:0] has the status of which pin raising edge interrupt was fired.
Register LPC_GPIOINT->IOxIntClr[31:0] is used to clear the status of a pin interrupt. To clear the status bit, write 1 to the corresponding bit.

Example
To check if pin 0.3 interrupt was fired or pin 0.5 interrupt was fired
void EINT3_IRQHandler (void)
{
  if ((LPC_GPIOINT->IO0IntStatR & (1 << 3)) == (1 << 3))
  {
  //raising edge interrupt on pin 0.3 was fired
  LPC_GPIOINT->IO0IntClr |= (1 << 3); // clear the status
  //do your task
 
  return;
  }
 
  if ((LPC_GPIOINT->IO0IntStatR & (1 << 5)) == (1 << 5))
  {
  //raising edge interrupt on pin 0.5 was fired
  LPC_GPIOINT->IO0IntClr |= (1 << 5); // clear the status
  //do your task
 
  return;
  }
}