CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

usb keyboard

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
iamlost



Joined: 18 Aug 2010
Posts: 3

View user's profile Send private message

usb keyboard
PostPosted: Wed Aug 18, 2010 11:33 am     Reply with quote

HI,
I am new with USB and I have a problem. I modified a example from ccs
usb_kbmouse2.

The issue is if I have the same code it will send the first one but not the other.
If I have 22344556 I will get only 23456 not 22344556.

When I press the button, send to the USB (keyboard) table numero
replace code ascii with code for USB.

Thank you.

Does anyone know what
Code:
static int8 tx_msg[8]={2,0,0,0,0,0,0,0};

means ?

My code is:
Code:

void usb_keyboard_task(void)
{
   static int8 tx_msg[8]={2,0,0,0,0,0,0,0};
    if(ascii2!=0)
    tx_msg[3]=(ascii2);
    else
    tx_msg[3]=0;
       
    usb_put_packet(1,tx_msg,sizeof(tx_msg),USB_DTS_TOGGLE);
 }

////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////


 while (TRUE) {

   
   if(!input(BUTTON))
    {
     for (i=0; i<=index; i++)
   {
   ascii=(numero[i]);
   switch (ascii)
   {
    case 0x30 : ascii2=0x62;
         break;
     
    case 0x31 : ascii2=0x59;
         break;
         
    case 0x32 : ascii2=0x5a;
         break;
         
    case 0x33 : ascii2=0x5b;
         break;
         
    case 0x34 : ascii2=0x5c;
         break;
         
    case 0x35 : ascii2=0x5d;
         break;
         
    case 0x36 : ascii2=0x5e;
         break;
         
    case 0x37 : ascii2=0x5f;
         break;
         
    case 0x38 : ascii2=0x60;
         break;
         
    case 0x39 : ascii2=0x61;
         break;
   
    case 0x2e : ascii2=0x63;
         break;
         
    case 0x0d : ascii2=0x58;
         break;

   default : ascii2=0x00;
   }

         usb_keyboard_task();
         usb_rx_task();
         delay_ms(10);
   }
   delay_ms(100);
      }
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Wed Aug 18, 2010 5:56 pm     Reply with quote

Quote:

Does anyone know what
static int8 tx_msg[8]={2,0,0,0,0,0,0,0};
means ?

Look in this file:
Quote:
c:\program files\picc\examples\ex_usb_kbmouse2.c

Find the usb_keyboard_task() function declaration. In the comments
just above, it gives the complete explanation of each byte in tx_msg[].
pmuldoon



Joined: 26 Sep 2003
Posts: 218
Location: Northern Indiana

View user's profile Send private message

PostPosted: Thu Aug 19, 2010 5:48 am     Reply with quote

is it the STATIC that is confusing you?
That just allows you to create an array as a local, but it reserves the memory space so it can't be reused by other locals from other functions.
Think of it as a global that is only visible within this function.
That way you can preload the default data and just change the byte that needs changing with each call.

Now my question:
Why the ascii2 translation?
Apparently I don't know much about keyboards. At first I thought that sent data would be ASCII, but maybe it's not. So then I vaguely remembered something about scancodes, but when I googled some charts, those numbers didn't seem to work either. I'm sure I'm missing some obvious thing, but how does 4 = 'a' in the example code?

also a suggestion for readability:
Code:
case 0x30:

is the same as:
Code:
case'0':

and is much easier to follow.
you can also use '.' for the decimal.
pmuldoon



Joined: 26 Sep 2003
Posts: 218
Location: Northern Indiana

View user's profile Send private message

PostPosted: Thu Aug 19, 2010 6:07 am     Reply with quote

Nevermind. I found my answer in a rather wordy Microsoft document.
There is something called a 'Usage Index' that correlates to the 4='a' thing,
0x62=keypad 0, etc.

Give a man a fish and you feed him for a day, teach a man to fish and you get him out of the house every weekend!
iamlost



Joined: 18 Aug 2010
Posts: 3

View user's profile Send private message

PostPosted: Thu Aug 19, 2010 9:52 am     Reply with quote

Yes translation is because I get data from rs232 and I send back to USB
and 30(ascii) from rs232 is "0" but for usb Keyboard is something else.

I still have the same issue with 2 or more same number.

Thank you for your help.
pmuldoon



Joined: 26 Sep 2003
Posts: 218
Location: Northern Indiana

View user's profile Send private message

PostPosted: Thu Aug 19, 2010 10:12 am     Reply with quote

Can you post a complete, simple program to demonstrate the problem?

I don't see anything that would cause repeated values to not be sent.
It could be something at the other end, also.
You might want to play with putting a very long delay in or even sending a 0 between characters just to see what happens.

I don't understand what you're trying to do with this, either:
Code:

if(ascii2!=0)
tx_msg[3]=(ascii2);
else
tx_msg[3]=0;
pmuldoon



Joined: 26 Sep 2003
Posts: 218
Location: Northern Indiana

View user's profile Send private message

PostPosted: Thu Aug 19, 2010 10:15 am     Reply with quote

guess i should've previewed:

Can you post a complete, simple program to demonstrate the problem?

I don't see anything that would cause repeated values to not be sent.
It could be something at the other end, also.
You might want to play with putting a very long delay in or even sending a 0 between characters just to see what happens.

I don't understand what you're trying to do with this, either:
Code:


if(ascii2!=0)
tx_msg[3]=(ascii2);
else
tx_msg[3]=0;
iamlost



Joined: 18 Aug 2010
Posts: 3

View user's profile Send private message

PostPosted: Thu Aug 26, 2010 8:14 am     Reply with quote

I understand the (static of int8 tx_msg) but what I still don't understand is
the first 2 and the other 0 do. I checked the file:

c:\program files\picc\examples\ex_usb_kbmouse2.c

And again when I have the same number in a row I got only one.

If I have 0.2223455 I get 0.2345 only.

My code is like that:
Code:

void usb_keyboard_task(void)
{
   static int8 tx_msg[8]={2,0,0,0,0,0,0,0};
    tx_msg[3]=(ascii2);
         
    usb_put_packet(1,tx_msg,sizeof(tx_msg),USB_DTS_TOGGLE);
 }

////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////


 while (TRUE) {

   
   if(!input(BUTTON))
    {
     for (i=0; i<=index; i++)
   {
   ascii=(numero[i]);
   switch (ascii)
   {
    case 0x30 : ascii2=0x62;
         break;
     
    case 0x31 : ascii2=0x59;
         break;
         
    case 0x32 : ascii2=0x5a;
         break;
         
    case 0x33 : ascii2=0x5b;
         break;
         
    case 0x34 : ascii2=0x5c;
         break;
         
    case 0x35 : ascii2=0x5d;
         break;
         
    case 0x36 : ascii2=0x5e;
         break;
         
    case 0x37 : ascii2=0x5f;
         break;
         
    case 0x38 : ascii2=0x60;
         break;
         
    case 0x39 : ascii2=0x61;
         break;
   
    case 0x2e : ascii2=0x63;
         break;
         
    case 0x0d : ascii2=0x58;
         break;

   default : ascii2=0x00;
   }

         usb_keyboard_task();
         usb_rx_task();
         delay_ms(10);
   }
   delay_ms(100);
      }
pmuldoon



Joined: 26 Sep 2003
Posts: 218
Location: Northern Indiana

View user's profile Send private message

PostPosted: Thu Aug 26, 2010 8:53 am     Reply with quote

I don't really know much about usb.
You might take a look at this for a better description of the field values.

http://www.usb.org/developers/devclass_docs/HID1_11.pdf

Maybe the USB disregards duplicate messages? Did you try sending a zero (not the character '0') or null message between characters?
cvargcal



Joined: 17 Feb 2015
Posts: 134

View user's profile Send private message

PostPosted: Thu Oct 04, 2018 6:50 pm     Reply with quote

Hi, I have the same problem.... someone solution?
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Fri Oct 05, 2018 12:25 am     Reply with quote

The key is that the behaviour is 'scan based'.

The standard PC keyboard sends a code to say 'this key pressed', and another to say 'this key released'. Now if you send 'this key pressed', followed by a second code saying that the same key is pressed, the PC will ignore the second code (after all it is the same key, and it hasn't been released).
So if sending successive keys, if the code you want is the same as the last one sent, you have to send a 'no key' code between (0).
You can either just always send a 0 after each key code, or check if the code is the same as the last one, and just send the 0 when this happens.
temtronic



Joined: 01 Jul 2010
Posts: 9282
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Fri Oct 05, 2018 7:10 am     Reply with quote

Mr T is 100% right, again ! PC KBD code is well documented and you really should read up about 'how it works' especially if you want to control the KBDs LEDs. Yeesh 20 years ago I did a PC KBD to ASCII convertor using the PIC16C84. Still have them running today !

Jay
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group