vpp/extras/emacs/elog-4-int-track-skel.el

48 lines
1.4 KiB
EmacsLisp
Raw Normal View History

;;; Copyright (c) 2016 Cisco and/or its affiliates.
;;; Licensed under the Apache License, Version 2.0 (the "License");
;;; you may not use this file except in compliance with the License.
;;; You may obtain a copy of the License at:
;;;
;;; http://www.apache.org/licenses/LICENSE-2.0
;;;
;;; Unless required by applicable law or agreed to in writing, software
;;; distributed under the License is distributed on an "AS IS" BASIS,
;;; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
;;; See the License for the specific language governing permissions and
;;; limitations under the License.
;;; elog-4-int-skel.el - 4 integer elog skeleton
(require 'skeleton)
(define-skeleton skel-elog-4-int-track
"Insert a skeleton 4-integer-with-track event definition"
nil
'(setq function-name (skeleton-read "Function: "))
'(setq track-label (skeleton-read "Track Label: "))
'(setq label (skeleton-read "Label: "))
"
/* $$$ May or may not be needed */
#include <vlib/vlib.h>
#include <vppinfra/elog.h>
static inline void " function-name " (u32 *data)
{
ELOG_TYPE_DECLARE(e) =
{
.format = \"" label ": first %d second %d third %d fourth %d\",
.format_args = \"i4i4i4i4\",
};
struct { u32 data[4];} * ed;
ELOG_TRACK(" track-label ");
ed = ELOG_TRACK_DATA (&vlib_global_main.elog_main, e, " track-label ");
ed->data[0] = data[0];
ed->data[1] = data[1];
ed->data[2] = data[2];
ed->data[3] = data[3];
}
")