Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756891AbYGJMpb (ORCPT ); Thu, 10 Jul 2008 08:45:31 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753989AbYGJMpY (ORCPT ); Thu, 10 Jul 2008 08:45:24 -0400 Received: from outbound-sin.frontbridge.com ([207.46.51.80]:39509 "EHLO SG2EHSOBE002.bigfish.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753940AbYGJMpX (ORCPT ); Thu, 10 Jul 2008 08:45:23 -0400 X-BigFish: VPS-39(z1039oz1418M1432R98dR4015M7efV18c1K1805M655O873fnc8kzz10d3izzz32i6bh43j62h) X-Spam-TCS-SCL: 1:0 X-WSS-ID: 0K3SJES-04-E4T-01 Date: Thu, 10 Jul 2008 14:44:34 +0200 From: Joerg Roedel To: FUJITA Tomonori CC: akpm@linux-foundation.org, tglx@linutronix.de, mingo@redhat.com, linux-kernel@vger.kernel.org, iommu@lists.linux-foundation.org, bhavna.sarathy@amd.com, Sebastian.Biemueller@amd.com, robert.richter@amd.com, joro@8bytes.org Subject: Re: [PATCH 17/34] AMD IOMMU: add generic defines and structures for mapping code Message-ID: <20080710124434.GM14977@amd.com> References: <1214508490-29683-1-git-send-email-joerg.roedel@amd.com> <1214508490-29683-18-git-send-email-joerg.roedel@amd.com> <20080709190140.ab662def.akpm@linux-foundation.org> <20080710132508N.fujita.tomonori@lab.ntt.co.jp> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: <20080710132508N.fujita.tomonori@lab.ntt.co.jp> User-Agent: mutt-ng/devel-r804 (Linux) X-OriginalArrivalTime: 10 Jul 2008 12:44:34.0351 (UTC) FILETIME=[B49B73F0:01C8E28A] Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4507 Lines: 113 On Thu, Jul 10, 2008 at 01:25:26PM +0900, FUJITA Tomonori wrote: > On Wed, 9 Jul 2008 19:01:40 -0700 > Andrew Morton wrote: > > > On Thu, 26 Jun 2008 21:27:53 +0200 Joerg Roedel wrote: > > > > > This patch adds generic stuff used by the mapping and unmapping code for the > > > AMD IOMMU. > > > > > > Signed-off-by: Joerg Roedel > > > --- > > > arch/x86/kernel/amd_iommu.c | 40 ++++++++++++++++++++++++++++++++++++++++ > > > 1 files changed, 40 insertions(+), 0 deletions(-) > > > create mode 100644 arch/x86/kernel/amd_iommu.c > > > > > > diff --git a/arch/x86/kernel/amd_iommu.c b/arch/x86/kernel/amd_iommu.c > > > new file mode 100644 > > > index 0000000..90392c7 > > > --- /dev/null > > > +++ b/arch/x86/kernel/amd_iommu.c > > > @@ -0,0 +1,40 @@ > > > +/* > > > + * Copyright (C) 2007-2008 Advanced Micro Devices, Inc. > > > + * Author: Joerg Roedel > > > + * Leo Duran > > > + * > > > + * This program is free software; you can redistribute it and/or modify it > > > + * under the terms of the GNU General Public License version 2 as published > > > + * by the Free Software Foundation. > > > + * > > > + * This program is distributed in the hope that it will be useful, > > > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > > > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > > > + * GNU General Public License for more details. > > > + * > > > + * You should have received a copy of the GNU General Public License > > > + * along with this program; if not, write to the Free Software > > > + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA > > > + */ > > > + > > > +#include > > > +#include > > > +#include > > > +#include > > > +#include > > > +#include > > > +#include > > > +#include > > > + > > > +#define CMD_SET_TYPE(cmd, t) ((cmd)->data[1] |= ((t) << 28)) > > > > Doesn't need to be implemented in a macro, hence should be implemented in C, > > please. > > > > > +#define to_pages(addr, size) \ > > > + (round_up(((addr) & ~PAGE_MASK) + (size), PAGE_SIZE) >> PAGE_SHIFT) > > > > Does this patchset add any comments *at all*? Is it really all so obvious > > that this was justifiable? > > > > I don't know what this function does, but it shouldn't be doing it here. > > Either it duplicates an existing helper or it should be implemented in mm.h > > I think that this calculates the number of IOMMU pages for a > request. Every IOMMUs has a similar function so it might be better to > add a helper function to include/linux/iommu-helper.h. > > Someone except for IOMMU need this? If so, it would be better to add > this to a different header file. > > > diff --git a/include/linux/iommu-helper.h b/include/linux/iommu-helper.h > index c975caf..9c29e65 100644 > --- a/include/linux/iommu-helper.h > +++ b/include/linux/iommu-helper.h > @@ -8,3 +8,14 @@ extern unsigned long iommu_area_alloc(unsigned long *map, unsigned long size, > unsigned long align_mask); > extern void iommu_area_free(unsigned long *map, unsigned long start, > unsigned int nr); > + > +static inline unsigned long iommu_num_pages(unsigned long addr, > + unsigned long len) > +{ > + unsigned long npages; > + > + npages = ALIGN(addr + len, 1UL << IOMMU_PAGE_SHIFT) - > + (addr & ~((1UL << IOMMU_PAGE_SHIFT) - 1)); > + > + return (npages >> IOMMU_PAGE_SHIFT); > +} > Yeah. I fully agree that this function would make sense in the iommu-helper code. Will you send a patch introducing that function upstream? I will change my code to use it if it is merged. Thanks, Joerg -- | AMD Saxony Limited Liability Company & Co. KG Operating | Wilschdorfer Landstr. 101, 01109 Dresden, Germany System | Register Court Dresden: HRA 4896 Research | General Partner authorized to represent: Center | AMD Saxony LLC (Wilmington, Delaware, US) | General Manager of AMD Saxony LLC: Dr. Hans-R. Deppe, Thomas McCoy -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/