2018-03-12 09:31:36 -04:00
|
|
|
;;; 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.
|
|
|
|
|
2016-01-04 15:27:42 -05:00
|
|
|
How to construct a complete plugin using the emacs skeletons
|
|
|
|
|
|
|
|
0. Install open-vpp, including the development package.
|
|
|
|
|
|
|
|
1. Load emacs skeletons
|
|
|
|
|
|
|
|
M-x find-file all-skel.el
|
|
|
|
M-x eval-buffer
|
|
|
|
|
|
|
|
2. Pick a single-word, lower-case name for your plugin. For example: macswap.
|
|
|
|
Hereafter, we'll refer to the selected name as <plugin-name>.
|
|
|
|
|
|
|
|
3. Generate the entire plugin:
|
|
|
|
|
|
|
|
M-x make-plugin
|
|
|
|
Plugin-name: <plugin-name>
|
|
|
|
|
|
|
|
Or, generate each file individually:
|
|
|
|
|
|
|
|
3. Create the required directories, e.g. under .../vpp
|
|
|
|
|
|
|
|
$ mkdir -p <plugin-name>-plugin/<plugin-name>
|
|
|
|
|
|
|
|
4. Create <plugin-name>-plugin/{configure.ac,Makefile.am}
|
|
|
|
|
|
|
|
M-x find-file <plugin-name>-plugin/configure.ac
|
|
|
|
M-x plugin-configure-skel
|
|
|
|
|
|
|
|
M-x find-file <plugin-name>-plugin/Makefile.am
|
2016-03-18 07:22:15 -07:00
|
|
|
M-x skel-plugin-makefile
|
2016-01-04 15:27:42 -05:00
|
|
|
|
|
|
|
5. Create the api skeleton
|
|
|
|
M-x find-file <plugin-name>-plugin/<plugin-name>/<plugin-name>.api
|
2016-03-18 07:22:15 -07:00
|
|
|
M-x skel-plugin-api
|
2016-01-04 15:27:42 -05:00
|
|
|
|
|
|
|
6. Create the api message enumeration header file
|
|
|
|
M-x find-file <plugin-name>-plugin/<plugin-name>/<plugin-name>_msg_enum.h
|
2016-03-18 07:22:15 -07:00
|
|
|
M-x skel-plugin-msg-enum
|
2016-01-04 15:27:42 -05:00
|
|
|
|
|
|
|
7. Create the "all-api" header file
|
|
|
|
M-x find-file <plugin-name>-plugin/<plugin-name>/<plugin-name>_all_api_h.h
|
2016-03-18 07:22:15 -07:00
|
|
|
M-x skel-plugin-all-apih
|
2016-01-04 15:27:42 -05:00
|
|
|
|
|
|
|
8. Create the main data structure definition header file
|
|
|
|
M-x find-file <plugin-name>-plugin/<plugin-name>/<plugin-name>.h
|
2016-03-18 07:22:15 -07:00
|
|
|
M-x skel-plugin-h
|
2016-01-04 15:27:42 -05:00
|
|
|
|
|
|
|
9. Create the plugin main C file
|
|
|
|
M-x find-file <plugin-name>-plugin/<plugin-name>/<plugin-name>.c
|
2016-03-18 07:22:15 -07:00
|
|
|
M-x skel-plugin-main
|
2016-01-04 15:27:42 -05:00
|
|
|
|
|
|
|
10. Create the vpp-api-test plugin main C file
|
|
|
|
M-x find-file <plugin-name>-plugin/<plugin-name>/<plugin-name>_test.c
|
2016-03-18 07:22:15 -07:00
|
|
|
M-x skel-plugin-test
|
2016-01-04 15:27:42 -05:00
|
|
|
|
|
|
|
11. Create the data plane packet processing node
|
|
|
|
M-x find-file <plugin-name>-plugin/<plugin-name>/node.c
|
2016-03-18 07:22:15 -07:00
|
|
|
M-x skel-plugin-node
|
2016-01-04 15:27:42 -05:00
|
|
|
|
|
|
|
12. Process autotools input files
|
|
|
|
|
|
|
|
$ cd <plugin-name>-plugin
|
|
|
|
$ autoreconf -i -f
|
|
|
|
|
|
|
|
13. Build the plugin skeleton
|
|
|
|
|
|
|
|
$ mkdir build
|
|
|
|
$ cd build
|
2017-01-11 11:11:00 +01:00
|
|
|
$ ../configure
|
2016-01-04 15:27:42 -05:00
|
|
|
$ make
|
|
|
|
$ sudo make install
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|