Citrix Windows Pv Drivers Download

Contents • • • • • • • • • • • • • • • • • • • • • • • • • Presentation: by Paul Durrant, 2015 Notes: Slide 1 Hi, I’m Paul Durrant. I’m a principal engineer in the XenServer group at Citrix and I’m project lead for the XenProject Windows PV Drivers. Slide 2 In this presentation I’m going to be giving an overview of the drivers.

We’ll start with the origins of the drivers, and the journey from the original XenServer-specific closed-source ‘Legacy’ drivers, through the open source XenServer drivers (dubbed the ‘Standard’ drivers in Citrix and available on GitHub), to the current generic XenProject drivers, the source of which is now hosted on Xenbits. I’ll then move on to the way that functionality is broken down into interfaces, how they are provided and consumed, and how compatibility is maintained as they evolve. And finally I’ll give a brief overview of what you need to do to build and install the drivers, and contribute to the project.

Slide 3 To start with I need to introduce some Windows driver terminology and some conventions I’ve used in the diagrams in this presentation. Windows devices are organized into a tree, or a set of trees, rooted at what’s called a Physical Device Object or PDO.

Xen - HVM domU Notices: The software drivers provided on this page are generic versions and can be used for general purposes. However, computer original equipment manufacturers (OEMs) may have altered the features, incorporated customizations, or made other changes to the software or software packaging they provide.

In my view of the world trees grow downwards so I put PDOs at the top  Normally a PDO just represents a piece of hardware, which is not that useful unless you have some code to talk to it. That code is called a Function Driver and when a function driver attaches to a PDO it creates a corresponding Function Device Object or FDO. Unlike some OS, such as Linux, Windows has a concept of demand-loading drivers. Hence function drivers do not contain code to discover their hardware. Instead they are part of a package described by what is called an INF file. In that INF file there are entries to tell Windows what PDO ‘names’ a particular function driver will ‘bind’ to, So, as Windows builds its device tree it can look at the names of newly created PDOs and determine which Function Drivers to load. A Function Driver can also be what’s called a Bus Driver.

That means that, having created its FDO, it can also create PDOs. For example, the root PCI driver binds to a PDO created by the ACPI driver (which is parsing the DSDT). It will create an FDO to bind to that, enumerate the root bus (using PCI config cycles) and create a PDO for each unique bus/device/function that it finds.

Ariston li 670 duo manual dexterity. Slide 4 The first set of drivers we’ll mention are the closed source ‘Legacy’ drivers. Before XenServer 6.1 was released, these were the only PV drivers and they were getting pretty long in the tooth.

Windows

I believe they were written for Windows 2000 support on the first version of XenServer (or possibly even XenEnterprise?) to support HVM guests. They are still used in XenServer today, but only for Windows Server 2003 (and XP before it went EOL).

Citrix have never provided source for these drivers, and that is mainly because there is code in them that is of unknown origin. Also, there is less and less point in doing so as time goes.