Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755972Ab1EKVEv (ORCPT ); Wed, 11 May 2011 17:04:51 -0400 Received: from e8.ny.us.ibm.com ([32.97.182.138]:46230 "EHLO e8.ny.us.ibm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755608Ab1EKVEu (ORCPT ); Wed, 11 May 2011 17:04:50 -0400 Subject: Re: [PATCH 2/3] printk: Add %ptc to safely print a task's comm From: John Stultz To: Andi Kleen Cc: LKML , "Ted Ts'o" , KOSAKI Motohiro , David Rientjes , Dave Hansen , Andrew Morton , linux-mm@kvack.org In-Reply-To: References: <1305073386-4810-1-git-send-email-john.stultz@linaro.org> <1305073386-4810-3-git-send-email-john.stultz@linaro.org> Content-Type: text/plain; charset="UTF-8" Date: Wed, 11 May 2011 14:04:27 -0700 Message-ID: <1305147867.2883.2.camel@work-vm> Mime-Version: 1.0 X-Mailer: Evolution 2.32.2 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1055 Lines: 30 On Wed, 2011-05-11 at 10:36 -0700, Andi Kleen wrote: > John Stultz writes: > > > Acessing task->comm requires proper locking. However in the past > > access to current->comm could be done without locking. This > > is no longer the case, so all comm access needs to be done > > while holding the comm_lock. > > > > In my attempt to clean up unprotected comm access, I've noticed > > most comm access is done for printk output. To simpify correct > > locking in these cases, I've introduced a new %ptc format, > > which will safely print the corresponding task's comm. > > > > Example use: > > printk("%ptc: unaligned epc - sending SIGBUS.\n", current); > > Neat. But you probably want a checkpatch rule for this too > to catch new offenders. Yea. That's on my queue. thanks -john -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/