All of lore.kernel.org
 help / color / mirror / Atom feed
From: Gavin Shan <gwshan@linux.vnet.ibm.com>
To: Wei Yang <weiyang@linux.vnet.ibm.com>
Cc: gwshan@linux.vnet.ibm.com, bhelgaas@google.com,
	linuxppc-dev@lists.ozlabs.org, linux-pci@vger.kernel.org
Subject: Re: [PATCH V4 10/11] powerpc/powernv: use "compound" as the child's list_head for compound PE
Date: Fri, 15 May 2015 17:37:10 +1000	[thread overview]
Message-ID: <20150515073710.GB7980@gwshan> (raw)
In-Reply-To: <1431668786-30371-11-git-send-email-weiyang@linux.vnet.ibm.com>

On Fri, May 15, 2015 at 01:46:25PM +0800, Wei Yang wrote:
>Commit 262af557dd75(powerpc/powernv: Enable M64 aperatus for PHB3)
>introduces the concept of compound PE, and they are linked together to
>master PE's slaves lish_head with the list field. While this field is
>usually used to linked to the phb->ioda.pe_list to represents the PE is
>used.
>
>This patch introduces a field "compound" to link those compound PEs.
>

I don't think we needn't it with:

- VF PEs are classified to master and slave PEs.
- Master PEs is linked to phb->list;
- Slave PEs is linked to master->slaves;
- When iterating all PEs, you have to check PE's flag to cover all
  (master & slave) VF PEs:

  for_each_pe_in_phb_list {
         /* Things we're doing */
         if (pe_is_not_vf_pe ||
             pe_is_not_master_pe)
             continue;

         for_each_pe_in_master_vf_pe_list {
               /* slave VF PEs */
         }
  }

Thanks,
Gavin

>Signed-off-by: Wei Yang <weiyang@linux.vnet.ibm.com>
>---
> arch/powerpc/platforms/powernv/pci-ioda.c |    8 ++++----
> arch/powerpc/platforms/powernv/pci.h      |    1 +
> 2 files changed, 5 insertions(+), 4 deletions(-)
>
>diff --git a/arch/powerpc/platforms/powernv/pci-ioda.c b/arch/powerpc/platforms/powernv/pci-ioda.c
>index 920c252..843457b 100644
>--- a/arch/powerpc/platforms/powernv/pci-ioda.c
>+++ b/arch/powerpc/platforms/powernv/pci-ioda.c
>@@ -344,7 +344,7 @@ done:
> 		} else {
> 			pe->flags |= PNV_IODA_PE_SLAVE;
> 			pe->master = master_pe;
>-			list_add_tail(&pe->list, &master_pe->slaves);
>+			list_add_tail(&pe->compound, &master_pe->slaves);
> 		}
> 	}
>
>@@ -428,7 +428,7 @@ static void pnv_ioda_freeze_pe(struct pnv_phb *phb, int pe_no)
> 	if (!(pe->flags & PNV_IODA_PE_MASTER))
> 		return;
>
>-	list_for_each_entry(slave, &pe->slaves, list) {
>+	list_for_each_entry(slave, &pe->slaves, compound) {
> 		rc = opal_pci_eeh_freeze_set(phb->opal_id,
> 					     slave->pe_number,
> 					     OPAL_EEH_ACTION_SET_FREEZE_ALL);
>@@ -464,7 +464,7 @@ static int pnv_ioda_unfreeze_pe(struct pnv_phb *phb, int pe_no, int opt)
> 		return 0;
>
> 	/* Clear frozen state for slave PEs */
>-	list_for_each_entry(slave, &pe->slaves, list) {
>+	list_for_each_entry(slave, &pe->slaves, compound) {
> 		rc = opal_pci_eeh_freeze_clear(phb->opal_id,
> 					     slave->pe_number,
> 					     opt);
>@@ -516,7 +516,7 @@ static int pnv_ioda_get_pe_state(struct pnv_phb *phb, int pe_no)
> 	if (!(pe->flags & PNV_IODA_PE_MASTER))
> 		return state;
>
>-	list_for_each_entry(slave, &pe->slaves, list) {
>+	list_for_each_entry(slave, &pe->slaves, compound) {
> 		rc = opal_pci_eeh_freeze_status(phb->opal_id,
> 						slave->pe_number,
> 						&fstate,
>diff --git a/arch/powerpc/platforms/powernv/pci.h b/arch/powerpc/platforms/powernv/pci.h
>index 070ee88..540ab1e 100644
>--- a/arch/powerpc/platforms/powernv/pci.h
>+++ b/arch/powerpc/platforms/powernv/pci.h
>@@ -73,6 +73,7 @@ struct pnv_ioda_pe {
> 	/* PEs in compound case */
> 	struct pnv_ioda_pe	*master;
> 	struct list_head	slaves;
>+	struct list_head	compound;
>
> 	/* Link in list of PE#s */
> 	struct list_head	dma_link;
>-- 
>1.7.9.5
>


WARNING: multiple messages have this Message-ID (diff)
From: Gavin Shan <gwshan@linux.vnet.ibm.com>
To: Wei Yang <weiyang@linux.vnet.ibm.com>
Cc: bhelgaas@google.com, linux-pci@vger.kernel.org,
	linuxppc-dev@lists.ozlabs.org, gwshan@linux.vnet.ibm.com
Subject: Re: [PATCH V4 10/11] powerpc/powernv: use "compound" as the child's list_head for compound PE
Date: Fri, 15 May 2015 17:37:10 +1000	[thread overview]
Message-ID: <20150515073710.GB7980@gwshan> (raw)
In-Reply-To: <1431668786-30371-11-git-send-email-weiyang@linux.vnet.ibm.com>

On Fri, May 15, 2015 at 01:46:25PM +0800, Wei Yang wrote:
>Commit 262af557dd75(powerpc/powernv: Enable M64 aperatus for PHB3)
>introduces the concept of compound PE, and they are linked together to
>master PE's slaves lish_head with the list field. While this field is
>usually used to linked to the phb->ioda.pe_list to represents the PE is
>used.
>
>This patch introduces a field "compound" to link those compound PEs.
>

I don't think we needn't it with:

- VF PEs are classified to master and slave PEs.
- Master PEs is linked to phb->list;
- Slave PEs is linked to master->slaves;
- When iterating all PEs, you have to check PE's flag to cover all
  (master & slave) VF PEs:

  for_each_pe_in_phb_list {
         /* Things we're doing */
         if (pe_is_not_vf_pe ||
             pe_is_not_master_pe)
             continue;

         for_each_pe_in_master_vf_pe_list {
               /* slave VF PEs */
         }
  }

Thanks,
Gavin

>Signed-off-by: Wei Yang <weiyang@linux.vnet.ibm.com>
>---
> arch/powerpc/platforms/powernv/pci-ioda.c |    8 ++++----
> arch/powerpc/platforms/powernv/pci.h      |    1 +
> 2 files changed, 5 insertions(+), 4 deletions(-)
>
>diff --git a/arch/powerpc/platforms/powernv/pci-ioda.c b/arch/powerpc/platforms/powernv/pci-ioda.c
>index 920c252..843457b 100644
>--- a/arch/powerpc/platforms/powernv/pci-ioda.c
>+++ b/arch/powerpc/platforms/powernv/pci-ioda.c
>@@ -344,7 +344,7 @@ done:
> 		} else {
> 			pe->flags |= PNV_IODA_PE_SLAVE;
> 			pe->master = master_pe;
>-			list_add_tail(&pe->list, &master_pe->slaves);
>+			list_add_tail(&pe->compound, &master_pe->slaves);
> 		}
> 	}
>
>@@ -428,7 +428,7 @@ static void pnv_ioda_freeze_pe(struct pnv_phb *phb, int pe_no)
> 	if (!(pe->flags & PNV_IODA_PE_MASTER))
> 		return;
>
>-	list_for_each_entry(slave, &pe->slaves, list) {
>+	list_for_each_entry(slave, &pe->slaves, compound) {
> 		rc = opal_pci_eeh_freeze_set(phb->opal_id,
> 					     slave->pe_number,
> 					     OPAL_EEH_ACTION_SET_FREEZE_ALL);
>@@ -464,7 +464,7 @@ static int pnv_ioda_unfreeze_pe(struct pnv_phb *phb, int pe_no, int opt)
> 		return 0;
>
> 	/* Clear frozen state for slave PEs */
>-	list_for_each_entry(slave, &pe->slaves, list) {
>+	list_for_each_entry(slave, &pe->slaves, compound) {
> 		rc = opal_pci_eeh_freeze_clear(phb->opal_id,
> 					     slave->pe_number,
> 					     opt);
>@@ -516,7 +516,7 @@ static int pnv_ioda_get_pe_state(struct pnv_phb *phb, int pe_no)
> 	if (!(pe->flags & PNV_IODA_PE_MASTER))
> 		return state;
>
>-	list_for_each_entry(slave, &pe->slaves, list) {
>+	list_for_each_entry(slave, &pe->slaves, compound) {
> 		rc = opal_pci_eeh_freeze_status(phb->opal_id,
> 						slave->pe_number,
> 						&fstate,
>diff --git a/arch/powerpc/platforms/powernv/pci.h b/arch/powerpc/platforms/powernv/pci.h
>index 070ee88..540ab1e 100644
>--- a/arch/powerpc/platforms/powernv/pci.h
>+++ b/arch/powerpc/platforms/powernv/pci.h
>@@ -73,6 +73,7 @@ struct pnv_ioda_pe {
> 	/* PEs in compound case */
> 	struct pnv_ioda_pe	*master;
> 	struct list_head	slaves;
>+	struct list_head	compound;
>
> 	/* Link in list of PE#s */
> 	struct list_head	dma_link;
>-- 
>1.7.9.5
>

  reply	other threads:[~2015-05-15  7:38 UTC|newest]

Thread overview: 44+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-05-15  5:46 [PATCH V4 00/11] VF EEH on Power8 Wei Yang
2015-05-15  5:46 ` Wei Yang
2015-05-15  5:46 ` [PATCH V4 01/11] pci/iov: rename and export virtfn_add/virtfn_remove Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  5:56   ` Gavin Shan
2015-05-15  5:56     ` Gavin Shan
2015-05-15  5:46 ` [PATCH V4 02/11] powerpc/pci_dn: cache vf_index in pci_dn Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  5:57   ` Gavin Shan
2015-05-15  5:57     ` Gavin Shan
2015-05-15  5:46 ` [PATCH V4 03/11] powerpc/pci: remove PCI devices in reverse order Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  5:46 ` [PATCH V4 04/11] powerpc/eeh: cache address range just for normal device Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  5:46 ` [PATCH V4 05/11] powerpc/powernv: create/release eeh_dev for VF Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  6:19   ` Gavin Shan
2015-05-15  6:19     ` Gavin Shan
2015-05-15  8:53     ` Wei Yang
2015-05-15  8:53       ` Wei Yang
2015-05-15  5:46 ` [PATCH V4 06/11] powerpc/eeh: create EEH_PE_VF for VF PE Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  6:26   ` Gavin Shan
2015-05-15  6:26     ` Gavin Shan
2015-05-15  5:46 ` [PATCH V4 07/11] powerpc/powernv: Support EEH reset for VFs Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  7:12   ` Gavin Shan
2015-05-15  7:12     ` Gavin Shan
2015-05-15  5:46 ` [PATCH V4 08/11] powerpc/powernv: Support PCI config restore " Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  7:27   ` Gavin Shan
2015-05-15  7:27     ` Gavin Shan
2015-05-15  9:18     ` Wei Yang
2015-05-15  9:18       ` Wei Yang
2015-05-15  5:46 ` [PATCH V4 09/11] powerpc/eeh: handle VF PE properly Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  7:31   ` Gavin Shan
2015-05-15  7:31     ` Gavin Shan
2015-05-15  5:46 ` [PATCH V4 10/11] powerpc/powernv: use "compound" as the child's list_head for compound PE Wei Yang
2015-05-15  5:46   ` Wei Yang
2015-05-15  7:37   ` Gavin Shan [this message]
2015-05-15  7:37     ` Gavin Shan
2015-05-15  5:46 ` [PATCH V4 11/11] powerpc/powernv: compound PE for VFs Wei Yang
2015-05-15  5:46   ` Wei Yang

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=20150515073710.GB7980@gwshan \
    --to=gwshan@linux.vnet.ibm.com \
    --cc=bhelgaas@google.com \
    --cc=linux-pci@vger.kernel.org \
    --cc=linuxppc-dev@lists.ozlabs.org \
    --cc=weiyang@linux.vnet.ibm.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.