From patchwork Tue Oct 2 08:43:18 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Hunt, David" X-Patchwork-Id: 45808 Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id E29C63576; Tue, 2 Oct 2018 10:43:45 +0200 (CEST) Received: from mga17.intel.com (mga17.intel.com [192.55.52.151]) by dpdk.org (Postfix) with ESMTP id 23AE32952 for ; Tue, 2 Oct 2018 10:43:39 +0200 (CEST) X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by fmsmga107.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 02 Oct 2018 01:43:37 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.54,331,1534834800"; d="scan'208";a="268705631" Received: from silpixa00399952.ir.intel.com (HELO silpixa00399952.ger.corp.intel.com) ([10.237.223.64]) by fmsmga006.fm.intel.com with ESMTP; 02 Oct 2018 01:43:31 -0700 From: David Hunt To: dev@dpdk.org Cc: john.mcnamara@intel.com, stephen@networkplumber.org, lei.a.yao@intel.com, anatoly.burakov@intel.com Date: Tue, 2 Oct 2018 09:43:18 +0100 Message-Id: <20181002084328.57127-1-david.hunt@intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20180926163727.47337-1-david.hunt@intel.com> References: <20180926163727.47337-1-david.hunt@intel.com> Subject: [dpdk-dev] [PATCH v6 0/10] add json power policy interface for containers X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" The current vm_power_manager example app has the capability to accept power policies from virtual machines via virtio-serial channels. These power policies allow a virtual machine to give information to the power manager to allow the power manager take care of the power management of the virtual machine based on the information in the policy. This power policy functionality is limited to virtual machines sending the policies to the power manager (which runs in the Host OS), and a solution was needed for additional methods of sending power policies to the power manager app. The main use-case for this modification is for containers and host applications that wish to send polices to the power manager. This patchset adds the capability to send power polices and power commands to the vm_power_manager app via JSON strings through a fifo on the file system. For example, given the following file, policy.json: {"policy": { "name": "ubuntu2", "command": "create", "policy_type": "TIME", "busy_hours":[ 17, 18, 19, 20, 21, 22, 23 ], "quiet_hours":[ 2, 3, 4, 5, 6 ], "core_list":[ 11, 12, 13 ] }} Then running the command: cat policy.json >/tmp/powermonitor/fifo The policy is sent to the vm_power_manager. The power manager app then parses the JSON data, and inserts the policy into the array of policies. Part of the patch series contains documentation updates to give all the details of the valid name-value pairs, the data types, etc. Patch v2: * Fixed review comments from Stephen Hemminger and Lei A Yao. * Added a check in the Makefile for libjansson-dev. Will Warn user and build without JSON functionality if not present, will build including JSON functionality if it is present. Patch v3: * Added meson/ninja support for vm_power_manager and guest_cli apps * Fixed compilation issue with guest_cli app Patch v4: * Split out some unrelated changes to separate patches in the set * Some changes out of review by Anatoly (Thanks!) Patch v5: * Removed the directory with JSON examples, as they already exist in the documentation. * Fixed some typos and formatting issues in the documentation. * Changed the JSON examples in the documentation to 'javascript' causing the syntax to be highlighted nicely. * Inherited the Acks from previous version. Patch v6: * Added ability to set WORKLOAD policy to LOW, MEDIUM, or HIGH. "workload": "MEDIUM" * Added missing functionality to allow passing of a list of mac addresses for the TRAFFIC profile type. "mac_list":[ "de:ad:be:ef:01:01", "de:ad:be:ef:01:02" ] * Updated docs to include both of the above additions. [01/10] examples/power: add checks around hypervisor [02/10] examples/power: allow for number of vms to be zero [03/10] lib/power: add changes for host commands/policies [04/10] examples/power: add necessary changes to guest app [05/10] examples/power: add host channel to power manager [06/10] examples/power: increase allowed number of clients [07/10] examples/power: add json string handling [08/10] examples/power: clean up verbose messages [09/10] examples/power: add meson/ninja build support [10/10] doc/vm_power_manager: add JSON interface API info