[PATCH 04/21] staging: comedi: c6xdigio: factor out status check busywait

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Factor out the common code that busywaits for the status to change.

Signed-off-by: H Hartley Sweeten <hsweeten@xxxxxxxxxxxxxxxxxxx>
Cc: Ian Abbott <abbotti@xxxxxxxxx>
Cc: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
---
 drivers/staging/comedi/drivers/c6xdigio.c | 187 ++++++++----------------------
 1 file changed, 48 insertions(+), 139 deletions(-)

diff --git a/drivers/staging/comedi/drivers/c6xdigio.c b/drivers/staging/comedi/drivers/c6xdigio.c
index adb607c..22315b8 100644
--- a/drivers/staging/comedi/drivers/c6xdigio.c
+++ b/drivers/staging/comedi/drivers/c6xdigio.c
@@ -77,45 +77,40 @@ union encvaluetype {
 
 #define C6XDIGIO_TIME_OUT 20
 
-static void C6X_pwmInit(unsigned long baseAddr)
+static int c6xdigio_chk_status(unsigned long baseAddr, unsigned long context)
 {
+	unsigned int status;
 	int timeout = 0;
 
-	outb_p(0x70, baseAddr);
-	while (((inb(baseAddr + 1) & 0x80) == 0)
-	       && (timeout < C6XDIGIO_TIME_OUT)) {
+	do {
+		status = inb(baseAddr + 1);
+		if ((status & 0x80) != context)
+			return 0;
 		timeout++;
-	}
+	} while  (timeout < C6XDIGIO_TIME_OUT);
+
+	return -EBUSY;
+}
+
+static void C6X_pwmInit(unsigned long baseAddr)
+{
+	outb_p(0x70, baseAddr);
+	c6xdigio_chk_status(baseAddr, 0x00);
 
 	outb_p(0x74, baseAddr);
-	timeout = 0;
-	while (((inb(baseAddr + 1) & 0x80) == 0x80)
-	       && (timeout < C6XDIGIO_TIME_OUT)) {
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
 
 	outb_p(0x70, baseAddr);
-	timeout = 0;
-	while (((inb(baseAddr + 1) & 0x80) == 0x0)
-	       && (timeout < C6XDIGIO_TIME_OUT)) {
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
 
 	outb_p(0x0, baseAddr);
-	timeout = 0;
-	while (((inb(baseAddr + 1) & 0x80) == 0x80)
-	       && (timeout < C6XDIGIO_TIME_OUT)) {
-		timeout++;
-	}
-
+	c6xdigio_chk_status(baseAddr, 0x80);
 }
 
 static void C6X_pwmOutput(unsigned long baseAddr, unsigned channel, int value)
 {
 	unsigned ppcmd;
 	union pwmcmdtype pwm;
-	int timeout = 0;
-	unsigned tmp;
 
 	pwm.cmd = value;
 	if (pwm.cmd > 498)
@@ -130,58 +125,28 @@ static void C6X_pwmOutput(unsigned long baseAddr, unsigned channel, int value)
 	}			/* endif */
 
 	outb_p(ppcmd + pwm.bits.sb0, baseAddr);
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
 
 	outb_p(ppcmd + pwm.bits.sb1 + 0x4, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x80) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
 
 	outb_p(ppcmd + pwm.bits.sb2, baseAddr);
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
 
 	outb_p(ppcmd + pwm.bits.sb3 + 0x4, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x80) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
 
 	outb_p(ppcmd + pwm.bits.sb4, baseAddr);
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
 
 	outb_p(0x0, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x80) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
-
+	c6xdigio_chk_status(baseAddr, 0x80);
 }
 
 static int C6X_encInput(unsigned long baseAddr, unsigned channel)
 {
 	unsigned ppcmd;
 	union encvaluetype enc;
-	int timeout = 0;
-	int tmp;
 
 	enc.value = 0;
 	if (channel == 0)
@@ -190,115 +155,59 @@ static int C6X_encInput(unsigned long baseAddr, unsigned channel)
 		ppcmd = 0x50;
 
 	outb_p(ppcmd, baseAddr);
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
 
 	enc.bits.sb0 = ((inb(baseAddr + 1) >> 3) & 0x7);
 	outb_p(ppcmd + 0x4, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x80) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
+
 	enc.bits.sb1 = ((inb(baseAddr + 1) >> 3) & 0x7);
 	outb_p(ppcmd, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
+
 	enc.bits.sb2 = ((inb(baseAddr + 1) >> 3) & 0x7);
 	outb_p(ppcmd + 0x4, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x80) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
+
 	enc.bits.sb3 = ((inb(baseAddr + 1) >> 3) & 0x7);
 	outb_p(ppcmd, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
+
 	enc.bits.sb4 = ((inb(baseAddr + 1) >> 3) & 0x7);
 	outb_p(ppcmd + 0x4, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x80) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
+
 	enc.bits.sb5 = ((inb(baseAddr + 1) >> 3) & 0x7);
 	outb_p(ppcmd, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x0) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
+
 	enc.bits.sb6 = ((inb(baseAddr + 1) >> 3) & 0x7);
 	outb_p(ppcmd + 0x4, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x80) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
+
 	enc.bits.sb7 = ((inb(baseAddr + 1) >> 3) & 0x7);
 	outb_p(ppcmd, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x0) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
 
 	outb_p(0x0, baseAddr);
-	timeout = 0;
-	tmp = inb(baseAddr + 1);
-	while (((tmp & 0x80) == 0x80) && (timeout < C6XDIGIO_TIME_OUT)) {
-		tmp = inb(baseAddr + 1);
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
 
 	return enc.value ^ 0x800000;
 }
 
 static void C6X_encResetAll(unsigned long baseAddr)
 {
-	unsigned timeout = 0;
-
 	outb_p(0x68, baseAddr);
-	while (((inb(baseAddr + 1) & 0x80) == 0)
-	       && (timeout < C6XDIGIO_TIME_OUT)) {
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
+
 	outb_p(0x6c, baseAddr);
-	timeout = 0;
-	while (((inb(baseAddr + 1) & 0x80) == 0x80)
-	       && (timeout < C6XDIGIO_TIME_OUT)) {
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
+
 	outb_p(0x68, baseAddr);
-	timeout = 0;
-	while (((inb(baseAddr + 1) & 0x80) == 0x0)
-	       && (timeout < C6XDIGIO_TIME_OUT)) {
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x00);
+
 	outb_p(0x0, baseAddr);
-	timeout = 0;
-	while (((inb(baseAddr + 1) & 0x80) == 0x80)
-	       && (timeout < C6XDIGIO_TIME_OUT)) {
-		timeout++;
-	}
+	c6xdigio_chk_status(baseAddr, 0x80);
 }
 
 static int c6xdigio_pwmo_insn_write(struct comedi_device *dev,
-- 
1.8.5.2

_______________________________________________
devel mailing list
devel@xxxxxxxxxxxxxxxxxxxxxx
http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel




[Index of Archives]     [Linux Driver Backports]     [DMA Engine]     [Linux GPIO]     [Linux SPI]     [Video for Linux]     [Linux USB Devel]     [Linux Coverity]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux