aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorAndrew Morton <akpm@linux-foundation.org>2010-10-28 08:15:26 -0400
committerJens Axboe <jaxboe@fusionio.com>2010-10-28 08:15:26 -0400
commit027b180d7405f2b2df25e2a8b1b796b00f3773cf (patch)
tree131c7744e2f4c2d3deeb8d74485c528e67707e80 /drivers
parente1fbd9210d5d172f951b1d21eb58383919c4d10d (diff)
drivers/block/aoe/aoeblk.c: ratelimit a warning printk
As described in https://bugzilla.kernel.org/show_bug.cgi?id=19922 : I had an AoE device go down overnight, and while a server was trying to : write to it, it was also writing this message to its logs: : : 209 printk(KERN_INFO "aoe: device %ld.%d is not up\n", : 210 d->aoemajor, d->aoeminor); : : The message appeared many times per second, and over several hours : produced about 7.5 gigabytes of log files, filling up all free space on : the root filesystem. Cc: "Ed L. Cashin" <ecashin@coraid.com> Suggested-by: Roman Mamedov <roman@rm.pp.ru> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Jens Axboe <jaxboe@fusionio.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/block/aoe/aoeblk.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/block/aoe/aoeblk.c b/drivers/block/aoe/aoeblk.c
index f21c237a9e5e..541e18879965 100644
--- a/drivers/block/aoe/aoeblk.c
+++ b/drivers/block/aoe/aoeblk.c
@@ -4,12 +4,14 @@
4 * block device routines 4 * block device routines
5 */ 5 */
6 6
7#include <linux/kernel.h>
7#include <linux/hdreg.h> 8#include <linux/hdreg.h>
8#include <linux/blkdev.h> 9#include <linux/blkdev.h>
9#include <linux/backing-dev.h> 10#include <linux/backing-dev.h>
10#include <linux/fs.h> 11#include <linux/fs.h>
11#include <linux/ioctl.h> 12#include <linux/ioctl.h>
12#include <linux/slab.h> 13#include <linux/slab.h>
14#include <linux/ratelimit.h>
13#include <linux/genhd.h> 15#include <linux/genhd.h>
14#include <linux/netdevice.h> 16#include <linux/netdevice.h>
15#include <linux/mutex.h> 17#include <linux/mutex.h>
@@ -207,7 +209,7 @@ aoeblk_make_request(struct request_queue *q, struct bio *bio)
207 spin_lock_irqsave(&d->lock, flags); 209 spin_lock_irqsave(&d->lock, flags);
208 210
209 if ((d->flags & DEVFL_UP) == 0) { 211 if ((d->flags & DEVFL_UP) == 0) {
210 printk(KERN_INFO "aoe: device %ld.%d is not up\n", 212 pr_info_ratelimited("aoe: device %ld.%d is not up\n",
211 d->aoemajor, d->aoeminor); 213 d->aoemajor, d->aoeminor);
212 spin_unlock_irqrestore(&d->lock, flags); 214 spin_unlock_irqrestore(&d->lock, flags);
213 mempool_free(buf, d->bufpool); 215 mempool_free(buf, d->bufpool);