blob: 880035a50824acf8da2e7f6fe3a943c0a1702f0c [file] [log] [blame]
Dave Barach8d0f2f02018-03-12 09:31:36 -04001;;; Copyright (c) 2016 Cisco and/or its affiliates.
2;;; Licensed under the Apache License, Version 2.0 (the "License");
3;;; you may not use this file except in compliance with the License.
4;;; You may obtain a copy of the License at:
5;;;
6;;; http://www.apache.org/licenses/LICENSE-2.0
7;;;
8;;; Unless required by applicable law or agreed to in writing, software
9;;; distributed under the License is distributed on an "AS IS" BASIS,
10;;; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11;;; See the License for the specific language governing permissions and
12;;; limitations under the License.
13
Dave Barache5389bb2016-03-28 17:12:19 -040014;;; elog-4-int-skel.el - 4 integer elog skeleton
15
16(require 'skeleton)
17
18(define-skeleton skel-elog-4-int-track
19"Insert a skeleton 4-integer-with-track event definition"
20nil
21'(setq function-name (skeleton-read "Function: "))
22'(setq track-label (skeleton-read "Track Label: "))
23'(setq label (skeleton-read "Label: "))
24
25"
26
27/* $$$ May or may not be needed */
28#include <vlib/vlib.h>
29#include <vppinfra/elog.h>
30
31static inline void " function-name " (u32 *data)
32{
33 ELOG_TYPE_DECLARE(e) =
34 {
35 .format = \"" label ": first %d second %d third %d fourth %d\",
36 .format_args = \"i4i4i4i4\",
37 };
38 struct { u32 data[4];} * ed;
39 ELOG_TRACK(" track-label ");
40 ed = ELOG_TRACK_DATA (&vlib_global_main.elog_main, e, " track-label ");
41 ed->data[0] = data[0];
42 ed->data[1] = data[1];
43 ed->data[2] = data[2];
44 ed->data[3] = data[3];
45}
46
47")