From mboxrd@z Thu Jan 1 00:00:00 1970 From: Andrew Morton Subject: Re: [PATCH] serial8250: ratelimit "too much work" error Date: Mon, 4 Oct 2010 16:11:39 -0700 Message-ID: <20101004161139.2a988b85.akpm@linux-foundation.org> References: <20101002110438.801F49D401B@zog.reactivated.net> <20101004145101.b28fdc0a.akpm@linux-foundation.org> <20101004150238.fbc1b6cf.akpm@linux-foundation.org> <1286230259.10512.81.camel@Joe-Laptop> <20101004152102.1e04f30a.akpm@linux-foundation.org> <1286233169.10512.85.camel@Joe-Laptop> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Return-path: Received: from smtp1.linux-foundation.org ([140.211.169.13]:50005 "EHLO smtp1.linux-foundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752125Ab0JDXMW (ORCPT ); Mon, 4 Oct 2010 19:12:22 -0400 In-Reply-To: <1286233169.10512.85.camel@Joe-Laptop> Sender: linux-serial-owner@vger.kernel.org List-Id: linux-serial@vger.kernel.org To: Joe Perches Cc: Daniel Drake , linux-serial@vger.kernel.org, linux-kernel@vger.kernel.org, Alan Cox , Greg KH On Mon, 04 Oct 2010 15:59:29 -0700 Joe Perches wrote: > On Mon, 2010-10-04 at 15:21 -0700, Andrew Morton wrote: > > On Mon, 04 Oct 2010 15:10:59 -0700 > > Joe Perches wrote: > > > On Mon, 2010-10-04 at 15:02 -0700, Andrew Morton wrote: > > > > On Mon, 4 Oct 2010 14:51:01 -0700 > > > > Andrew Morton wrote: > > > > I'll give up and pronounce that users of printk_ratelimited() need to > > > > include ratelimit.h as well. > > > What I suggested several months ago was to move the > > > macro definitions to ratelimit.h > > > http://lkml.org/lkml/2010/2/18/377 > > That's a bit nasty because at present ratelimit.h is purely about > > ratelimiting and knowns nothing about any of its clients. At present > > it has only one client (printk), but it could have more in the future! > > Look at the structure, it's very specific to > message logging functionality. > > struct ratelimit_state { > spinlock_t lock; /* protect the state */ > > int interval; > int burst; > int printed; > int missed; > unsigned long begin; > }; s/printed/hit/there,fixed This is at present a quite general facility. > I think it's likely that the current ratelimit > will not be used for any other function. Filling it up with printk-specific stuff will help ensure that.