| ;;; 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]; |
| } |
| |
| ") |