Date: Tue, 12 Apr 2016 22:44:47 +0000 (UTC) From: Warren Block <wblock@FreeBSD.org> To: doc-committers@freebsd.org, svn-doc-all@freebsd.org, svn-doc-head@freebsd.org Subject: svn commit: r48596 - head/en_US.ISO8859-1/htdocs/news/status Message-ID: <201604122244.u3CMilpm076347@repo.freebsd.org>
next in thread | raw e-mail | index | archive | help
Author: wblock Date: Tue Apr 12 22:44:47 2016 New Revision: 48596 URL: https://svnweb.freebsd.org/changeset/doc/48596 Log: Add report on BIS drivers from Dexuan Cui <decui@microsoft.com>. Modified: head/en_US.ISO8859-1/htdocs/news/status/report-2016-01-2016-03.xml Modified: head/en_US.ISO8859-1/htdocs/news/status/report-2016-01-2016-03.xml ============================================================================== --- head/en_US.ISO8859-1/htdocs/news/status/report-2016-01-2016-03.xml Tue Apr 12 22:31:59 2016 (r48595) +++ head/en_US.ISO8859-1/htdocs/news/status/report-2016-01-2016-03.xml Tue Apr 12 22:44:47 2016 (r48596) @@ -1331,4 +1331,173 @@ <help></help> </project> + + <project cat='kern'> + <title>FreeBSD Integration Services (BIS)</title> + + <contact> + <person> + <name> + <given>Sepherosa</given> + <common>Ziehau</common> + </name> + <email>sepherosa@gmail.com</email> + </person> + + <person> + <name> + <given>Howard</given> + <common>Su</common> + </name> + <email>howard0su@gmail.com</email> + </person> + + <person> + <name> + <given>Hongjiang</given> + <common>Zhang</common> + </name> + <email>honzhan@microsoft.com</email> + </person> + + <person> + <name> + <given>Dexuan</given> + <common>Cui</common> + </name> + <email>decui@microsoft.com</email> + </person> + </contact> + + <links> + <url href="https://wiki.FreeBSD.org/HyperV">FreeBSD Virtual Machines on Microsoft Hyper-V</url> + <url href="https://technet.microsoft.com/en-us/library/dn531030.aspx">Supported Linux and FreeBSD virtual machines for Hyper-V on Windows</url> + </links> + + <body> + <p>When &os; virtual machines (VMs) run on Hyper-V, using + Hyper-V synthetic devices is recommended to get the best + network and storage performance and make full use of all the + benefits that Hyper-V provides. The collection of drivers that + are required to use Hyper-V synthetic devices in FreeBSD are + known as FreeBSD Integration Services (BIS). Some of the BIS + drivers (like network and storage drivers) have existed in + FreeBSD 9.x and 10.x for years, but there are still some + performance and stability issues and bugs. Compared with + Windows and Linux VMs, the current BIS lacks some useful + features, e.g., live virtual machine backup, TRIM/Unmap, the + support for UEFI VM (boot from UEFI), etc.</p> + + <p>During the past quarter, we made a great progress on the + performance tuning for Hyper-V network driver. We also + refactored and cleaned up the VMBus driver, and fixed some + important bugs. All the work makes FreeBSD VMs run even better + on Hyper-V and the Hyper-V based cloud platform Azure!</p> + + <p>Our work during 2016Q1 is documented below:</p> + + <p>Optimizing the performance of Hyper-V network driver</p> + + <ul> + <li>We added the LRO (Large Receive Offloading) support to the + driver and properly handled the ACK packets. This + effectively reduced the CPU cycles used in the TCP/IP stack + and dramatically boosted the network performance!</li> + + <li>We enabled the vRSS (virtual Receive Side Scaling) support + for the driver. This greatly improved the network + performance for SMP virtual machine (VM).</li> + + <li>We used a separate Tx kernel thread to relieve the Rx + thread of transmitting packets (the Rx thread tried to + transmit packets after receiving ACKs), so the Rx thread can + receive packets and send ACKs faster.</li> + + <li>Now we can reach a VM-to-VM throughput of 9.1Gbps on a + host with 10Gbps physical NIC, and over 20Gbps on a host + with 40Gbps NIC, and meanwhile the CPUs still have plenty of + cycles for applications.</li> + + <li>We also enabled IP header checksum offloading, and RX + checksum offloading for UDP.</li> + + <li>Further performance tuning is working in progress.</li> + </ul> + + <p>Refactoring and Cleaning up the VMBus driver code</p> + + <ul> + <li>Instead of using swi threads directly, now we use per-CPU + taskqueue_create_fast() threads for event and message + handling, making the code more FreeBSD conventional.</li> + + <li>Made a lot of cleanup to the hv_utils code (HeartBeat, + TimeSync and Shutdown) and we are further cleaning up the + KVP code.</li> + + <li>Used a new message/interrupt slot for Hyper-V timer, so + the handling of timer and non-timer messages can be + distinguished, fixing a potential issue.</li> + + <li>Instead of finding an available IDT vector by hacking, + we're changing to use the normal method, i.e., + lapic_ipi_alloc().</li> + + <li>We're modularizing the Hyper-V modules: 1) they will be + loaded in the loader; 2) we're going to enhance devd(8) to + improve the hot plug case.</li> + </ul> + + <p>Bug Fixing</p> + + <ul> + <li>Fixed the "spurious multiple disks" issue (PR 206630 ??? + FreeBSD 10.2 on Windows 10 and 2016 server may not boot due + to multiple invalid disks issue) in the Hyper-V storage + driver and now FreeBSD VM can reliably boot on Win10 and + 2016 hosts.</li> + + <li>Fixed the OACTIVE issue (PR 207297 - [Hyper-V] FreeBSD + 10.2 on hyperv lost network under heavy load for + OACTIVE).</li> + + <li>Fixed TSC calibration issue (PR 208238 - [Hyper-V] TSC + frequency is not correctly detected: "calcru: runtime went + backwards") and we won't see the "runtime went backwards" + messages anymore!</li> + + <li>Fixed the "very slow terminal" issue of 11-CURRENT by + enabling text mode when we're running on hypervisors.</li> + + <li>Fixed the "unknown dhcp option value 0xf5" issue in + <tt>dhclient(8)</tt> by asking <tt>dhclient(8)</tt> to + ignore the option and &os; VM on Azure can reliably get IP + now.</li> + </ul> + + <p>Found a workaround for PR 20824 ([Hyper-V] VM network may not + work over virtual switch based on wireless NIC): add + "net.link.ether.inet.max_age=60" in /etc/sysctl.conf.</p> + + <p>We plan to add support for live virtual machine backup, + TRIM/Unmap, and UEFI VMs (Hyper-V Generation-2 VMs).</p> + + <p>We published errata (FreeBSD-EN-16:04.hyperv, + FreeBSD-EN-16:05.hv_netvsc) with the Release Engineering team, + so 10.1 and 10.2 users can easily get the fixes of KVP and TCP + checksum by upgrading the system.</p> + + <p>We published BIS test cases for Hyper-V on github: + https://github.com/FreeBSDonHyper-V/Test-BIS and we are going + to publish the test cases for Azure soon.</p> + + <p>This project is sponsored by Microsoft.</p> + </body> + + <sponsor> + Microsoft + </sponsor> + + <help></help> + </project> </report>
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201604122244.u3CMilpm076347>