Changeset 9f1362d4 in mainline for uspace/srv/hid/console/console.c
- Timestamp:
- 2010-04-19T19:58:18Z (15 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 369a5f8
- Parents:
- caad59a
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/hid/console/console.c
rcaad59a r9f1362d4 71 71 /** Information about framebuffer */ 72 72 struct { 73 int phone; /**< Framebuffer phone */74 ipcarg_t cols; /**< Framebuffer columns */75 ipcarg_t rows; /**< Framebuffer rows */76 i nt color_cap; /**< Color capabilities (FB_CCAP_xxx) */73 int phone; /**< Framebuffer phone */ 74 ipcarg_t cols; /**< Framebuffer columns */ 75 ipcarg_t rows; /**< Framebuffer rows */ 76 ipcarg_t color_cap; /**< Color capabilities (FB_CCAP_xxx) */ 77 77 } fb_info; 78 78 … … 99 99 /** Information on row-span yet unsent to FB driver. */ 100 100 struct { 101 size_t col; /**< Leftmost column of the span. */102 size_t row; /**< Row where the span lies. */103 size_t cnt; /**< Width of the span. */101 ipcarg_t col; /**< Leftmost column of the span. */ 102 ipcarg_t row; /**< Row where the span lies. */ 103 ipcarg_t cnt; /**< Width of the span. */ 104 104 } fb_pending; 105 105 … … 117 117 } 118 118 119 static void curs_goto( size_t x, size_t y)119 static void curs_goto(ipcarg_t x, ipcarg_t y) 120 120 { 121 121 async_msg_2(fb_info.phone, FB_CURSOR_GOTO, x, y); … … 147 147 } 148 148 149 static void set_style( int style)149 static void set_style(uint8_t style) 150 150 { 151 151 async_msg_1(fb_info.phone, FB_SET_STYLE, style); 152 152 } 153 153 154 static void set_color( int fgcolor, int bgcolor, int flags)154 static void set_color(uint8_t fgcolor, uint8_t bgcolor, uint8_t flags) 155 155 { 156 156 async_msg_3(fb_info.phone, FB_SET_COLOR, fgcolor, bgcolor, flags); 157 157 } 158 158 159 static void set_rgb_color( int fgcolor, int bgcolor)159 static void set_rgb_color(uint32_t fgcolor, uint32_t bgcolor) 160 160 { 161 161 async_msg_2(fb_info.phone, FB_SET_RGB_COLOR, fgcolor, bgcolor); … … 178 178 } 179 179 180 static int ccap_fb_to_con(i nt ccap_fb, int *ccap_con)180 static int ccap_fb_to_con(ipcarg_t ccap_fb, ipcarg_t *ccap_con) 181 181 { 182 182 switch (ccap_fb) { 183 case FB_CCAP_NONE: *ccap_con = CONSOLE_CCAP_NONE; break; 184 case FB_CCAP_STYLE: *ccap_con = CONSOLE_CCAP_STYLE; break; 185 case FB_CCAP_INDEXED: *ccap_con = CONSOLE_CCAP_INDEXED; break; 186 case FB_CCAP_RGB: *ccap_con = CONSOLE_CCAP_RGB; break; 187 default: return EINVAL; 188 } 189 183 case FB_CCAP_NONE: 184 *ccap_con = CONSOLE_CCAP_NONE; 185 break; 186 case FB_CCAP_STYLE: 187 *ccap_con = CONSOLE_CCAP_STYLE; 188 break; 189 case FB_CCAP_INDEXED: 190 *ccap_con = CONSOLE_CCAP_INDEXED; 191 break; 192 case FB_CCAP_RGB: 193 *ccap_con = CONSOLE_CCAP_RGB; 194 break; 195 default: 196 return EINVAL; 197 } 198 190 199 return EOK; 191 200 } … … 226 235 * 227 236 */ 228 static void cell_mark_changed( size_t col, size_t row)237 static void cell_mark_changed(ipcarg_t col, ipcarg_t row) 229 238 { 230 239 if (fb_pending.cnt != 0) { … … 253 262 { 254 263 bool flush_cursor = false; 255 264 256 265 switch (ch) { 257 266 case '\n': … … 297 306 async_msg_1(fb_info.phone, FB_SCROLL, 1); 298 307 } 299 308 300 309 if (cons == active_console && flush_cursor) 301 310 curs_goto(cons->scr.position_x, cons->scr.position_y); … … 327 336 328 337 if (cons != kernel_console) { 329 size_t x;330 size_t y;331 int rc = 0;332 333 338 async_serialize_start(); 334 339 … … 344 349 set_attrs(&cons->scr.attrs); 345 350 curs_visibility(false); 351 352 ipcarg_t x; 353 ipcarg_t y; 354 int rc = 0; 355 346 356 if (interbuffer) { 347 357 for (y = 0; y < cons->scr.size_y; y++) { … … 390 400 /* Ignore parameters, the connection is already opened */ 391 401 while (true) { 392 393 402 ipc_call_t call; 394 403 ipc_callid_t callid = async_get_call(&call); … … 433 442 static void mouse_events(ipc_callid_t iid, ipc_call_t *icall) 434 443 { 435 int button, press;436 int dx, dy;437 int newcon;438 439 444 /* Ignore parameters, the connection is already opened */ 440 445 while (true) { 441 442 446 ipc_call_t call; 443 447 ipc_callid_t callid = async_get_call(&call); 444 448 445 449 int retval; 446 450 447 451 switch (IPC_GET_METHOD(call)) { 448 452 case IPC_M_PHONE_HUNGUP: … … 450 454 return; 451 455 case MEVENT_BUTTON: 452 button = IPC_GET_ARG1(call); 453 press = IPC_GET_ARG2(call); 454 if (button == 1) { 455 newcon = gcons_mouse_btn(press); 456 if (IPC_GET_ARG1(call) == 1) { 457 int newcon = gcons_mouse_btn((bool) IPC_GET_ARG2(call)); 456 458 if (newcon != -1) 457 459 change_console(&consoles[newcon]); … … 460 462 break; 461 463 case MEVENT_MOVE: 462 dx = IPC_GET_ARG1(call); 463 dy = IPC_GET_ARG2(call); 464 gcons_mouse_move(dx, dy); 464 gcons_mouse_move((int) IPC_GET_ARG1(call), 465 (int) IPC_GET_ARG2(call)); 465 466 retval = 0; 466 467 break; … … 520 521 console_event_t ev; 521 522 fibril_mutex_lock(&input_mutex); 523 522 524 recheck: 523 525 while ((keybuffer_pop(&cons->keybuffer, &ev)) && (pos < size)) { … … 536 538 goto recheck; 537 539 } 540 538 541 fibril_mutex_unlock(&input_mutex); 539 542 } … … 542 545 { 543 546 console_event_t ev; 544 547 545 548 fibril_mutex_lock(&input_mutex); 549 546 550 recheck: 547 551 if (keybuffer_pop(&cons->keybuffer, &ev)) { … … 551 555 goto recheck; 552 556 } 557 553 558 fibril_mutex_unlock(&input_mutex); 554 559 } … … 580 585 ipcarg_t arg2; 581 586 ipcarg_t arg3; 582 583 int cons_ccap; 587 584 588 int rc; 585 589 … … 622 626 if (cons == active_console) { 623 627 async_req_0_0(fb_info.phone, FB_FLUSH); 624 625 628 curs_goto(cons->scr.position_x, cons->scr.position_y); 626 629 } … … 650 653 break; 651 654 case CONSOLE_GET_COLOR_CAP: 652 rc = ccap_fb_to_con(fb_info.color_cap, & cons_ccap);655 rc = ccap_fb_to_con(fb_info.color_cap, &arg1); 653 656 if (rc != EOK) { 654 657 ipc_answer_0(callid, rc); 655 658 continue; 656 659 } 657 arg1 = cons_ccap;658 660 break; 659 661 case CONSOLE_SET_STYLE: … … 714 716 return false; 715 717 } 716 718 717 719 kbd_phone = fd_phone(input_fd); 718 720 if (kbd_phone < 0) { … … 720 722 return false; 721 723 } 722 724 723 725 /* NB: The callback connection is slotted for removal */ 724 726 ipcarg_t phonehash; … … 727 729 return false; 728 730 } 729 731 730 732 async_new_connection(phonehash, 0, NULL, keyboard_events); 731 733 732 734 /* Connect to mouse device */ 733 735 mouse_phone = -1; 734 736 int mouse_fd = open("/dev/hid_in/mouse", O_RDONLY); 735 737 736 738 if (mouse_fd < 0) { 737 739 printf(NAME ": Notice - failed opening %s\n", "/dev/hid_in/mouse"); 738 740 goto skip_mouse; 739 741 } 740 742 741 743 mouse_phone = fd_phone(mouse_fd); 742 744 if (mouse_phone < 0) { … … 744 746 goto skip_mouse; 745 747 } 746 748 747 749 if (ipc_connect_to_me(mouse_phone, SERVICE_CONSOLE, 0, 0, &phonehash) != 0) { 748 750 printf(NAME ": Failed to create callback from mouse device\n"); … … 750 752 goto skip_mouse; 751 753 } 752 754 753 755 async_new_connection(phonehash, 0, NULL, mouse_events); 754 756 skip_mouse: 755 757 756 758 /* Connect to framebuffer driver */ 757 759 fb_info.phone = ipc_connect_me_to_blocking(PHONE_NS, SERVICE_VIDEO, 0, 0); … … 760 762 return -1; 761 763 } 762 764 763 765 /* Register driver */ 764 766 int rc = devmap_driver_register(NAME, client_connection); … … 772 774 773 775 /* Synchronize, the gcons could put something in queue */ 774 ipcarg_t color_cap;775 776 async_req_0_0(fb_info.phone, FB_FLUSH); 776 777 async_req_0_2(fb_info.phone, FB_GET_CSIZE, &fb_info.cols, &fb_info.rows); 777 async_req_0_1(fb_info.phone, FB_GET_COLOR_CAP, &color_cap); 778 fb_info.color_cap = color_cap; 778 async_req_0_1(fb_info.phone, FB_GET_COLOR_CAP, &fb_info.color_cap); 779 779 780 780 /* Set up shared memory buffer. */
Note:
See TracChangeset
for help on using the changeset viewer.