Received: by 10.223.164.202 with SMTP id h10csp1626693wrb; Sat, 18 Nov 2017 02:58:28 -0800 (PST) X-Google-Smtp-Source: AGs4zMY84gx9prJukg6SqbPFt5J0ojRWg+L4b12+Dj8DPd9WSuBdNoY/tOXZ6AbfsnBSBtHwtp/b X-Received: by 10.99.151.66 with SMTP id d2mr7671034pgo.178.1511002708304; Sat, 18 Nov 2017 02:58:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511002708; cv=none; d=google.com; s=arc-20160816; b=NsutNEAeHrd91A/gya+ou8QcEURTfTAf7qNF7E7ov5KMtAphzBr0kGdyMr8c5mL18f 1zkVSn9lJ8TD22m7lMp3Ucx/QADOMNWhWIbImV9BS1Ag7eyLrY4muY9NU+vMbjXvUwSv 9mcjZgzvbnj9X8V8bwjpp8dz5+7X5+21MPwI0PWDtSbfF21DNXVg6VVHRdb7S2/fvAVq 5mKiyw9EEfs5w0fQUYNurGZjexCxDUh0vXumUkfl2e56Zg2GhHYnrwcxIinHTcpq6Z2Q 0uHgpjUGt9e6DCOM0n8iTQ8FZd5phYpj7mVlszYPW2VwY7gLvZnWGXBKawwUXlGlel1u yLVw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=N34K4UTRzthejOeGQ2hJUDcRTpUBEZo+BBjBvcroSKM=; b=WnPMZFGijD4ZoxDvGkoJxVvR+HlIpPxInRnQIBHgla1bhfvJ0YxQLqFsAGQ/m7Wrox ltwdjfQjgMuKcJkOudHpTCdOtd+ZiC9VdsvLlkMBevjDhn6gW+CvSoDo8zPCcTp9Pn6S jeeWcNbddD21zm93N+vrGljR+1nWdmfD/Ay8wFJp/DqvTopMPseV8ZipwMDvjSA7kyNv WRS9YkVMA9a0PPsnw0fbNrE7XXmFhAaMHqhj8SYPvIGaZD96WaAzVbmpbG5FVX43fF0M cRE6RrVdfUuFePuh/vzxGIuPknuwQVEeTL25ycIH8BwazM7Q6tYQg/oII06mo+toOy+D AsYw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w5si4836519pfk.132.2017.11.18.02.58.15; Sat, 18 Nov 2017 02:58:28 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S966531AbdKQUlQ (ORCPT + 93 others); Fri, 17 Nov 2017 15:41:16 -0500 Received: from mga02.intel.com ([134.134.136.20]:61933 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935928AbdKQUey (ORCPT ); Fri, 17 Nov 2017 15:34:54 -0500 Received: from orsmga003.jf.intel.com ([10.7.209.27]) by orsmga101.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 17 Nov 2017 12:34:54 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.44,411,1505804400"; d="scan'208";a="3489234" Received: from mjglynn-mobl.ger.corp.intel.com (HELO localhost) ([10.254.124.112]) by orsmga003.jf.intel.com with ESMTP; 17 Nov 2017 12:34:52 -0800 From: Tom Zanussi To: rostedt@goodmis.org Cc: tglx@linutronix.de, mhiramat@kernel.org, namhyung@kernel.org, vedang.patel@intel.com, bigeasy@linutronix.de, joel.opensrc@gmail.com, joelaf@google.com, mathieu.desnoyers@efficios.com, baohong.liu@intel.com, rajvi.jingar@intel.com, julia@ni.com, fengguang.wu@intel.com, linux-kernel@vger.kernel.org, linux-rt-users@vger.kernel.org, Tom Zanussi Subject: [PATCH v6 21/37] tracing: Add hist_field 'type' field Date: Fri, 17 Nov 2017 14:33:00 -0600 Message-Id: <6776041835ecafbcc3a8a37585e20c5eb5a96353.1510948725.git.tom.zanussi@linux.intel.com> X-Mailer: git-send-email 1.9.3 In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Future support for synthetic events requires hist_field 'type' information, so add a field for that. Also, make other hist_field attribute usage consistent (size, is_signed, etc). Signed-off-by: Tom Zanussi --- kernel/trace/trace_events_hist.c | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/kernel/trace/trace_events_hist.c b/kernel/trace/trace_events_hist.c index db903ce..d22cdfd 100644 --- a/kernel/trace/trace_events_hist.c +++ b/kernel/trace/trace_events_hist.c @@ -54,6 +54,7 @@ struct hist_field { unsigned int size; unsigned int offset; unsigned int is_signed; + const char *type; struct hist_field *operands[HIST_FIELD_OPERANDS_MAX]; struct hist_trigger_data *hist_data; struct hist_var var; @@ -712,6 +713,7 @@ static void destroy_hist_field(struct hist_field *hist_field, kfree(hist_field->var.name); kfree(hist_field->name); + kfree(hist_field->type); kfree(hist_field); } @@ -737,6 +739,10 @@ static struct hist_field *create_hist_field(struct hist_trigger_data *hist_data, if (flags & HIST_FIELD_FL_HITCOUNT) { hist_field->fn = hist_field_counter; + hist_field->size = sizeof(u64); + hist_field->type = kstrdup("u64", GFP_KERNEL); + if (!hist_field->type) + goto free; goto out; } @@ -750,12 +756,18 @@ static struct hist_field *create_hist_field(struct hist_trigger_data *hist_data, hist_field->fn = hist_field_log2; hist_field->operands[0] = create_hist_field(hist_data, field, fl, NULL); hist_field->size = hist_field->operands[0]->size; + hist_field->type = kstrdup(hist_field->operands[0]->type, GFP_KERNEL); + if (!hist_field->type) + goto free; goto out; } if (flags & HIST_FIELD_FL_TIMESTAMP) { hist_field->fn = hist_field_timestamp; hist_field->size = sizeof(u64); + hist_field->type = kstrdup("u64", GFP_KERNEL); + if (!hist_field->type) + goto free; goto out; } @@ -765,6 +777,11 @@ static struct hist_field *create_hist_field(struct hist_trigger_data *hist_data, if (is_string_field(field)) { flags |= HIST_FIELD_FL_STRING; + hist_field->size = MAX_FILTER_STR_VAL; + hist_field->type = kstrdup(field->type, GFP_KERNEL); + if (!hist_field->type) + goto free; + if (field->filter_type == FILTER_STATIC_STRING) hist_field->fn = hist_field_string; else if (field->filter_type == FILTER_DYN_STRING) @@ -772,6 +789,12 @@ static struct hist_field *create_hist_field(struct hist_trigger_data *hist_data, else hist_field->fn = hist_field_pstring; } else { + hist_field->size = field->size; + hist_field->is_signed = field->is_signed; + hist_field->type = kstrdup(field->type, GFP_KERNEL); + if (!hist_field->type) + goto free; + hist_field->fn = select_value_fn(field->size, field->is_signed); if (!hist_field->fn) { @@ -981,6 +1004,11 @@ static struct hist_field *parse_unary(struct hist_trigger_data *hist_data, expr->operands[0] = operand1; expr->operator = FIELD_OP_UNARY_MINUS; expr->name = expr_str(expr, 0); + expr->type = kstrdup(operand1->type, GFP_KERNEL); + if (!expr->type) { + ret = -ENOMEM; + goto free; + } return expr; free: @@ -1070,6 +1098,11 @@ static struct hist_field *parse_expr(struct hist_trigger_data *hist_data, expr->operands[1] = operand2; expr->operator = field_op; expr->name = expr_str(expr, 0); + expr->type = kstrdup(operand1->type, GFP_KERNEL); + if (!expr->type) { + ret = -ENOMEM; + goto free; + } switch (field_op) { case FIELD_OP_MINUS: -- 1.9.3 From 1583558427077108950@xxx Thu Nov 09 03:43:20 +0000 2017 X-GM-THRID: 1583483886934922232 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread