aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/block/cciss.c45
1 files changed, 23 insertions, 22 deletions
diff --git a/drivers/block/cciss.c b/drivers/block/cciss.c
index 156ea365c14d..10a0268a1f92 100644
--- a/drivers/block/cciss.c
+++ b/drivers/block/cciss.c
@@ -213,6 +213,7 @@ static void cciss_hba_release(struct device *dev);
213static void cciss_device_release(struct device *dev); 213static void cciss_device_release(struct device *dev);
214static void cciss_free_gendisk(ctlr_info_t *h, int drv_index); 214static void cciss_free_gendisk(ctlr_info_t *h, int drv_index);
215static void cciss_free_drive_info(ctlr_info_t *h, int drv_index); 215static void cciss_free_drive_info(ctlr_info_t *h, int drv_index);
216static inline u32 next_command(ctlr_info_t *h);
216 217
217/* performant mode helper functions */ 218/* performant mode helper functions */
218static void calc_bucket_map(int *bucket, int num_buckets, int nsgs, 219static void calc_bucket_map(int *bucket, int num_buckets, int nsgs,
@@ -374,28 +375,6 @@ static const char *raid_label[] = { "0", "4", "1(1+0)", "5", "5+1", "ADG",
374 375
375#ifdef CONFIG_PROC_FS 376#ifdef CONFIG_PROC_FS
376 377
377static inline u32 next_command(ctlr_info_t *h)
378{
379 u32 a;
380
381 if (unlikely(h->transMethod != CFGTBL_Trans_Performant))
382 return h->access.command_completed(h);
383
384 if ((*(h->reply_pool_head) & 1) == (h->reply_pool_wraparound)) {
385 a = *(h->reply_pool_head); /* Next cmd in ring buffer */
386 (h->reply_pool_head)++;
387 h->commands_outstanding--;
388 } else {
389 a = FIFO_EMPTY;
390 }
391 /* Check for wraparound */
392 if (h->reply_pool_head == (h->reply_pool + h->max_commands)) {
393 h->reply_pool_head = h->reply_pool;
394 h->reply_pool_wraparound ^= 1;
395 }
396 return a;
397}
398
399/* 378/*
400 * Report information about this controller. 379 * Report information about this controller.
401 */ 380 */
@@ -3411,6 +3390,28 @@ static inline void finish_cmd(ctlr_info_t *h, CommandList_struct *c,
3411#endif 3390#endif
3412} 3391}
3413 3392
3393static inline u32 next_command(ctlr_info_t *h)
3394{
3395 u32 a;
3396
3397 if (unlikely(h->transMethod != CFGTBL_Trans_Performant))
3398 return h->access.command_completed(h);
3399
3400 if ((*(h->reply_pool_head) & 1) == (h->reply_pool_wraparound)) {
3401 a = *(h->reply_pool_head); /* Next cmd in ring buffer */
3402 (h->reply_pool_head)++;
3403 h->commands_outstanding--;
3404 } else {
3405 a = FIFO_EMPTY;
3406 }
3407 /* Check for wraparound */
3408 if (h->reply_pool_head == (h->reply_pool + h->max_commands)) {
3409 h->reply_pool_head = h->reply_pool;
3410 h->reply_pool_wraparound ^= 1;
3411 }
3412 return a;
3413}
3414
3414/* process completion of an indexed ("direct lookup") command */ 3415/* process completion of an indexed ("direct lookup") command */
3415static inline u32 process_indexed_cmd(ctlr_info_t *h, u32 raw_tag) 3416static inline u32 process_indexed_cmd(ctlr_info_t *h, u32 raw_tag)
3416{ 3417{