From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jens Axboe Subject: Re: [RFC PATCH 3/3] blk_end_request: caller change Date: Thu, 11 Jan 2007 09:34:31 +0100 Message-ID: <20070111083430.GD11203@kernel.dk> References: <20070110.180859.78702215.k-ueda@ct.jp.nec.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <20070110.180859.78702215.k-ueda@ct.jp.nec.com> Sender: linux-scsi-owner@vger.kernel.org To: Kiyoshi Ueda Cc: linux-kernel@vger.kernel.org, linux-scsi@vger.kernel.org, dm-devel@redhat.com, j-nomura@ce.jp.nec.com List-Id: dm-devel.ids On Wed, Jan 10 2007, Kiyoshi Ueda wrote: > +static int end_request_callback(void *arg) > +{ > + struct request *req = (struct request *)arg; > + > + add_disk_randomness(req->rq_disk); > + blkdev_dequeue_request(req); > + > + return 0; > +} This is bad, don't pass void * around. > +static int cdrom_newpc_intr_dma_callback(void *arg) > +{ > + void **argv = (void **)arg; > + struct request *rq = (struct request *)*argv++; > + ide_drive_t *drive = (ide_drive_t *)argv++; > + spinlock_t *ide_lock = (spinlock_t *)argv; > + > + rq->data_len = 0; > + > + cdrom_newpc_intr_callback_common(rq, drive, ide_lock); > + > + return 0; > +} And this is why, down right horrible. The callback should be correctly typed, pass down a request pointer ALWAYS. -- Jens Axboe