All of lore.kernel.org
 help / color / mirror / Atom feed
From: Joao Pinto <Joao.Pinto@synopsys.com>
To: Kishon Vijay Abraham I <kishon@ti.com>,
	Bjorn Helgaas <bhelgaas@google.com>,
	Jingoo Han <jingoohan1@gmail.com>,
	Joao Pinto <Joao.Pinto@synopsys.com>
Cc: <linux-pci@vger.kernel.org>, <linux-doc@vger.kernel.org>,
	<linux-kernel@vger.kernel.org>, <devicetree@vger.kernel.org>,
	<linux-omap@vger.kernel.org>,
	<linux-arm-kernel@lists.infradead.org>, <nsekhar@ti.com>
Subject: Re: [PATCH v2 02/22] Documentation: PCI: Guide to use PCI Endpoint Core Layer
Date: Fri, 17 Feb 2017 11:43:17 +0000	[thread overview]
Message-ID: <c7b32fa3-0b69-8ffe-ab0a-581e4e784c12@synopsys.com> (raw)
In-Reply-To: <1487325042-28227-3-git-send-email-kishon@ti.com>

Às 9:50 AM de 2/17/2017, Kishon Vijay Abraham I escreveu:
> Add Documentation to help users use endpoint library to enable endpoint
> mode in the PCI controller and add new PCI endpoint functions.
> 
> Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
> ---
>  Documentation/PCI/00-INDEX                  |    2 +
>  Documentation/PCI/endpoint/pci-endpoint.txt |  190 +++++++++++++++++++++++++++
>  2 files changed, 192 insertions(+)
>  create mode 100644 Documentation/PCI/endpoint/pci-endpoint.txt
> 
> diff --git a/Documentation/PCI/00-INDEX b/Documentation/PCI/00-INDEX
> index 147231f..ba950b2 100644
> --- a/Documentation/PCI/00-INDEX
> +++ b/Documentation/PCI/00-INDEX
> @@ -12,3 +12,5 @@ pci.txt
>  	- info on the PCI subsystem for device driver authors
>  pcieaer-howto.txt
>  	- the PCI Express Advanced Error Reporting Driver Guide HOWTO
> +endpoint/pci-endpoint.txt
> +	- guide to add endpoint controller driver and endpoint function driver.
> diff --git a/Documentation/PCI/endpoint/pci-endpoint.txt b/Documentation/PCI/endpoint/pci-endpoint.txt
> new file mode 100644
> index 0000000..68a7839
> --- /dev/null
> +++ b/Documentation/PCI/endpoint/pci-endpoint.txt
> @@ -0,0 +1,190 @@
> +			    PCI ENDPOINT FRAMEWORK
> +		    Kishon Vijay Abraham I <kishon@ti.com>
> +
> +This document is a guide to use the PCI Endpoint Framework in order to create
> +endpoint controller driver, endpoint function driver and using configfs
> +interface to bind the function driver to the controller driver.
> +
> +1. Introduction
> +
> +*Linux* has a comprehensive PCI subsystem to support PCI controllers that
> +operates in Root Complex mode. The subsystem has capability to scan PCI bus,
> +assign memory resources and irq resources, load PCI driver (based on
> +vendorid, deviceid), support other services like hot-plug, power management,
> +advanced error reporting and virtual channels.
> +
> +However PCI controller IPs integrated in certain SoC is capable of operating
> +either in Root Complex mode or Endpoint mode. PCI Endpoint Framework will
> +add endpoint mode support in *Linux*. This will help to run Linux in an
> +EP system which can have a wide variety of use cases from testing or
> +validation, co-processor accelerator etc..
> +
> +2. PCI Endpoint Core
> +
> +The PCI Endpoint Core layer comprises of 3 components: the Endpoint Controller
> +library, the Endpoint Function library and the configfs layer to bind the
> +endpoint function with the endpoint controller.
> +
> +2.1 PCI Endpoint Controller(EPC) Library
> +
> +The EPC library provides APIs to be used by the controller that can operate
> +in endpoint mode. It also provides APIs to be used by function driver/library
> +in order to implement a particular endpoint function.
> +
> +2.1.1 APIs for the PCI controller Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI controller driver.
> +
> +*) devm_pci_epc_create()/pci_epc_create()
> +
> +   The PCI controller driver should implement the following ops:
> +	 * write_header: ops to populate configuration space header
> +	 * set_bar: ops to configure the BAR
> +	 * clear_bar: ops to reset the BAR
> +	 * alloc_addr_space: ops to allocate *in* PCI controller address space
> +	 * free_addr_space: ops to free the allocated address space
> +	 * raise_irq: ops to raise a legacy or MSI interrupt
> +	 * start: ops to start the PCI link
> +	 * stop: ops to stop the PCI link
> +
> +   The PCI controller driver can then create a new EPC device by invoking
> +   devm_pci_epc_create/pci_epc_create.
> +
> +*) devm_pci_epc_destroy()/pci_epc_destroy()
> +
> +   The PCI controller driver can destroy the EPC device created by either
> +   devm_pci_epc_create or pci_epc_create using devm_pci_epc_destroy() or
> +   /pci_epc_destroy()
> +
> +2.1.2 APIs for the PCI Endpoint Function Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI endpoint function driver.
> +
> +*) pci_epc_write_header()
> +
> +   The PCI endpoint function driver should use pci_epc_write_header() to
> +   write the standard configuration header to the endpoint controller.
> +
> +*) pci_epc_set_bar()
> +
> +   The PCI endpoint function driver should use pci_epc_set_bar() to configure
> +   the Base Address Register in order for the host to assign PCI addr space.
> +   Register space of the function driver is usually configured
> +   using this API.
> +
> +*) pci_epc_clear_bar()
> +
> +   The PCI endpoint function driver should use pci_epc_clear_bar() to reset
> +   the BAR.
> +
> +*) pci_epc_raise_irq()
> +
> +   The PCI endpoint function driver should use pci_epc_raise_irq() to raise
> +   Legacy Interrupt or MSI Interrupt.
> +
> +*) pci_epc_start()
> +
> +   The PCI endpoint function driver should invoke pci_epc_start() once it
> +   has configured the endpoint function and wants to start the PCI link.
> +
> +*) pci_epc_stop()
> +
> +   The PCI endpoint function driver should invoke pci_epc_stop() to stop
> +   the PCI LINK.
> +
> +2.1.3 Other APIs
> +
> +There are other APIs provided by the EPC library. These are used for binding
> +the epf device with epc device. pci-ep-cfs.c can be used as reference for
> +using these APIs.
> +
> +*) pci_epc_get()
> +
> +   Get a reference to the pci endpoint controller based on the device name of
> +   the controller.
> +
> +*) pci_epc_put()
> +
> +   Release the reference to the pci endpoint controller obtained using
> +   pci_epc_get()
> +
> +*) pci_epc_add_epf()
> +
> +   Add a pci endpoint function to a pci endpoint controller. A pcie device
> +   can have upto 8 functions according to the specification.
> +
> +*) pci_epc_remove_epf()
> +
> +   Remove the pci endpoint function from pci endpoint controller.
> +
> +2.2 PCI Endpoint Function(EPF) Library
> +
> +The EPF library provides APIs to be used by the function driver and the EPC
> +library in order to provide endpoint mode functionality.
> +
> +2.2.1 APIs for the PCI Endpoint Function Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI endpoint function driver.
> +
> +*) pci_epf_register_driver()
> +
> +   The PCI Endpoint Function driver should implement the following ops:
> +	 * bind: ops to perform when a EPC device has been bound to EPF device
> +	 * unbind: ops to perform when a binding has been lost between a EPC
> +	   device and EPF device
> +	 * linkup: ops to perform when the EPC device has established a
> +	   connection with a host system
> +
> +  The PCI Function driver can then register the PCI EPF driver by using
> +  pci_epf_register_driver().
> +
> +*) pci_epf_unregister_driver()
> +
> +  The PCI Function driver can unregister the PCI EPF driver by using
> +  pci_epf_unregister_driver().
> +
> +*) pci_epf_alloc_space()
> +
> +  The PCI Function driver can allocate space for a particular BAR using
> +  pci_epf_alloc_space().
> +
> +*) pci_epf_free_space()
> +
> +  The PCI Function driver can free the allocated space
> +  (using pci_epf_alloc_space) by invoking pci_epf_free_space().
> +
> +2.2.2 APIs for the PCI Endpoint Controller Library
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI endpoint controller library.
> +
> +*) pci_epf_linkup()
> +
> +   The PCI endpoint controller library invokes pci_epf_linkup() when the
> +   EPC device has established the connection to the host.
> +
> +2.2.2 Other APIs
> +There are other APIs provided by the EPF library. These are used to notify
> +the function driver when the EPF device is bound to the EPC device.
> +pci-ep-cfs.c can be used as reference for using these APIs.
> +
> +*) pci_epf_create()
> +
> +   Create a new PCI EPF device by passing the name of the PCI EPF device.
> +   This name will be used to bind the the EPF device to a EPF driver.
> +
> +*) pci_epf_destroy()
> +
> +   Destroy the created PCI EPF device.
> +
> +*) pci_epf_bind()
> +
> +   pci_epf_bind() should be invoked when the EPF device has been bound to
> +   a EPC device.
> +
> +*) pci_epf_unbind()
> +
> +   pci_epf_unbind() should be invoked when the binding between EPC device
> +   and EPF device is lost.
> 

Good initial reference guide.

Acked-By: Joao Pinto <jpinto@synopsys.com>

WARNING: multiple messages have this Message-ID (diff)
From: Joao Pinto <Joao.Pinto-HKixBCOQz3hWk0Htik3J/w@public.gmane.org>
To: Kishon Vijay Abraham I <kishon-l0cyMroinI0@public.gmane.org>,
	Bjorn Helgaas <bhelgaas-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>,
	Jingoo Han <jingoohan1-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>,
	Joao Pinto <Joao.Pinto-HKixBCOQz3hWk0Htik3J/w@public.gmane.org>
Cc: linux-pci-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-doc-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-omap-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org,
	nsekhar-l0cyMroinI0@public.gmane.org
Subject: Re: [PATCH v2 02/22] Documentation: PCI: Guide to use PCI Endpoint Core Layer
Date: Fri, 17 Feb 2017 11:43:17 +0000	[thread overview]
Message-ID: <c7b32fa3-0b69-8ffe-ab0a-581e4e784c12@synopsys.com> (raw)
In-Reply-To: <1487325042-28227-3-git-send-email-kishon-l0cyMroinI0@public.gmane.org>

Às 9:50 AM de 2/17/2017, Kishon Vijay Abraham I escreveu:
> Add Documentation to help users use endpoint library to enable endpoint
> mode in the PCI controller and add new PCI endpoint functions.
> 
> Signed-off-by: Kishon Vijay Abraham I <kishon-l0cyMroinI0@public.gmane.org>
> ---
>  Documentation/PCI/00-INDEX                  |    2 +
>  Documentation/PCI/endpoint/pci-endpoint.txt |  190 +++++++++++++++++++++++++++
>  2 files changed, 192 insertions(+)
>  create mode 100644 Documentation/PCI/endpoint/pci-endpoint.txt
> 
> diff --git a/Documentation/PCI/00-INDEX b/Documentation/PCI/00-INDEX
> index 147231f..ba950b2 100644
> --- a/Documentation/PCI/00-INDEX
> +++ b/Documentation/PCI/00-INDEX
> @@ -12,3 +12,5 @@ pci.txt
>  	- info on the PCI subsystem for device driver authors
>  pcieaer-howto.txt
>  	- the PCI Express Advanced Error Reporting Driver Guide HOWTO
> +endpoint/pci-endpoint.txt
> +	- guide to add endpoint controller driver and endpoint function driver.
> diff --git a/Documentation/PCI/endpoint/pci-endpoint.txt b/Documentation/PCI/endpoint/pci-endpoint.txt
> new file mode 100644
> index 0000000..68a7839
> --- /dev/null
> +++ b/Documentation/PCI/endpoint/pci-endpoint.txt
> @@ -0,0 +1,190 @@
> +			    PCI ENDPOINT FRAMEWORK
> +		    Kishon Vijay Abraham I <kishon-l0cyMroinI0@public.gmane.org>
> +
> +This document is a guide to use the PCI Endpoint Framework in order to create
> +endpoint controller driver, endpoint function driver and using configfs
> +interface to bind the function driver to the controller driver.
> +
> +1. Introduction
> +
> +*Linux* has a comprehensive PCI subsystem to support PCI controllers that
> +operates in Root Complex mode. The subsystem has capability to scan PCI bus,
> +assign memory resources and irq resources, load PCI driver (based on
> +vendorid, deviceid), support other services like hot-plug, power management,
> +advanced error reporting and virtual channels.
> +
> +However PCI controller IPs integrated in certain SoC is capable of operating
> +either in Root Complex mode or Endpoint mode. PCI Endpoint Framework will
> +add endpoint mode support in *Linux*. This will help to run Linux in an
> +EP system which can have a wide variety of use cases from testing or
> +validation, co-processor accelerator etc..
> +
> +2. PCI Endpoint Core
> +
> +The PCI Endpoint Core layer comprises of 3 components: the Endpoint Controller
> +library, the Endpoint Function library and the configfs layer to bind the
> +endpoint function with the endpoint controller.
> +
> +2.1 PCI Endpoint Controller(EPC) Library
> +
> +The EPC library provides APIs to be used by the controller that can operate
> +in endpoint mode. It also provides APIs to be used by function driver/library
> +in order to implement a particular endpoint function.
> +
> +2.1.1 APIs for the PCI controller Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI controller driver.
> +
> +*) devm_pci_epc_create()/pci_epc_create()
> +
> +   The PCI controller driver should implement the following ops:
> +	 * write_header: ops to populate configuration space header
> +	 * set_bar: ops to configure the BAR
> +	 * clear_bar: ops to reset the BAR
> +	 * alloc_addr_space: ops to allocate *in* PCI controller address space
> +	 * free_addr_space: ops to free the allocated address space
> +	 * raise_irq: ops to raise a legacy or MSI interrupt
> +	 * start: ops to start the PCI link
> +	 * stop: ops to stop the PCI link
> +
> +   The PCI controller driver can then create a new EPC device by invoking
> +   devm_pci_epc_create/pci_epc_create.
> +
> +*) devm_pci_epc_destroy()/pci_epc_destroy()
> +
> +   The PCI controller driver can destroy the EPC device created by either
> +   devm_pci_epc_create or pci_epc_create using devm_pci_epc_destroy() or
> +   /pci_epc_destroy()
> +
> +2.1.2 APIs for the PCI Endpoint Function Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI endpoint function driver.
> +
> +*) pci_epc_write_header()
> +
> +   The PCI endpoint function driver should use pci_epc_write_header() to
> +   write the standard configuration header to the endpoint controller.
> +
> +*) pci_epc_set_bar()
> +
> +   The PCI endpoint function driver should use pci_epc_set_bar() to configure
> +   the Base Address Register in order for the host to assign PCI addr space.
> +   Register space of the function driver is usually configured
> +   using this API.
> +
> +*) pci_epc_clear_bar()
> +
> +   The PCI endpoint function driver should use pci_epc_clear_bar() to reset
> +   the BAR.
> +
> +*) pci_epc_raise_irq()
> +
> +   The PCI endpoint function driver should use pci_epc_raise_irq() to raise
> +   Legacy Interrupt or MSI Interrupt.
> +
> +*) pci_epc_start()
> +
> +   The PCI endpoint function driver should invoke pci_epc_start() once it
> +   has configured the endpoint function and wants to start the PCI link.
> +
> +*) pci_epc_stop()
> +
> +   The PCI endpoint function driver should invoke pci_epc_stop() to stop
> +   the PCI LINK.
> +
> +2.1.3 Other APIs
> +
> +There are other APIs provided by the EPC library. These are used for binding
> +the epf device with epc device. pci-ep-cfs.c can be used as reference for
> +using these APIs.
> +
> +*) pci_epc_get()
> +
> +   Get a reference to the pci endpoint controller based on the device name of
> +   the controller.
> +
> +*) pci_epc_put()
> +
> +   Release the reference to the pci endpoint controller obtained using
> +   pci_epc_get()
> +
> +*) pci_epc_add_epf()
> +
> +   Add a pci endpoint function to a pci endpoint controller. A pcie device
> +   can have upto 8 functions according to the specification.
> +
> +*) pci_epc_remove_epf()
> +
> +   Remove the pci endpoint function from pci endpoint controller.
> +
> +2.2 PCI Endpoint Function(EPF) Library
> +
> +The EPF library provides APIs to be used by the function driver and the EPC
> +library in order to provide endpoint mode functionality.
> +
> +2.2.1 APIs for the PCI Endpoint Function Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI endpoint function driver.
> +
> +*) pci_epf_register_driver()
> +
> +   The PCI Endpoint Function driver should implement the following ops:
> +	 * bind: ops to perform when a EPC device has been bound to EPF device
> +	 * unbind: ops to perform when a binding has been lost between a EPC
> +	   device and EPF device
> +	 * linkup: ops to perform when the EPC device has established a
> +	   connection with a host system
> +
> +  The PCI Function driver can then register the PCI EPF driver by using
> +  pci_epf_register_driver().
> +
> +*) pci_epf_unregister_driver()
> +
> +  The PCI Function driver can unregister the PCI EPF driver by using
> +  pci_epf_unregister_driver().
> +
> +*) pci_epf_alloc_space()
> +
> +  The PCI Function driver can allocate space for a particular BAR using
> +  pci_epf_alloc_space().
> +
> +*) pci_epf_free_space()
> +
> +  The PCI Function driver can free the allocated space
> +  (using pci_epf_alloc_space) by invoking pci_epf_free_space().
> +
> +2.2.2 APIs for the PCI Endpoint Controller Library
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI endpoint controller library.
> +
> +*) pci_epf_linkup()
> +
> +   The PCI endpoint controller library invokes pci_epf_linkup() when the
> +   EPC device has established the connection to the host.
> +
> +2.2.2 Other APIs
> +There are other APIs provided by the EPF library. These are used to notify
> +the function driver when the EPF device is bound to the EPC device.
> +pci-ep-cfs.c can be used as reference for using these APIs.
> +
> +*) pci_epf_create()
> +
> +   Create a new PCI EPF device by passing the name of the PCI EPF device.
> +   This name will be used to bind the the EPF device to a EPF driver.
> +
> +*) pci_epf_destroy()
> +
> +   Destroy the created PCI EPF device.
> +
> +*) pci_epf_bind()
> +
> +   pci_epf_bind() should be invoked when the EPF device has been bound to
> +   a EPC device.
> +
> +*) pci_epf_unbind()
> +
> +   pci_epf_unbind() should be invoked when the binding between EPC device
> +   and EPF device is lost.
> 

Good initial reference guide.

Acked-By: Joao Pinto <jpinto-HKixBCOQz3hWk0Htik3J/w@public.gmane.org>
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

WARNING: multiple messages have this Message-ID (diff)
From: Joao Pinto <Joao.Pinto@synopsys.com>
To: Kishon Vijay Abraham I <kishon@ti.com>,
	Bjorn Helgaas <bhelgaas@google.com>,
	Jingoo Han <jingoohan1@gmail.com>,
	Joao Pinto <Joao.Pinto@synopsys.com>
Cc: devicetree@vger.kernel.org, linux-doc@vger.kernel.org,
	linux-pci@vger.kernel.org, nsekhar@ti.com,
	linux-kernel@vger.kernel.org, linux-omap@vger.kernel.org,
	linux-arm-kernel@lists.infradead.org
Subject: Re: [PATCH v2 02/22] Documentation: PCI: Guide to use PCI Endpoint Core Layer
Date: Fri, 17 Feb 2017 11:43:17 +0000	[thread overview]
Message-ID: <c7b32fa3-0b69-8ffe-ab0a-581e4e784c12@synopsys.com> (raw)
In-Reply-To: <1487325042-28227-3-git-send-email-kishon@ti.com>

=C0s 9:50 AM de 2/17/2017, Kishon Vijay Abraham I escreveu:
> Add Documentation to help users use endpoint library to enable endpoint
> mode in the PCI controller and add new PCI endpoint functions.
> =

> Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
> ---
>  Documentation/PCI/00-INDEX                  |    2 +
>  Documentation/PCI/endpoint/pci-endpoint.txt |  190 +++++++++++++++++++++=
++++++
>  2 files changed, 192 insertions(+)
>  create mode 100644 Documentation/PCI/endpoint/pci-endpoint.txt
> =

> diff --git a/Documentation/PCI/00-INDEX b/Documentation/PCI/00-INDEX
> index 147231f..ba950b2 100644
> --- a/Documentation/PCI/00-INDEX
> +++ b/Documentation/PCI/00-INDEX
> @@ -12,3 +12,5 @@ pci.txt
>  	- info on the PCI subsystem for device driver authors
>  pcieaer-howto.txt
>  	- the PCI Express Advanced Error Reporting Driver Guide HOWTO
> +endpoint/pci-endpoint.txt
> +	- guide to add endpoint controller driver and endpoint function driver.
> diff --git a/Documentation/PCI/endpoint/pci-endpoint.txt b/Documentation/=
PCI/endpoint/pci-endpoint.txt
> new file mode 100644
> index 0000000..68a7839
> --- /dev/null
> +++ b/Documentation/PCI/endpoint/pci-endpoint.txt
> @@ -0,0 +1,190 @@
> +			    PCI ENDPOINT FRAMEWORK
> +		    Kishon Vijay Abraham I <kishon@ti.com>
> +
> +This document is a guide to use the PCI Endpoint Framework in order to c=
reate
> +endpoint controller driver, endpoint function driver and using configfs
> +interface to bind the function driver to the controller driver.
> +
> +1. Introduction
> +
> +*Linux* has a comprehensive PCI subsystem to support PCI controllers that
> +operates in Root Complex mode. The subsystem has capability to scan PCI =
bus,
> +assign memory resources and irq resources, load PCI driver (based on
> +vendorid, deviceid), support other services like hot-plug, power managem=
ent,
> +advanced error reporting and virtual channels.
> +
> +However PCI controller IPs integrated in certain SoC is capable of opera=
ting
> +either in Root Complex mode or Endpoint mode. PCI Endpoint Framework will
> +add endpoint mode support in *Linux*. This will help to run Linux in an
> +EP system which can have a wide variety of use cases from testing or
> +validation, co-processor accelerator etc..
> +
> +2. PCI Endpoint Core
> +
> +The PCI Endpoint Core layer comprises of 3 components: the Endpoint Cont=
roller
> +library, the Endpoint Function library and the configfs layer to bind the
> +endpoint function with the endpoint controller.
> +
> +2.1 PCI Endpoint Controller(EPC) Library
> +
> +The EPC library provides APIs to be used by the controller that can oper=
ate
> +in endpoint mode. It also provides APIs to be used by function driver/li=
brary
> +in order to implement a particular endpoint function.
> +
> +2.1.1 APIs for the PCI controller Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be us=
ed
> +by the PCI controller driver.
> +
> +*) devm_pci_epc_create()/pci_epc_create()
> +
> +   The PCI controller driver should implement the following ops:
> +	 * write_header: ops to populate configuration space header
> +	 * set_bar: ops to configure the BAR
> +	 * clear_bar: ops to reset the BAR
> +	 * alloc_addr_space: ops to allocate *in* PCI controller address space
> +	 * free_addr_space: ops to free the allocated address space
> +	 * raise_irq: ops to raise a legacy or MSI interrupt
> +	 * start: ops to start the PCI link
> +	 * stop: ops to stop the PCI link
> +
> +   The PCI controller driver can then create a new EPC device by invoking
> +   devm_pci_epc_create/pci_epc_create.
> +
> +*) devm_pci_epc_destroy()/pci_epc_destroy()
> +
> +   The PCI controller driver can destroy the EPC device created by either
> +   devm_pci_epc_create or pci_epc_create using devm_pci_epc_destroy() or
> +   /pci_epc_destroy()
> +
> +2.1.2 APIs for the PCI Endpoint Function Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be us=
ed
> +by the PCI endpoint function driver.
> +
> +*) pci_epc_write_header()
> +
> +   The PCI endpoint function driver should use pci_epc_write_header() to
> +   write the standard configuration header to the endpoint controller.
> +
> +*) pci_epc_set_bar()
> +
> +   The PCI endpoint function driver should use pci_epc_set_bar() to conf=
igure
> +   the Base Address Register in order for the host to assign PCI addr sp=
ace.
> +   Register space of the function driver is usually configured
> +   using this API.
> +
> +*) pci_epc_clear_bar()
> +
> +   The PCI endpoint function driver should use pci_epc_clear_bar() to re=
set
> +   the BAR.
> +
> +*) pci_epc_raise_irq()
> +
> +   The PCI endpoint function driver should use pci_epc_raise_irq() to ra=
ise
> +   Legacy Interrupt or MSI Interrupt.
> +
> +*) pci_epc_start()
> +
> +   The PCI endpoint function driver should invoke pci_epc_start() once it
> +   has configured the endpoint function and wants to start the PCI link.
> +
> +*) pci_epc_stop()
> +
> +   The PCI endpoint function driver should invoke pci_epc_stop() to stop
> +   the PCI LINK.
> +
> +2.1.3 Other APIs
> +
> +There are other APIs provided by the EPC library. These are used for bin=
ding
> +the epf device with epc device. pci-ep-cfs.c can be used as reference for
> +using these APIs.
> +
> +*) pci_epc_get()
> +
> +   Get a reference to the pci endpoint controller based on the device na=
me of
> +   the controller.
> +
> +*) pci_epc_put()
> +
> +   Release the reference to the pci endpoint controller obtained using
> +   pci_epc_get()
> +
> +*) pci_epc_add_epf()
> +
> +   Add a pci endpoint function to a pci endpoint controller. A pcie devi=
ce
> +   can have upto 8 functions according to the specification.
> +
> +*) pci_epc_remove_epf()
> +
> +   Remove the pci endpoint function from pci endpoint controller.
> +
> +2.2 PCI Endpoint Function(EPF) Library
> +
> +The EPF library provides APIs to be used by the function driver and the =
EPC
> +library in order to provide endpoint mode functionality.
> +
> +2.2.1 APIs for the PCI Endpoint Function Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be us=
ed
> +by the PCI endpoint function driver.
> +
> +*) pci_epf_register_driver()
> +
> +   The PCI Endpoint Function driver should implement the following ops:
> +	 * bind: ops to perform when a EPC device has been bound to EPF device
> +	 * unbind: ops to perform when a binding has been lost between a EPC
> +	   device and EPF device
> +	 * linkup: ops to perform when the EPC device has established a
> +	   connection with a host system
> +
> +  The PCI Function driver can then register the PCI EPF driver by using
> +  pci_epf_register_driver().
> +
> +*) pci_epf_unregister_driver()
> +
> +  The PCI Function driver can unregister the PCI EPF driver by using
> +  pci_epf_unregister_driver().
> +
> +*) pci_epf_alloc_space()
> +
> +  The PCI Function driver can allocate space for a particular BAR using
> +  pci_epf_alloc_space().
> +
> +*) pci_epf_free_space()
> +
> +  The PCI Function driver can free the allocated space
> +  (using pci_epf_alloc_space) by invoking pci_epf_free_space().
> +
> +2.2.2 APIs for the PCI Endpoint Controller Library
> +This section lists the APIs that the PCI Endpoint core provides to be us=
ed
> +by the PCI endpoint controller library.
> +
> +*) pci_epf_linkup()
> +
> +   The PCI endpoint controller library invokes pci_epf_linkup() when the
> +   EPC device has established the connection to the host.
> +
> +2.2.2 Other APIs
> +There are other APIs provided by the EPF library. These are used to noti=
fy
> +the function driver when the EPF device is bound to the EPC device.
> +pci-ep-cfs.c can be used as reference for using these APIs.
> +
> +*) pci_epf_create()
> +
> +   Create a new PCI EPF device by passing the name of the PCI EPF device.
> +   This name will be used to bind the the EPF device to a EPF driver.
> +
> +*) pci_epf_destroy()
> +
> +   Destroy the created PCI EPF device.
> +
> +*) pci_epf_bind()
> +
> +   pci_epf_bind() should be invoked when the EPF device has been bound to
> +   a EPC device.
> +
> +*) pci_epf_unbind()
> +
> +   pci_epf_unbind() should be invoked when the binding between EPC device
> +   and EPF device is lost.
> =


Good initial reference guide.

Acked-By: Joao Pinto <jpinto@synopsys.com>

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

WARNING: multiple messages have this Message-ID (diff)
From: Joao.Pinto@synopsys.com (Joao Pinto)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v2 02/22] Documentation: PCI: Guide to use PCI Endpoint Core Layer
Date: Fri, 17 Feb 2017 11:43:17 +0000	[thread overview]
Message-ID: <c7b32fa3-0b69-8ffe-ab0a-581e4e784c12@synopsys.com> (raw)
In-Reply-To: <1487325042-28227-3-git-send-email-kishon@ti.com>

?s 9:50 AM de 2/17/2017, Kishon Vijay Abraham I escreveu:
> Add Documentation to help users use endpoint library to enable endpoint
> mode in the PCI controller and add new PCI endpoint functions.
> 
> Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
> ---
>  Documentation/PCI/00-INDEX                  |    2 +
>  Documentation/PCI/endpoint/pci-endpoint.txt |  190 +++++++++++++++++++++++++++
>  2 files changed, 192 insertions(+)
>  create mode 100644 Documentation/PCI/endpoint/pci-endpoint.txt
> 
> diff --git a/Documentation/PCI/00-INDEX b/Documentation/PCI/00-INDEX
> index 147231f..ba950b2 100644
> --- a/Documentation/PCI/00-INDEX
> +++ b/Documentation/PCI/00-INDEX
> @@ -12,3 +12,5 @@ pci.txt
>  	- info on the PCI subsystem for device driver authors
>  pcieaer-howto.txt
>  	- the PCI Express Advanced Error Reporting Driver Guide HOWTO
> +endpoint/pci-endpoint.txt
> +	- guide to add endpoint controller driver and endpoint function driver.
> diff --git a/Documentation/PCI/endpoint/pci-endpoint.txt b/Documentation/PCI/endpoint/pci-endpoint.txt
> new file mode 100644
> index 0000000..68a7839
> --- /dev/null
> +++ b/Documentation/PCI/endpoint/pci-endpoint.txt
> @@ -0,0 +1,190 @@
> +			    PCI ENDPOINT FRAMEWORK
> +		    Kishon Vijay Abraham I <kishon@ti.com>
> +
> +This document is a guide to use the PCI Endpoint Framework in order to create
> +endpoint controller driver, endpoint function driver and using configfs
> +interface to bind the function driver to the controller driver.
> +
> +1. Introduction
> +
> +*Linux* has a comprehensive PCI subsystem to support PCI controllers that
> +operates in Root Complex mode. The subsystem has capability to scan PCI bus,
> +assign memory resources and irq resources, load PCI driver (based on
> +vendorid, deviceid), support other services like hot-plug, power management,
> +advanced error reporting and virtual channels.
> +
> +However PCI controller IPs integrated in certain SoC is capable of operating
> +either in Root Complex mode or Endpoint mode. PCI Endpoint Framework will
> +add endpoint mode support in *Linux*. This will help to run Linux in an
> +EP system which can have a wide variety of use cases from testing or
> +validation, co-processor accelerator etc..
> +
> +2. PCI Endpoint Core
> +
> +The PCI Endpoint Core layer comprises of 3 components: the Endpoint Controller
> +library, the Endpoint Function library and the configfs layer to bind the
> +endpoint function with the endpoint controller.
> +
> +2.1 PCI Endpoint Controller(EPC) Library
> +
> +The EPC library provides APIs to be used by the controller that can operate
> +in endpoint mode. It also provides APIs to be used by function driver/library
> +in order to implement a particular endpoint function.
> +
> +2.1.1 APIs for the PCI controller Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI controller driver.
> +
> +*) devm_pci_epc_create()/pci_epc_create()
> +
> +   The PCI controller driver should implement the following ops:
> +	 * write_header: ops to populate configuration space header
> +	 * set_bar: ops to configure the BAR
> +	 * clear_bar: ops to reset the BAR
> +	 * alloc_addr_space: ops to allocate *in* PCI controller address space
> +	 * free_addr_space: ops to free the allocated address space
> +	 * raise_irq: ops to raise a legacy or MSI interrupt
> +	 * start: ops to start the PCI link
> +	 * stop: ops to stop the PCI link
> +
> +   The PCI controller driver can then create a new EPC device by invoking
> +   devm_pci_epc_create/pci_epc_create.
> +
> +*) devm_pci_epc_destroy()/pci_epc_destroy()
> +
> +   The PCI controller driver can destroy the EPC device created by either
> +   devm_pci_epc_create or pci_epc_create using devm_pci_epc_destroy() or
> +   /pci_epc_destroy()
> +
> +2.1.2 APIs for the PCI Endpoint Function Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI endpoint function driver.
> +
> +*) pci_epc_write_header()
> +
> +   The PCI endpoint function driver should use pci_epc_write_header() to
> +   write the standard configuration header to the endpoint controller.
> +
> +*) pci_epc_set_bar()
> +
> +   The PCI endpoint function driver should use pci_epc_set_bar() to configure
> +   the Base Address Register in order for the host to assign PCI addr space.
> +   Register space of the function driver is usually configured
> +   using this API.
> +
> +*) pci_epc_clear_bar()
> +
> +   The PCI endpoint function driver should use pci_epc_clear_bar() to reset
> +   the BAR.
> +
> +*) pci_epc_raise_irq()
> +
> +   The PCI endpoint function driver should use pci_epc_raise_irq() to raise
> +   Legacy Interrupt or MSI Interrupt.
> +
> +*) pci_epc_start()
> +
> +   The PCI endpoint function driver should invoke pci_epc_start() once it
> +   has configured the endpoint function and wants to start the PCI link.
> +
> +*) pci_epc_stop()
> +
> +   The PCI endpoint function driver should invoke pci_epc_stop() to stop
> +   the PCI LINK.
> +
> +2.1.3 Other APIs
> +
> +There are other APIs provided by the EPC library. These are used for binding
> +the epf device with epc device. pci-ep-cfs.c can be used as reference for
> +using these APIs.
> +
> +*) pci_epc_get()
> +
> +   Get a reference to the pci endpoint controller based on the device name of
> +   the controller.
> +
> +*) pci_epc_put()
> +
> +   Release the reference to the pci endpoint controller obtained using
> +   pci_epc_get()
> +
> +*) pci_epc_add_epf()
> +
> +   Add a pci endpoint function to a pci endpoint controller. A pcie device
> +   can have upto 8 functions according to the specification.
> +
> +*) pci_epc_remove_epf()
> +
> +   Remove the pci endpoint function from pci endpoint controller.
> +
> +2.2 PCI Endpoint Function(EPF) Library
> +
> +The EPF library provides APIs to be used by the function driver and the EPC
> +library in order to provide endpoint mode functionality.
> +
> +2.2.1 APIs for the PCI Endpoint Function Driver
> +
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI endpoint function driver.
> +
> +*) pci_epf_register_driver()
> +
> +   The PCI Endpoint Function driver should implement the following ops:
> +	 * bind: ops to perform when a EPC device has been bound to EPF device
> +	 * unbind: ops to perform when a binding has been lost between a EPC
> +	   device and EPF device
> +	 * linkup: ops to perform when the EPC device has established a
> +	   connection with a host system
> +
> +  The PCI Function driver can then register the PCI EPF driver by using
> +  pci_epf_register_driver().
> +
> +*) pci_epf_unregister_driver()
> +
> +  The PCI Function driver can unregister the PCI EPF driver by using
> +  pci_epf_unregister_driver().
> +
> +*) pci_epf_alloc_space()
> +
> +  The PCI Function driver can allocate space for a particular BAR using
> +  pci_epf_alloc_space().
> +
> +*) pci_epf_free_space()
> +
> +  The PCI Function driver can free the allocated space
> +  (using pci_epf_alloc_space) by invoking pci_epf_free_space().
> +
> +2.2.2 APIs for the PCI Endpoint Controller Library
> +This section lists the APIs that the PCI Endpoint core provides to be used
> +by the PCI endpoint controller library.
> +
> +*) pci_epf_linkup()
> +
> +   The PCI endpoint controller library invokes pci_epf_linkup() when the
> +   EPC device has established the connection to the host.
> +
> +2.2.2 Other APIs
> +There are other APIs provided by the EPF library. These are used to notify
> +the function driver when the EPF device is bound to the EPC device.
> +pci-ep-cfs.c can be used as reference for using these APIs.
> +
> +*) pci_epf_create()
> +
> +   Create a new PCI EPF device by passing the name of the PCI EPF device.
> +   This name will be used to bind the the EPF device to a EPF driver.
> +
> +*) pci_epf_destroy()
> +
> +   Destroy the created PCI EPF device.
> +
> +*) pci_epf_bind()
> +
> +   pci_epf_bind() should be invoked when the EPF device has been bound to
> +   a EPC device.
> +
> +*) pci_epf_unbind()
> +
> +   pci_epf_unbind() should be invoked when the binding between EPC device
> +   and EPF device is lost.
> 

Good initial reference guide.

Acked-By: Joao Pinto <jpinto@synopsys.com>

  reply	other threads:[~2017-02-17 11:43 UTC|newest]

Thread overview: 184+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-02-17  9:50 [PATCH v2 00/22] PCI: Support for configurable PCI endpoint Kishon Vijay Abraham I
2017-02-17  9:50 ` Kishon Vijay Abraham I
2017-02-17  9:50 ` Kishon Vijay Abraham I
2017-02-17  9:50 ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 01/22] PCI: endpoint: Add EP core layer to enable EP controller and EP functions Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17 11:26   ` Joao Pinto
2017-02-17 11:26     ` Joao Pinto
2017-02-17 11:26     ` Joao Pinto
2017-02-17 11:26     ` Joao Pinto
2017-02-17 11:37     ` Kishon Vijay Abraham I
2017-02-17 11:37       ` Kishon Vijay Abraham I
2017-02-17 11:37       ` Kishon Vijay Abraham I
2017-02-17 11:37       ` Kishon Vijay Abraham I
2017-02-17 11:39       ` Joao Pinto
2017-02-17 11:39         ` Joao Pinto
2017-02-17 11:39         ` Joao Pinto
2017-02-17 11:39         ` Joao Pinto
2017-02-17  9:50 ` [PATCH v2 02/22] Documentation: PCI: Guide to use PCI Endpoint Core Layer Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17 11:43   ` Joao Pinto [this message]
2017-02-17 11:43     ` Joao Pinto
2017-02-17 11:43     ` Joao Pinto
2017-02-17 11:43     ` Joao Pinto
2017-02-17  9:50 ` [PATCH v2 03/22] PCI: endpoint: Introduce configfs entry for configuring EP functions Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17 12:01   ` Kishon Vijay Abraham I
2017-02-17 12:01     ` Kishon Vijay Abraham I
2017-02-17 12:01     ` Kishon Vijay Abraham I
2017-02-17 17:04   ` Christoph Hellwig
2017-02-17 17:04     ` Christoph Hellwig
2017-02-17 17:04     ` Christoph Hellwig
2017-03-06  9:41     ` Kishon Vijay Abraham I
2017-03-06  9:41       ` Kishon Vijay Abraham I
2017-03-06  9:41       ` Kishon Vijay Abraham I
2017-03-06  9:41       ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 04/22] Documentation: PCI: Guide to use pci endpoint configfs Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17 13:05   ` Joao Pinto
2017-02-17 13:05     ` Joao Pinto
2017-02-17 13:05     ` Joao Pinto
2017-02-17 13:05     ` Joao Pinto
2017-02-17 17:15   ` Christoph Hellwig
2017-02-17 17:15     ` Christoph Hellwig
2017-02-17 17:15     ` Christoph Hellwig
2017-02-17 17:15     ` Christoph Hellwig
2017-03-06 10:16     ` Kishon Vijay Abraham I
2017-03-06 10:16       ` Kishon Vijay Abraham I
2017-03-06 10:16       ` Kishon Vijay Abraham I
2017-03-06 10:16       ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 05/22] Documentation: PCI: Add specification for the *pci test* function device Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 06/22] PCI: endpoint: functions: Add an EP function to test PCI Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 07/22] Documentation: PCI: Add binding documentation for pci-test endpoint function Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 08/22] PCI: dwc: designware: Add EP mode support Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17 13:15   ` Kishon Vijay Abraham I
2017-02-17 13:15     ` Kishon Vijay Abraham I
2017-02-17 13:15     ` Kishon Vijay Abraham I
2017-02-17 13:15     ` Kishon Vijay Abraham I
2017-02-17 17:20   ` Joao Pinto
2017-02-17 17:20     ` Joao Pinto
2017-02-17 17:20     ` Joao Pinto
2017-02-17 17:20     ` Joao Pinto
2017-03-06  9:55     ` Kishon Vijay Abraham I
2017-03-06  9:55       ` Kishon Vijay Abraham I
2017-03-06  9:55       ` Kishon Vijay Abraham I
2017-03-06  9:55       ` Kishon Vijay Abraham I
2017-03-07  5:18     ` Kishon Vijay Abraham I
2017-03-07  5:18       ` Kishon Vijay Abraham I
2017-03-07  5:18       ` Kishon Vijay Abraham I
2017-03-07  5:18       ` Kishon Vijay Abraham I
2017-03-07 11:10       ` Joao Pinto
2017-03-07 11:10         ` Joao Pinto
2017-03-07 11:10         ` Joao Pinto
2017-03-07 11:10         ` Joao Pinto
2017-03-08 11:32         ` Joao Pinto
2017-03-08 11:32           ` Joao Pinto
2017-03-08 11:32           ` Joao Pinto
2017-03-08 11:32           ` Joao Pinto
2017-03-08 11:35           ` Kishon Vijay Abraham I
2017-03-08 11:35             ` Kishon Vijay Abraham I
2017-03-08 11:35             ` Kishon Vijay Abraham I
2017-03-08 11:35             ` Kishon Vijay Abraham I
2017-03-08 11:37             ` Joao Pinto
2017-03-08 11:37               ` Joao Pinto
2017-03-08 11:37               ` Joao Pinto
2017-03-08 11:37               ` Joao Pinto
2017-03-08 13:31               ` Kishon Vijay Abraham I
2017-03-08 13:31                 ` Kishon Vijay Abraham I
2017-03-08 13:31                 ` Kishon Vijay Abraham I
2017-03-08 13:31                 ` Kishon Vijay Abraham I
2017-03-08 15:32                 ` Joao Pinto
2017-03-08 15:32                   ` Joao Pinto
2017-03-08 15:32                   ` Joao Pinto
2017-03-08 15:32                   ` Joao Pinto
2017-03-08 15:33                   ` Joao Pinto
2017-03-08 15:33                     ` Joao Pinto
2017-03-08 15:33                     ` Joao Pinto
2017-03-08 15:33                     ` Joao Pinto
2017-03-08 19:14                   ` Christoph Hellwig
2017-03-08 19:14                     ` Christoph Hellwig
2017-03-08 19:14                     ` Christoph Hellwig
2017-03-08 19:14                     ` Christoph Hellwig
2017-03-09 11:55                     ` Joao Pinto
2017-03-09 11:55                       ` Joao Pinto
2017-03-09 11:55                       ` Joao Pinto
2017-03-09 11:55                       ` Joao Pinto
2017-02-17  9:50 ` [PATCH v2 09/22] dt-bindings: PCI: Add dt bindings for pci designware EP mode Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 10/22] PCI: dwc: dra7xx: Facilitate wrapper and msi interrupts to be enabled independently Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 11/22] PCI: dwc: dra7xx: Add EP mode support Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 12/22] dt-bindings: PCI: dra7xx: Add dt bindings for pci dra7xx EP mode Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 13/22] PCI: dwc: dra7xx: Workaround for errata id i870 Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 14/22] dt-bindings: PCI: dra7xx: Add dt bindings to enable legacy mode Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-27 16:40   ` Rob Herring
2017-02-27 16:40     ` Rob Herring
2017-02-27 16:40     ` Rob Herring
2017-02-27 16:40     ` Rob Herring
2017-02-28  3:28     ` Kishon Vijay Abraham I
2017-02-28  3:28       ` Kishon Vijay Abraham I
2017-02-28  3:28       ` Kishon Vijay Abraham I
2017-02-28  3:28       ` Kishon Vijay Abraham I
2017-03-06  9:56     ` Kishon Vijay Abraham I
2017-03-06  9:56       ` Kishon Vijay Abraham I
2017-03-06  9:56       ` Kishon Vijay Abraham I
2017-03-06  9:56       ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 15/22] PCI: Add device IDs for DRA74x and DRA72x Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 16/22] misc: Add host side pci driver for pci test function device Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 17/22] Documentation: misc-devices: Add Documentation for pci-endpoint-test driver Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 18/22] tools: PCI: Add a userspace tool to test PCI endpoint Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 19/22] tools: PCI: Add sample test script to invoke pcitest Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 20/22] Documentation: PCI: Add userguide for PCI endpoint test function Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 21/22] MAINTAINERS: add PCI EP maintainer Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50 ` [PATCH v2 22/22] ARM: DRA7: clockdomain: Change the CLKTRCTRL of CM_PCIE_CLKSTCTRL to SW_WKUP Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I
2017-02-17  9:50   ` Kishon Vijay Abraham I

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=c7b32fa3-0b69-8ffe-ab0a-581e4e784c12@synopsys.com \
    --to=joao.pinto@synopsys.com \
    --cc=bhelgaas@google.com \
    --cc=devicetree@vger.kernel.org \
    --cc=jingoohan1@gmail.com \
    --cc=kishon@ti.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-doc@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-omap@vger.kernel.org \
    --cc=linux-pci@vger.kernel.org \
    --cc=nsekhar@ti.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.