X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2Ftdm_monitor_server.c;h=a68ce21ad83be99e662b0f4e4866a00115893160;hb=2adc0c96b4af5f88b3560e8ebd0b595a3f483578;hp=c5bda9572d3d9d0738efef570b5a3d73d7034969;hpb=a18be1c14ab996cf0c9aad64778b97f8af111a70;p=platform%2Fcore%2Fuifw%2Flibtdm.git diff --git a/src/tdm_monitor_server.c b/src/tdm_monitor_server.c index c5bda95..a68ce21 100644 --- a/src/tdm_monitor_server.c +++ b/src/tdm_monitor_server.c @@ -9,7 +9,7 @@ * Taeheon Kim , * YoungJun Cho , * SooChan Lim , - * Boram Park + * Boram Park * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the @@ -33,18 +33,11 @@ * **************************************************************************/ -#include -#include -#include -#include - -#include "tdm.h" #include "tdm_private.h" -#include "tdm_helper.h" -#include "tdm_log.h" #define TDM_DBG_SERVER_ARGS_MAX 32 +/* LCOV_EXCL_START */ static void _tdm_monitor_server_usage(char *app_name, char *reply, int *len); static void @@ -54,6 +47,23 @@ _tdm_monitor_server_query(unsigned int pid, char *cwd, int argc, char *argv[], c } static void +_tdm_monitor_server_protocol_trace(unsigned int pid, char *cwd, int argc, char *argv[], char *reply, int *len, tdm_display *dpy) +{ + int enable; + + if (argc < 3) { + _tdm_monitor_server_usage(argv[0], reply, len); + return; + } + + enable = atoi(argv[2]); + + tdm_event_loop_trace_enable(dpy, enable); + + TDM_SNPRINTF(reply, len, "protocol trace: '%s'\n", (enable) ? "enabled" : "disabled"); +} + +static void _tdm_monitor_server_dpms(unsigned int pid, char *cwd, int argc, char *argv[], char *reply, int *len, tdm_display *dpy) { tdm_output *output; @@ -87,6 +97,25 @@ _tdm_monitor_server_dpms(unsigned int pid, char *cwd, int argc, char *argv[], ch } static void +_tdm_monitor_server_ttrace(unsigned int pid, char *cwd, int argc, char *argv[], char *reply, int *len, tdm_display *dpy) +{ + int output_id = 0; + char *end; + tdm_error ret; + + if (argc < 3) { + _tdm_monitor_server_usage(argv[0], reply, len); + return; + } + + if (argv[3]) + output_id = strtol(argv[3], &end, 10); + + ret = tdm_display_enable_ttrace(dpy, argv[2], output_id, reply, len); + TDM_DBG_RETURN_IF_FAIL(ret == TDM_ERROR_NONE); +} + +static void _tdm_monitor_server_debug(unsigned int pid, char *cwd, int argc, char *argv[], char *reply, int *len, tdm_display *dpy) { int level; @@ -150,16 +179,144 @@ _tdm_monitor_server_log_path(unsigned int pid, char *cwd, int argc, char *argv[] tdm_log_enable_color(0); } - if (tdm_display_enable_path((const char*)fd_name) != TDM_ERROR_NONE) { - TDM_SNPRINTF(reply, len, "failed: '%s'\n", path); - return; - } + tdm_log_set_path((const char*)fd_name); done: TDM_SNPRINTF(reply, len, "log path: '%s'\n", path); } static void +_tdm_monitor_server_choose_commit_per_vblank_mode(unsigned int pid, char *cwd, int argc, char *argv[], char *reply, int *len, tdm_display *dpy) +{ + int output_idx; + int mode; + char *arg; + char *end; + tdm_error err; + + /* TODO: do we have to provide an ability to choose commit_per_vblank mode outside? */ + + if (argc < 4) { + _tdm_monitor_server_usage(argv[0], reply, len); + return; + } + + arg = argv[2]; + output_idx = strtol(arg, &end, 10); + + arg = argv[3]; + mode = strtol(arg, &end, 10); + + err = tdm_output_choose_commit_per_vblank_mode(tdm_display_get_output(dpy, output_idx, NULL), mode); + if (err != TDM_ERROR_NONE) { + TDM_SNPRINTF(reply, len, "an error: output_idx or mode is wrong\n"); + return; + } + + TDM_SNPRINTF(reply, len, "the mode's been set\n"); +} + +static void +_tdm_monitor_server_fps(unsigned int pid, char *cwd, int argc, char *argv[], char *reply, int *len, tdm_display *dpy) +{ + int enable; + char *arg; + char *end; + + if (argc < 3) { + _tdm_monitor_server_usage(argv[0], reply, len); + return; + } + + arg = argv[2]; + enable = strtol(arg, &end, 10); + + tdm_display_enable_fps(dpy, enable); + + TDM_SNPRINTF(reply, len, "%s to print fps\n", (enable) ? "enable" : "disable"); +} + +static void +_tdm_monitor_server_vblank_list(unsigned int pid, char *cwd, int argc, char *argv[], + char *reply, int *len, tdm_display *dpy) +{ + tdm_vblank_get_vblank_list_information(dpy, reply, len); +} + +static void +_tdm_monitor_server_vblank_fps(unsigned int pid, char *cwd, int argc, char *argv[], + char *reply, int *len, tdm_display *dpy) +{ + unsigned int target_pid, fps; + char *arg; + char *end; + char name[TDM_NAME_LEN]; + tdm_error ret; + + if (argc < 3) { + _tdm_monitor_server_usage(argv[0], reply, len); + return; + } + + arg = argv[2]; + target_pid = strtol(arg, &end, 10); + + if (*end == ',') { + arg = end + 1; + end = strtostr(name, TDM_NAME_LEN, arg, TDM_DELIM); + } else { + strncpy(name, TDM_VBLANK_DEFAULT_NAME, TDM_NAME_LEN - 1); + name[TDM_NAME_LEN - 1] = '\0'; + } + + if (*end != '@') { + TDM_SNPRINTF(reply, len, "failed: no fps value\n"); + return; + } + + arg = end + 1; + fps = strtol(arg, &end, 10); + + ret = tdm_vblank_set_client_vblank_fps(target_pid, name, fps); + if (ret != TDM_ERROR_NONE) { + TDM_SNPRINTF(reply, len, "can't set '%u' fps to '%s' client vblank(PID:%u)\n", fps, name, target_pid); + return; + } + + TDM_SNPRINTF(reply, len, "success: '%u' fps for '%s' client vblank(PID:%u)\n", fps, name, target_pid); +} + +static void +_tdm_monitor_server_global_fps(unsigned int pid, char *cwd, int argc, char *argv[], + char *reply, int *len, tdm_display *dpy) +{ + unsigned int fps; + char *arg; + char *end; + tdm_error ret; + + if (argc < 3) { + _tdm_monitor_server_usage(argv[0], reply, len); + return; + } + + arg = argv[2]; + fps = strtol(arg, &end, 10); + + if (fps > 0) + ret = tdm_vblank_enable_global_fps(1, fps); + else + ret = tdm_vblank_enable_global_fps(0, 0); + + if (ret != TDM_ERROR_NONE) { + TDM_SNPRINTF(reply, len, "can't set '%u' fps to global fps\n", fps); + return; + } + + TDM_SNPRINTF(reply, len, "success: '%u' global fps\n", fps); +} + +static void _tdm_monitor_server_prop(unsigned int pid, char *cwd, int argc, char *argv[], char *reply, int *len, tdm_display *dpy) { tdm_output *output; @@ -195,6 +352,10 @@ _tdm_monitor_server_prop(unsigned int pid, char *cwd, int argc, char *argv[], ch arg = end + 1; prop_name = strtok_r(arg, ",", &end); + if (!prop_name) { + TDM_SNPRINTF(reply, len, "failed: get prop_name by strtok_r\n"); + return; + } if (*end == '\0') { TDM_SNPRINTF(reply, len, "failed: no value\n"); @@ -202,6 +363,10 @@ _tdm_monitor_server_prop(unsigned int pid, char *cwd, int argc, char *argv[], ch } arg = strtok_r(NULL, TDM_DELIM, &end); + if (!arg) { + TDM_SNPRINTF(reply, len, "failed: get arg by strtok_r\n"); + return; + } value.u32 = strtol(arg, &end, 10); output = tdm_display_get_output(dpy, output_idx, &ret); @@ -255,6 +420,63 @@ _tdm_monitor_server_dump(unsigned int pid, char *cwd, int argc, char *argv[], ch tdm_display_enable_dump(dpy, (const char*)argv[2], reply, len); } +static void +_tdm_monitor_server_punch(unsigned int pid, char *cwd, int argc, char *argv[], char *reply, int *len, tdm_display *dpy) +{ + char *arg, *end; + unsigned int output_id, layer_id; + tdm_output *output; + tdm_layer *layer; + tbm_surface_h buffer; + + arg = argv[2]; + + output_id = strtol(arg, &end, 10); + output = tdm_display_get_output(dpy, output_id, NULL); + if (!output) { + TDM_SNPRINTF(reply, len, "not found output\n"); + return; + } + if (*end != ',') { + TDM_SNPRINTF(reply, len, "not found ','\n"); + return; + } + + arg = end + 1; + layer_id = strtol(arg, &end, 10); + layer = tdm_output_get_layer(output, layer_id, NULL); + if (!layer) { + TDM_SNPRINTF(reply, len, "not found layer\n"); + return; + } + + buffer = tdm_layer_get_displaying_buffer(layer, NULL); + if (!buffer) { + TDM_SNPRINTF(reply, len, "not found buffer\n"); + return; + } + + if (*end == ':') { + tdm_pos pos = {0,}; + + arg = end + 1; + pos.w = strtol(arg, &end, 10); + TDM_EXIT_IF_FAIL(*end == 'x'); + arg = end + 1; + pos.h = strtol(arg, &end, 10); + if (*end == '+') { + arg = end + 1; + pos.x = strtol(arg, &end, 10); + TDM_EXIT_IF_FAIL(*end == '+'); + arg = end + 1; + pos.y = strtol(arg, &end, 10); + } + + tdm_helper_clear_buffer_pos(buffer, &pos); + } else + tdm_helper_clear_buffer(buffer); +} + static struct { const char *opt; void (*func)(unsigned int pid, char *cwd, int argc, char *argv[], char *reply, int *len, tdm_display *dpy); @@ -267,10 +489,22 @@ static struct { "show tdm output, layer information", NULL, NULL }, { + "trace", _tdm_monitor_server_protocol_trace, + "enable/disable the wl protocol", + "", + "0 or 1" + }, + { "dpms", _tdm_monitor_server_dpms, "set output dpms", ":", "0:3 or 0:0" }, { + "ttrace", _tdm_monitor_server_ttrace, + "enable/disable ttrace (module: none,vsync,client_vblank,server_vblank,vblank,layer,pp,capture,all", + "[@]", + NULL + }, + { "debug", _tdm_monitor_server_debug, "set the debug level and modules(module: none, mutex, buffer, thread, vblank)", "[@[,]]", @@ -283,6 +517,36 @@ static struct { "console" }, { + "choose_commit_per_vblank_mode", _tdm_monitor_server_choose_commit_per_vblank_mode, + "choose a commit_per_vblank mode for the output", + " ", + "0 1 or 1 2 or 2 0" + }, + { + "fps", _tdm_monitor_server_fps, + "enable/disable to print fps", + "", + "0 or 1" + }, + { + "vblank_list", _tdm_monitor_server_vblank_list, + "print the client vblank list", + NULL, + NULL + }, + { + "vblank_fps", _tdm_monitor_server_vblank_fps, + "set the client vblank fps for the given process ID and client vblank name", + "[,]@", + NULL + }, + { + "global_fps", _tdm_monitor_server_global_fps, + "set the global vblank fps for the entire system", + "", + NULL + }, + { "prop", _tdm_monitor_server_prop, "set the property of a output or a layer", "[,]:,", @@ -294,7 +558,13 @@ static struct { "\t\t layer, pp, capture - start to dump buffers of layer, pp, capture\n" "\t\t none - stop to dump buffers\n" "\t\t current - dump the current buffer of all layers", - "[,[,...]]@[]", + "[,[,...]][@]", + NULL + }, + { + "punch", _tdm_monitor_server_punch, + "punch a layer", + ",[:x[++]]", NULL }, }; @@ -386,3 +656,4 @@ tdm_monitor_server_command(tdm_display *dpy, const char *options, char *reply, i _tdm_monitor_server_command(pid, cwd, dpy, argc, argv, reply, len); } +/* LCOV_EXCL_STOP */