diff options
| -rw-r--r-- | drivers/char/agp/sworks-agp.c | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/drivers/char/agp/sworks-agp.c b/drivers/char/agp/sworks-agp.c index a9fb12c20eb7..53968973f890 100644 --- a/drivers/char/agp/sworks-agp.c +++ b/drivers/char/agp/sworks-agp.c | |||
| @@ -242,13 +242,27 @@ static int serverworks_fetch_size(void) | |||
| 242 | */ | 242 | */ |
| 243 | static void serverworks_tlbflush(struct agp_memory *temp) | 243 | static void serverworks_tlbflush(struct agp_memory *temp) |
| 244 | { | 244 | { |
| 245 | unsigned long timeout; | ||
| 246 | |||
| 245 | writeb(1, serverworks_private.registers+SVWRKS_POSTFLUSH); | 247 | writeb(1, serverworks_private.registers+SVWRKS_POSTFLUSH); |
| 246 | while (readb(serverworks_private.registers+SVWRKS_POSTFLUSH) == 1) | 248 | timeout = jiffies + 3*HZ; |
| 249 | while (readb(serverworks_private.registers+SVWRKS_POSTFLUSH) == 1) { | ||
| 247 | cpu_relax(); | 250 | cpu_relax(); |
| 251 | if (time_after(jiffies, timeout)) { | ||
| 252 | printk(KERN_ERR PFX "TLB post flush took more than 3 seconds\n"); | ||
| 253 | break; | ||
| 254 | } | ||
| 255 | } | ||
| 248 | 256 | ||
| 249 | writel(1, serverworks_private.registers+SVWRKS_DIRFLUSH); | 257 | writel(1, serverworks_private.registers+SVWRKS_DIRFLUSH); |
| 250 | while(readl(serverworks_private.registers+SVWRKS_DIRFLUSH) == 1) | 258 | timeout = jiffies + 3*HZ; |
| 259 | while (readl(serverworks_private.registers+SVWRKS_DIRFLUSH) == 1) { | ||
| 251 | cpu_relax(); | 260 | cpu_relax(); |
| 261 | if (time_after(jiffies, timeout)) { | ||
| 262 | printk(KERN_ERR PFX "TLB Dir flush took more than 3 seconds\n"); | ||
| 263 | break; | ||
| 264 | } | ||
| 265 | } | ||
| 252 | } | 266 | } |
| 253 | 267 | ||
| 254 | static int serverworks_configure(void) | 268 | static int serverworks_configure(void) |
