summaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/amd_iommu.c
diff options
context:
space:
mode:
authorJoerg Roedel <joerg.roedel@amd.com>2011-04-06 10:53:48 +0200
committerJoerg Roedel <joerg.roedel@amd.com>2011-04-06 10:53:48 +0200
commitded467374a34eb80020c2213456b1d9ca946b88c (patch)
tree723fe36eeb88eaa953ffd04cae39f0a06d176f7d /arch/x86/kernel/amd_iommu.c
parent6221f222c0ebf1acdf7abcf927178f40e1a65e2a (diff)
downloadlinux-ded467374a34eb80020c2213456b1d9ca946b88c.tar.gz
linux-ded467374a34eb80020c2213456b1d9ca946b88c.tar.bz2
linux-ded467374a34eb80020c2213456b1d9ca946b88c.zip
x86/amd-iommu: Move compl-wait command building to own function
This patch introduces a seperate function for building completion-wait commands. Signed-off-by: Joerg Roedel <joerg.roedel@amd.com>
Diffstat (limited to 'arch/x86/kernel/amd_iommu.c')
-rw-r--r--arch/x86/kernel/amd_iommu.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/arch/x86/kernel/amd_iommu.c b/arch/x86/kernel/amd_iommu.c
index 57ca77787220..eebd504519c6 100644
--- a/arch/x86/kernel/amd_iommu.c
+++ b/arch/x86/kernel/amd_iommu.c
@@ -383,6 +383,13 @@ irqreturn_t amd_iommu_int_handler(int irq, void *data)
*
****************************************************************************/
+static void build_completion_wait(struct iommu_cmd *cmd)
+{
+ memset(cmd, 0, sizeof(*cmd));
+ cmd->data[0] = CMD_COMPL_WAIT_INT_MASK;
+ CMD_SET_TYPE(cmd, CMD_COMPL_WAIT);
+}
+
/*
* Writes the command to the IOMMUs command buffer and informs the
* hardware about the new command. Must be called with iommu->lock held.
@@ -458,9 +465,7 @@ static int __iommu_completion_wait(struct amd_iommu *iommu)
{
struct iommu_cmd cmd;
- memset(&cmd, 0, sizeof(cmd));
- cmd.data[0] = CMD_COMPL_WAIT_INT_MASK;
- CMD_SET_TYPE(&cmd, CMD_COMPL_WAIT);
+ build_completion_wait(&cmd);
return __iommu_queue_command(iommu, &cmd);
}