Changeset f4f866c in mainline for uspace/srv/hid/console
- Timestamp:
- 2010-04-23T21:42:26Z (16 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 6c39a907
- Parents:
- 38aaacc2 (diff), 80badbe (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)links above to see all the changes relative to each parent. - Location:
- uspace/srv/hid/console
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/hid/console/Makefile
r38aaacc2 rf4f866c 33 33 GENERIC_SOURCES = \ 34 34 console.c \ 35 screenbuffer.c \36 35 keybuffer.c \ 37 36 gcons.c -
uspace/srv/hid/console/console.c
r38aaacc2 rf4f866c 54 54 #include <vfs/vfs.h> 55 55 #include <fibril_synch.h> 56 #include <io/style.h> 57 #include <io/screenbuffer.h> 56 58 57 59 #include "console.h" 58 60 #include "gcons.h" 59 61 #include "keybuffer.h" 60 #include "screenbuffer.h" 62 61 63 62 64 #define NAME "console" … … 71 73 /** Information about framebuffer */ 72 74 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) */75 int phone; /**< Framebuffer phone */ 76 ipcarg_t cols; /**< Framebuffer columns */ 77 ipcarg_t rows; /**< Framebuffer rows */ 78 ipcarg_t color_cap; /**< Color capabilities (FB_CCAP_xxx) */ 77 79 } fb_info; 78 80 … … 99 101 /** Information on row-span yet unsent to FB driver. */ 100 102 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. */103 ipcarg_t col; /**< Leftmost column of the span. */ 104 ipcarg_t row; /**< Row where the span lies. */ 105 ipcarg_t cnt; /**< Width of the span. */ 104 106 } fb_pending; 105 107 … … 117 119 } 118 120 119 static void curs_goto( size_t x, size_t y)121 static void curs_goto(ipcarg_t x, ipcarg_t y) 120 122 { 121 123 async_msg_2(fb_info.phone, FB_CURSOR_GOTO, x, y); … … 147 149 } 148 150 149 static void set_style( int style)151 static void set_style(uint8_t style) 150 152 { 151 153 async_msg_1(fb_info.phone, FB_SET_STYLE, style); 152 154 } 153 155 154 static void set_color( int fgcolor, int bgcolor, int flags)156 static void set_color(uint8_t fgcolor, uint8_t bgcolor, uint8_t flags) 155 157 { 156 158 async_msg_3(fb_info.phone, FB_SET_COLOR, fgcolor, bgcolor, flags); 157 159 } 158 160 159 static void set_rgb_color( int fgcolor, int bgcolor)161 static void set_rgb_color(uint32_t fgcolor, uint32_t bgcolor) 160 162 { 161 163 async_msg_2(fb_info.phone, FB_SET_RGB_COLOR, fgcolor, bgcolor); … … 178 180 } 179 181 180 static int ccap_fb_to_con(i nt ccap_fb, int *ccap_con)182 static int ccap_fb_to_con(ipcarg_t ccap_fb, ipcarg_t *ccap_con) 181 183 { 182 184 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 185 case FB_CCAP_NONE: 186 *ccap_con = CONSOLE_CCAP_NONE; 187 break; 188 case FB_CCAP_STYLE: 189 *ccap_con = CONSOLE_CCAP_STYLE; 190 break; 191 case FB_CCAP_INDEXED: 192 *ccap_con = CONSOLE_CCAP_INDEXED; 193 break; 194 case FB_CCAP_RGB: 195 *ccap_con = CONSOLE_CCAP_RGB; 196 break; 197 default: 198 return EINVAL; 199 } 200 190 201 return EOK; 191 202 } … … 226 237 * 227 238 */ 228 static void cell_mark_changed( size_t col, size_t row)239 static void cell_mark_changed(ipcarg_t col, ipcarg_t row) 229 240 { 230 241 if (fb_pending.cnt != 0) { … … 253 264 { 254 265 bool flush_cursor = false; 255 266 256 267 switch (ch) { 257 268 case '\n': … … 297 308 async_msg_1(fb_info.phone, FB_SCROLL, 1); 298 309 } 299 310 300 311 if (cons == active_console && flush_cursor) 301 312 curs_goto(cons->scr.position_x, cons->scr.position_y); … … 327 338 328 339 if (cons != kernel_console) { 329 size_t x;330 size_t y;331 int rc = 0;332 333 340 async_serialize_start(); 334 341 … … 344 351 set_attrs(&cons->scr.attrs); 345 352 curs_visibility(false); 353 354 ipcarg_t x; 355 ipcarg_t y; 356 int rc = 0; 357 346 358 if (interbuffer) { 347 359 for (y = 0; y < cons->scr.size_y; y++) { … … 390 402 /* Ignore parameters, the connection is already opened */ 391 403 while (true) { 392 393 404 ipc_call_t call; 394 405 ipc_callid_t callid = async_get_call(&call); … … 433 444 static void mouse_events(ipc_callid_t iid, ipc_call_t *icall) 434 445 { 435 int button, press;436 int dx, dy;437 int newcon;438 439 446 /* Ignore parameters, the connection is already opened */ 440 447 while (true) { 441 442 448 ipc_call_t call; 443 449 ipc_callid_t callid = async_get_call(&call); 444 450 445 451 int retval; 446 452 447 453 switch (IPC_GET_METHOD(call)) { 448 454 case IPC_M_PHONE_HUNGUP: … … 450 456 return; 451 457 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); 458 if (IPC_GET_ARG1(call) == 1) { 459 int newcon = gcons_mouse_btn((bool) IPC_GET_ARG2(call)); 456 460 if (newcon != -1) 457 461 change_console(&consoles[newcon]); … … 460 464 break; 461 465 case MEVENT_MOVE: 462 dx = IPC_GET_ARG1(call); 463 dy = IPC_GET_ARG2(call); 464 gcons_mouse_move(dx, dy); 466 gcons_mouse_move((int) IPC_GET_ARG1(call), 467 (int) IPC_GET_ARG2(call)); 465 468 retval = 0; 466 469 break; … … 520 523 console_event_t ev; 521 524 fibril_mutex_lock(&input_mutex); 525 522 526 recheck: 523 527 while ((keybuffer_pop(&cons->keybuffer, &ev)) && (pos < size)) { … … 536 540 goto recheck; 537 541 } 542 538 543 fibril_mutex_unlock(&input_mutex); 539 544 } … … 542 547 { 543 548 console_event_t ev; 544 549 545 550 fibril_mutex_lock(&input_mutex); 551 546 552 recheck: 547 553 if (keybuffer_pop(&cons->keybuffer, &ev)) { … … 551 557 goto recheck; 552 558 } 559 553 560 fibril_mutex_unlock(&input_mutex); 554 561 } … … 580 587 ipcarg_t arg2; 581 588 ipcarg_t arg3; 582 583 int cons_ccap; 589 584 590 int rc; 585 591 … … 622 628 if (cons == active_console) { 623 629 async_req_0_0(fb_info.phone, FB_FLUSH); 624 625 630 curs_goto(cons->scr.position_x, cons->scr.position_y); 626 631 } … … 650 655 break; 651 656 case CONSOLE_GET_COLOR_CAP: 652 rc = ccap_fb_to_con(fb_info.color_cap, & cons_ccap);657 rc = ccap_fb_to_con(fb_info.color_cap, &arg1); 653 658 if (rc != EOK) { 654 659 ipc_answer_0(callid, rc); 655 660 continue; 656 661 } 657 arg1 = cons_ccap;658 662 break; 659 663 case CONSOLE_SET_STYLE: … … 714 718 return false; 715 719 } 716 720 717 721 kbd_phone = fd_phone(input_fd); 718 722 if (kbd_phone < 0) { … … 720 724 return false; 721 725 } 722 726 723 727 /* NB: The callback connection is slotted for removal */ 724 728 ipcarg_t phonehash; … … 727 731 return false; 728 732 } 729 733 730 734 async_new_connection(phonehash, 0, NULL, keyboard_events); 731 735 732 736 /* Connect to mouse device */ 733 737 mouse_phone = -1; 734 738 int mouse_fd = open("/dev/hid_in/mouse", O_RDONLY); 735 739 736 740 if (mouse_fd < 0) { 737 741 printf(NAME ": Notice - failed opening %s\n", "/dev/hid_in/mouse"); 738 742 goto skip_mouse; 739 743 } 740 744 741 745 mouse_phone = fd_phone(mouse_fd); 742 746 if (mouse_phone < 0) { … … 744 748 goto skip_mouse; 745 749 } 746 750 747 751 if (ipc_connect_to_me(mouse_phone, SERVICE_CONSOLE, 0, 0, &phonehash) != 0) { 748 752 printf(NAME ": Failed to create callback from mouse device\n"); … … 750 754 goto skip_mouse; 751 755 } 752 756 753 757 async_new_connection(phonehash, 0, NULL, mouse_events); 754 758 skip_mouse: 755 759 756 760 /* Connect to framebuffer driver */ 757 761 fb_info.phone = ipc_connect_me_to_blocking(PHONE_NS, SERVICE_VIDEO, 0, 0); … … 760 764 return -1; 761 765 } 762 766 763 767 /* Register driver */ 764 768 int rc = devmap_driver_register(NAME, client_connection); … … 772 776 773 777 /* Synchronize, the gcons could put something in queue */ 774 ipcarg_t color_cap;775 778 async_req_0_0(fb_info.phone, FB_FLUSH); 776 779 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; 780 async_req_0_1(fb_info.phone, FB_GET_COLOR_CAP, &fb_info.color_cap); 779 781 780 782 /* Set up shared memory buffer. */ … … 827 829 async_serialize_start(); 828 830 gcons_redraw_console(); 829 set_ rgb_color(DEFAULT_FOREGROUND, DEFAULT_BACKGROUND);831 set_style(STYLE_NORMAL); 830 832 screen_clear(); 831 833 curs_goto(0, 0); -
uspace/srv/hid/console/gcons.c
r38aaacc2 rf4f866c 54 54 #define STATUS_HEIGHT 48 55 55 56 #define MAIN_COLOR 0xffffff 56 #define COLOR_MAIN 0xffffff 57 #define COLOR_FOREGROUND 0x202020 58 #define COLOR_BACKGROUND 0xffffff 59 60 extern char _binary_gfx_helenos_ppm_start[0]; 61 extern int _binary_gfx_helenos_ppm_size; 62 extern char _binary_gfx_nameic_ppm_start[0]; 63 extern int _binary_gfx_nameic_ppm_size; 64 65 extern char _binary_gfx_anim_1_ppm_start[0]; 66 extern int _binary_gfx_anim_1_ppm_size; 67 extern char _binary_gfx_anim_2_ppm_start[0]; 68 extern int _binary_gfx_anim_2_ppm_size; 69 extern char _binary_gfx_anim_3_ppm_start[0]; 70 extern int _binary_gfx_anim_3_ppm_size; 71 extern char _binary_gfx_anim_4_ppm_start[0]; 72 extern int _binary_gfx_anim_4_ppm_size; 73 74 extern char _binary_gfx_cons_selected_ppm_start[0]; 75 extern int _binary_gfx_cons_selected_ppm_size; 76 extern char _binary_gfx_cons_idle_ppm_start[0]; 77 extern int _binary_gfx_cons_idle_ppm_size; 78 extern char _binary_gfx_cons_has_data_ppm_start[0]; 79 extern int _binary_gfx_cons_has_data_ppm_size; 80 extern char _binary_gfx_cons_kernel_ppm_start[0]; 81 extern int _binary_gfx_cons_kernel_ppm_size; 57 82 58 83 static bool use_gcons = false; … … 82 107 static size_t active_console = 0; 83 108 84 s ize_t mouse_x;85 s ize_t mouse_y;86 87 bool btn_pressed;88 s ize_t btn_x;89 s ize_t btn_y;109 static ipcarg_t mouse_x = 0; 110 static ipcarg_t mouse_y= 0; 111 112 static bool btn_pressed = false; 113 static ipcarg_t btn_x = 0; 114 static ipcarg_t btn_y = 0; 90 115 91 116 static void vp_switch(int vp) … … 95 120 96 121 /** Create view port */ 97 static int vp_create( size_t x, size_t y, size_t width, size_t height)122 static int vp_create(ipcarg_t x, ipcarg_t y, ipcarg_t width, ipcarg_t height) 98 123 { 99 124 return async_req_2_0(fbphone, FB_VIEWPORT_CREATE, (x << 16) | y, … … 112 137 113 138 /** Transparent putchar */ 114 static void tran_putch(wchar_t ch, size_t col, size_t row)139 static void tran_putch(wchar_t ch, ipcarg_t col, ipcarg_t row) 115 140 { 116 141 async_msg_3(fbphone, FB_PUTCHAR, ch, col, row); … … 259 284 void gcons_mouse_move(ssize_t dx, ssize_t dy) 260 285 { 261 mouse_x = limit(mouse_x + dx, 0, xres); 262 mouse_y = limit(mouse_y + dy, 0, yres); 263 286 ssize_t nx = (ssize_t) mouse_x + dx; 287 ssize_t ny = (ssize_t) mouse_y + dy; 288 289 mouse_x = (size_t) limit(nx, 0, xres); 290 mouse_y = (size_t) limit(ny, 0, yres); 291 264 292 if (active_console != KERNEL_CONSOLE) 265 293 async_msg_2(fbphone, FB_POINTER_MOVE, mouse_x, mouse_y); 266 294 } 267 295 268 static int gcons_find_conbut(i nt x, int y)269 { 270 i nt status_start = STATUS_START + (xres - 800) / 2;296 static int gcons_find_conbut(ipcarg_t x, ipcarg_t y) 297 { 298 ipcarg_t status_start = STATUS_START + (xres - 800) / 2; 271 299 272 300 if ((y < STATUS_TOP) || (y >= STATUS_TOP + STATUS_HEIGHT)) … … 278 306 if (x >= status_start + (STATUS_WIDTH + STATUS_SPACE) * CONSOLE_COUNT) 279 307 return -1; 308 280 309 if (((x - status_start) % (STATUS_WIDTH + STATUS_SPACE)) < STATUS_SPACE) 281 310 return -1; 282 311 283 return (x - status_start) / (STATUS_WIDTH + STATUS_SPACE); 312 ipcarg_t btn = (x - status_start) / (STATUS_WIDTH + STATUS_SPACE); 313 314 if (btn < CONSOLE_COUNT) 315 return btn; 316 317 return -1; 284 318 } 285 319 … … 287 321 * 288 322 * @param state New state (true - pressed, false - depressed) 323 * 289 324 */ 290 325 int gcons_mouse_btn(bool state) 291 326 { 292 int conbut; 327 /* Ignore mouse clicks if no buttons 328 are drawn at all */ 329 if (xres < 800) 330 return -1; 293 331 294 332 if (state) { 295 conbut = gcons_find_conbut(mouse_x, mouse_y);333 int conbut = gcons_find_conbut(mouse_x, mouse_y); 296 334 if (conbut != -1) { 297 335 btn_pressed = true; … … 307 345 btn_pressed = false; 308 346 309 conbut = gcons_find_conbut(mouse_x, mouse_y);347 int conbut = gcons_find_conbut(mouse_x, mouse_y); 310 348 if (conbut == gcons_find_conbut(btn_x, btn_y)) 311 349 return conbut; … … 313 351 return -1; 314 352 } 315 316 353 317 354 /** Draw a PPM pixmap to framebuffer … … 321 358 * @param x Coordinate of upper left corner 322 359 * @param y Coordinate of upper left corner 323 */ 324 static void draw_pixmap(char *logo, size_t size, int x, int y) 325 { 326 char *shm; 327 int rc; 328 360 * 361 */ 362 static void draw_pixmap(char *logo, size_t size, ipcarg_t x, ipcarg_t y) 363 { 329 364 /* Create area */ 330 shm = mmap(NULL, size, PROTO_READ | PROTO_WRITE, MAP_SHARED |365 char *shm = mmap(NULL, size, PROTO_READ | PROTO_WRITE, MAP_SHARED | 331 366 MAP_ANONYMOUS, 0, 0); 332 367 if (shm == MAP_FAILED) … … 336 371 337 372 /* Send area */ 338 rc = async_req_1_0(fbphone, FB_PREPARE_SHM, (ipcarg_t) shm);373 int rc = async_req_1_0(fbphone, FB_PREPARE_SHM, (ipcarg_t) shm); 339 374 if (rc) 340 375 goto exit; … … 356 391 } 357 392 358 extern char _binary_gfx_helenos_ppm_start[0];359 extern int _binary_gfx_helenos_ppm_size;360 extern char _binary_gfx_nameic_ppm_start[0];361 extern int _binary_gfx_nameic_ppm_size;362 363 393 /** Redraws console graphics */ 364 394 void gcons_redraw_console(void) 365 395 { 366 int i;367 368 396 if (!use_gcons) 369 397 return; 370 398 371 399 vp_switch(0); 372 set_rgb_color( MAIN_COLOR, MAIN_COLOR);400 set_rgb_color(COLOR_MAIN, COLOR_MAIN); 373 401 clear(); 374 402 draw_pixmap(_binary_gfx_helenos_ppm_start, … … 377 405 (size_t) &_binary_gfx_nameic_ppm_size, 5, 17); 378 406 407 unsigned int i; 379 408 for (i = 0; i < CONSOLE_COUNT; i++) 380 409 redraw_state(i); … … 393 422 static int make_pixmap(char *data, size_t size) 394 423 { 395 char *shm;396 int rc;397 int pxid = -1;398 399 424 /* Create area */ 400 shm = mmap(NULL, size, PROTO_READ | PROTO_WRITE, MAP_SHARED |425 char *shm = mmap(NULL, size, PROTO_READ | PROTO_WRITE, MAP_SHARED | 401 426 MAP_ANONYMOUS, 0, 0); 402 427 if (shm == MAP_FAILED) … … 405 430 memcpy(shm, data, size); 406 431 432 int pxid = -1; 433 407 434 /* Send area */ 408 rc = async_req_1_0(fbphone, FB_PREPARE_SHM, (ipcarg_t) shm);435 int rc = async_req_1_0(fbphone, FB_PREPARE_SHM, (ipcarg_t) shm); 409 436 if (rc) 410 437 goto exit; … … 432 459 } 433 460 434 extern char _binary_gfx_anim_1_ppm_start[0];435 extern int _binary_gfx_anim_1_ppm_size;436 extern char _binary_gfx_anim_2_ppm_start[0];437 extern int _binary_gfx_anim_2_ppm_size;438 extern char _binary_gfx_anim_3_ppm_start[0];439 extern int _binary_gfx_anim_3_ppm_size;440 extern char _binary_gfx_anim_4_ppm_start[0];441 extern int _binary_gfx_anim_4_ppm_size;442 443 461 static void make_anim(void) 444 462 { 445 int an = async_req_1_0(fbphone, FB_ANIM_CREATE, cstatus_vp[KERNEL_CONSOLE]); 463 int an = async_req_1_0(fbphone, FB_ANIM_CREATE, 464 cstatus_vp[KERNEL_CONSOLE]); 446 465 if (an < 0) 447 466 return; … … 467 486 animation = an; 468 487 } 469 470 extern char _binary_gfx_cons_selected_ppm_start[0];471 extern int _binary_gfx_cons_selected_ppm_size;472 extern char _binary_gfx_cons_idle_ppm_start[0];473 extern int _binary_gfx_cons_idle_ppm_size;474 extern char _binary_gfx_cons_has_data_ppm_start[0];475 extern int _binary_gfx_cons_has_data_ppm_size;476 extern char _binary_gfx_cons_kernel_ppm_start[0];477 extern int _binary_gfx_cons_kernel_ppm_size;478 488 479 489 /** Initialize nice graphical console environment */ … … 500 510 501 511 /* Create status buttons */ 502 size_t status_start = STATUS_START + (xres - 800) / 2;512 ipcarg_t status_start = STATUS_START + (xres - 800) / 2; 503 513 size_t i; 504 514 for (i = 0; i < CONSOLE_COUNT; i++) { … … 511 521 512 522 vp_switch(cstatus_vp[i]); 513 set_rgb_color( 0x202020, 0xffffff);523 set_rgb_color(COLOR_FOREGROUND, COLOR_BACKGROUND); 514 524 } 515 525 -
uspace/srv/hid/console/gcons.h
r38aaacc2 rf4f866c 38 38 #include <sys/types.h> 39 39 40 void gcons_init(int phone);40 void gcons_init(int); 41 41 42 42 void gcons_redraw_console(void); 43 void gcons_change_console(size_t index);44 void gcons_notify_char(size_t index);43 void gcons_change_console(size_t); 44 void gcons_notify_char(size_t); 45 45 void gcons_in_kernel(void); 46 46 47 void gcons_notify_connect(size_t index);48 void gcons_notify_disconnect(size_t index);47 void gcons_notify_connect(size_t); 48 void gcons_notify_disconnect(size_t); 49 49 50 void gcons_mouse_move(ssize_t dx, ssize_t dy);50 void gcons_mouse_move(ssize_t, ssize_t); 51 51 int gcons_mouse_btn(bool state); 52 52 -
uspace/srv/hid/console/keybuffer.h
r38aaacc2 rf4f866c 47 47 typedef struct { 48 48 console_event_t fifo[KEYBUFFER_SIZE]; 49 unsigned longhead;50 unsigned longtail;51 unsigned longitems;49 size_t head; 50 size_t tail; 51 size_t items; 52 52 } keybuffer_t; 53 53
Note:
See TracChangeset
for help on using the changeset viewer.
