aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorBorislav Petkov <petkovbb@googlemail.com>2008-04-27 09:38:25 -0400
committerBartlomiej Zolnierkiewicz <bzolnier@gmail.com>2008-04-27 09:38:25 -0400
commitddfe7a776360f7067e06eee9d8b1ae4d957e6ddf (patch)
treea21e169170f98bda7b604a9b481c12d6ffaf3482 /drivers
parent97c566cebe083b8e500c9b0b5033212c809d9844 (diff)
ide-tape remove pipeline speed/control calculations
Pipeline handling calculations in idetape_calculate_speeds() can go since they do not have any effect on other functionality besides: 1. info is only being exported through /proc as a read-only item (controlled_pipeline_head_speed, uncontrolled_pipeline_head_speed) 2. used in idetape_restart_speed_control() which, in turn, is unrelated to other code 3. used only for pipeline frames number accounting (tape->pipeline_head), also unused elsewhere. 4.some variables are: only written to: tape->buffer_head; unused: tape->tape_head, tape->last_tape_head Signed-off-by: Borislav Petkov <petkovbb@gmail.com> Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/ide/ide-tape.c131
1 files changed, 0 insertions, 131 deletions
diff --git a/drivers/ide/ide-tape.c b/drivers/ide/ide-tape.c
index 71ebee001882..e785145abb47 100644
--- a/drivers/ide/ide-tape.c
+++ b/drivers/ide/ide-tape.c
@@ -84,9 +84,6 @@ enum {
84 * We start from MIN maximum stages (we will not even use MIN stages if we don't 84 * We start from MIN maximum stages (we will not even use MIN stages if we don't
85 * need them), increment it by RATE*(MAX-MIN) whenever we sense that the 85 * need them), increment it by RATE*(MAX-MIN) whenever we sense that the
86 * pipeline is empty, until we reach the optimum value or until we reach MAX. 86 * pipeline is empty, until we reach the optimum value or until we reach MAX.
87 *
88 * Setting the following parameter to 0 is illegal: the pipelined mode cannot be
89 * disabled (idetape_calculate_speeds() divides by tape->max_stages.)
90 */ 87 */
91#define IDETAPE_MIN_PIPELINE_STAGES 1 88#define IDETAPE_MIN_PIPELINE_STAGES 1
92#define IDETAPE_MAX_PIPELINE_STAGES 400 89#define IDETAPE_MAX_PIPELINE_STAGES 400
@@ -392,39 +389,12 @@ typedef struct ide_tape_obj {
392 */ 389 */
393 int postpone_cnt; 390 int postpone_cnt;
394 391
395 /*
396 * Measures number of frames:
397 *
398 * 1. written/read to/from the driver pipeline (pipeline_head).
399 * 2. written/read to/from the tape buffers (idetape_bh).
400 * 3. written/read by the tape to/from the media (tape_head).
401 */
402 int pipeline_head;
403 int buffer_head;
404 int tape_head;
405 int last_tape_head;
406
407 /* Speed control at the tape buffers input/output */ 392 /* Speed control at the tape buffers input/output */
408 unsigned long insert_time; 393 unsigned long insert_time;
409 int insert_size; 394 int insert_size;
410 int insert_speed; 395 int insert_speed;
411 int max_insert_speed;
412 int measure_insert_time; 396 int measure_insert_time;
413 397
414 /* Speed regulation negative feedback loop */
415 int speed_control;
416 int pipeline_head_speed;
417 int controlled_pipeline_head_speed;
418 int uncontrolled_pipeline_head_speed;
419 int controlled_last_pipeline_head;
420 unsigned long uncontrolled_pipeline_head_time;
421 unsigned long controlled_pipeline_head_time;
422 int controlled_previous_pipeline_head;
423 int uncontrolled_previous_pipeline_head;
424 unsigned long controlled_previous_head_time;
425 unsigned long uncontrolled_previous_head_time;
426 int restart_speed_control_req;
427
428 u32 debug_mask; 398 u32 debug_mask;
429} idetape_tape_t; 399} idetape_tape_t;
430 400
@@ -1333,69 +1303,6 @@ static void idetape_create_mode_sense_cmd(struct ide_atapi_pc *pc, u8 page_code)
1333 pc->idetape_callback = &idetape_pc_callback; 1303 pc->idetape_callback = &idetape_pc_callback;
1334} 1304}
1335 1305
1336static void idetape_calculate_speeds(ide_drive_t *drive)
1337{
1338 idetape_tape_t *tape = drive->driver_data;
1339
1340 if (time_after(jiffies,
1341 tape->controlled_pipeline_head_time + 120 * HZ)) {
1342 tape->controlled_previous_pipeline_head =
1343 tape->controlled_last_pipeline_head;
1344 tape->controlled_previous_head_time =
1345 tape->controlled_pipeline_head_time;
1346 tape->controlled_last_pipeline_head = tape->pipeline_head;
1347 tape->controlled_pipeline_head_time = jiffies;
1348 }
1349 if (time_after(jiffies, tape->controlled_pipeline_head_time + 60 * HZ))
1350 tape->controlled_pipeline_head_speed = (tape->pipeline_head -
1351 tape->controlled_last_pipeline_head) * 32 * HZ /
1352 (jiffies - tape->controlled_pipeline_head_time);
1353 else if (time_after(jiffies, tape->controlled_previous_head_time))
1354 tape->controlled_pipeline_head_speed = (tape->pipeline_head -
1355 tape->controlled_previous_pipeline_head) * 32 *
1356 HZ / (jiffies - tape->controlled_previous_head_time);
1357
1358 if (tape->nr_pending_stages < tape->max_stages/*- 1 */) {
1359 /* -1 for read mode error recovery */
1360 if (time_after(jiffies, tape->uncontrolled_previous_head_time +
1361 10 * HZ)) {
1362 tape->uncontrolled_pipeline_head_time = jiffies;
1363 tape->uncontrolled_pipeline_head_speed =
1364 (tape->pipeline_head -
1365 tape->uncontrolled_previous_pipeline_head) *
1366 32 * HZ / (jiffies -
1367 tape->uncontrolled_previous_head_time);
1368 }
1369 } else {
1370 tape->uncontrolled_previous_head_time = jiffies;
1371 tape->uncontrolled_previous_pipeline_head = tape->pipeline_head;
1372 if (time_after(jiffies, tape->uncontrolled_pipeline_head_time +
1373 30 * HZ))
1374 tape->uncontrolled_pipeline_head_time = jiffies;
1375
1376 }
1377 tape->pipeline_head_speed = max(tape->uncontrolled_pipeline_head_speed,
1378 tape->controlled_pipeline_head_speed);
1379
1380 if (tape->speed_control == 1) {
1381 if (tape->nr_pending_stages >= tape->max_stages / 2)
1382 tape->max_insert_speed = tape->pipeline_head_speed +
1383 (1100 - tape->pipeline_head_speed) * 2 *
1384 (tape->nr_pending_stages - tape->max_stages / 2)
1385 / tape->max_stages;
1386 else
1387 tape->max_insert_speed = 500 +
1388 (tape->pipeline_head_speed - 500) * 2 *
1389 tape->nr_pending_stages / tape->max_stages;
1390
1391 if (tape->nr_pending_stages >= tape->max_stages * 99 / 100)
1392 tape->max_insert_speed = 5000;
1393 } else
1394 tape->max_insert_speed = tape->speed_control;
1395
1396 tape->max_insert_speed = max(tape->max_insert_speed, 500);
1397}
1398
1399static ide_startstop_t idetape_media_access_finished(ide_drive_t *drive) 1306static ide_startstop_t idetape_media_access_finished(ide_drive_t *drive)
1400{ 1307{
1401 idetape_tape_t *tape = drive->driver_data; 1308 idetape_tape_t *tape = drive->driver_data;
@@ -1548,7 +1455,6 @@ static ide_startstop_t idetape_do_request(ide_drive_t *drive,
1548 if (time_after(jiffies, tape->insert_time)) 1455 if (time_after(jiffies, tape->insert_time))
1549 tape->insert_speed = tape->insert_size / 1024 * HZ / 1456 tape->insert_speed = tape->insert_size / 1024 * HZ /
1550 (jiffies - tape->insert_time); 1457 (jiffies - tape->insert_time);
1551 idetape_calculate_speeds(drive);
1552 if (!test_and_clear_bit(IDETAPE_FLAG_IGNORE_DSC, &tape->flags) && 1458 if (!test_and_clear_bit(IDETAPE_FLAG_IGNORE_DSC, &tape->flags) &&
1553 (stat & SEEK_STAT) == 0) { 1459 (stat & SEEK_STAT) == 0) {
1554 if (postponed_rq == NULL) { 1460 if (postponed_rq == NULL) {
@@ -1572,7 +1478,6 @@ static ide_startstop_t idetape_do_request(ide_drive_t *drive,
1572 return ide_stopped; 1478 return ide_stopped;
1573 } 1479 }
1574 if (rq->cmd[0] & REQ_IDETAPE_READ) { 1480 if (rq->cmd[0] & REQ_IDETAPE_READ) {
1575 tape->buffer_head++;
1576 tape->postpone_cnt = 0; 1481 tape->postpone_cnt = 0;
1577 pc = idetape_next_pc_storage(drive); 1482 pc = idetape_next_pc_storage(drive);
1578 idetape_create_read_cmd(tape, pc, rq->current_nr_sectors, 1483 idetape_create_read_cmd(tape, pc, rq->current_nr_sectors,
@@ -1580,7 +1485,6 @@ static ide_startstop_t idetape_do_request(ide_drive_t *drive,
1580 goto out; 1485 goto out;
1581 } 1486 }
1582 if (rq->cmd[0] & REQ_IDETAPE_WRITE) { 1487 if (rq->cmd[0] & REQ_IDETAPE_WRITE) {
1583 tape->buffer_head++;
1584 tape->postpone_cnt = 0; 1488 tape->postpone_cnt = 0;
1585 pc = idetape_next_pc_storage(drive); 1489 pc = idetape_next_pc_storage(drive);
1586 idetape_create_write_cmd(tape, pc, rq->current_nr_sectors, 1490 idetape_create_write_cmd(tape, pc, rq->current_nr_sectors,
@@ -2321,24 +2225,6 @@ static void idetape_empty_write_pipeline(ide_drive_t *drive)
2321 } 2225 }
2322} 2226}
2323 2227
2324static void idetape_restart_speed_control(ide_drive_t *drive)
2325{
2326 idetape_tape_t *tape = drive->driver_data;
2327
2328 tape->restart_speed_control_req = 0;
2329 tape->pipeline_head = 0;
2330 tape->controlled_last_pipeline_head = 0;
2331 tape->controlled_previous_pipeline_head = 0;
2332 tape->uncontrolled_previous_pipeline_head = 0;
2333 tape->controlled_pipeline_head_speed = 5000;
2334 tape->pipeline_head_speed = 5000;
2335 tape->uncontrolled_pipeline_head_speed = 0;
2336 tape->controlled_pipeline_head_time =
2337 tape->uncontrolled_pipeline_head_time = jiffies;
2338 tape->controlled_previous_head_time =
2339 tape->uncontrolled_previous_head_time = jiffies;
2340}
2341
2342static int idetape_init_read(ide_drive_t *drive, int max_stages) 2228static int idetape_init_read(ide_drive_t *drive, int max_stages)
2343{ 2229{
2344 idetape_tape_t *tape = drive->driver_data; 2230 idetape_tape_t *tape = drive->driver_data;
@@ -2381,8 +2267,6 @@ static int idetape_init_read(ide_drive_t *drive, int max_stages)
2381 } 2267 }
2382 } 2268 }
2383 } 2269 }
2384 if (tape->restart_speed_control_req)
2385 idetape_restart_speed_control(drive);
2386 idetape_init_rq(&rq, REQ_IDETAPE_READ); 2270 idetape_init_rq(&rq, REQ_IDETAPE_READ);
2387 rq.sector = tape->first_frame; 2271 rq.sector = tape->first_frame;
2388 rq.nr_sectors = blocks; 2272 rq.nr_sectors = blocks;
@@ -2451,8 +2335,6 @@ static int idetape_add_chrdev_read_request(ide_drive_t *drive, int blocks)
2451 spin_lock_irqsave(&tape->lock, flags); 2335 spin_lock_irqsave(&tape->lock, flags);
2452 idetape_remove_stage_head(drive); 2336 idetape_remove_stage_head(drive);
2453 spin_unlock_irqrestore(&tape->lock, flags); 2337 spin_unlock_irqrestore(&tape->lock, flags);
2454 tape->pipeline_head++;
2455 idetape_calculate_speeds(drive);
2456 } 2338 }
2457 if (bytes_read > blocks * tape->blk_size) { 2339 if (bytes_read > blocks * tape->blk_size) {
2458 printk(KERN_ERR "ide-tape: bug: trying to return more bytes" 2340 printk(KERN_ERR "ide-tape: bug: trying to return more bytes"
@@ -2787,8 +2669,6 @@ static ssize_t idetape_chrdev_write(struct file *file, const char __user *buf,
2787 } 2669 }
2788 if (count == 0) 2670 if (count == 0)
2789 return (0); 2671 return (0);
2790 if (tape->restart_speed_control_req)
2791 idetape_restart_speed_control(drive);
2792 if (tape->merge_stage_size) { 2672 if (tape->merge_stage_size) {
2793 if (tape->merge_stage_size >= tape->stage_size) { 2673 if (tape->merge_stage_size >= tape->stage_size) {
2794 printk(KERN_ERR "ide-tape: bug: merge buf too big\n"); 2674 printk(KERN_ERR "ide-tape: bug: merge buf too big\n");
@@ -2997,7 +2877,6 @@ static int idetape_chrdev_ioctl(struct inode *inode, struct file *file,
2997 2877
2998 debug_log(DBG_CHRDEV, "Enter %s, cmd=%u\n", __func__, cmd); 2878 debug_log(DBG_CHRDEV, "Enter %s, cmd=%u\n", __func__, cmd);
2999 2879
3000 tape->restart_speed_control_req = 1;
3001 if (tape->chrdev_dir == IDETAPE_DIR_WRITE) { 2880 if (tape->chrdev_dir == IDETAPE_DIR_WRITE) {
3002 idetape_empty_write_pipeline(drive); 2881 idetape_empty_write_pipeline(drive);
3003 idetape_flush_tape_buffers(drive); 2882 idetape_flush_tape_buffers(drive);
@@ -3140,8 +3019,6 @@ static int idetape_chrdev_open(struct inode *inode, struct file *filp)
3140 } 3019 }
3141 } 3020 }
3142 } 3021 }
3143 idetape_restart_speed_control(drive);
3144 tape->restart_speed_control_req = 0;
3145 return 0; 3022 return 0;
3146 3023
3147out_put_tape: 3024out_put_tape:
@@ -3344,12 +3221,6 @@ static void idetape_add_settings(ide_drive_t *drive)
3344 NULL); 3221 NULL);
3345 ide_add_setting(drive, "dsc_overlap", SETTING_RW, TYPE_BYTE, 0, 1, 1, 3222 ide_add_setting(drive, "dsc_overlap", SETTING_RW, TYPE_BYTE, 0, 1, 1,
3346 1, &drive->dsc_overlap, NULL); 3223 1, &drive->dsc_overlap, NULL);
3347 ide_add_setting(drive, "pipeline_head_speed_c", SETTING_READ, TYPE_INT,
3348 0, 0xffff, 1, 1, &tape->controlled_pipeline_head_speed,
3349 NULL);
3350 ide_add_setting(drive, "pipeline_head_speed_u", SETTING_READ, TYPE_INT,
3351 0, 0xffff, 1, 1,
3352 &tape->uncontrolled_pipeline_head_speed, NULL);
3353 ide_add_setting(drive, "avg_speed", SETTING_READ, TYPE_INT, 0, 0xffff, 3224 ide_add_setting(drive, "avg_speed", SETTING_READ, TYPE_INT, 0, 0xffff,
3354 1, 1, &tape->avg_speed, NULL); 3225 1, 1, &tape->avg_speed, NULL);
3355 ide_add_setting(drive, "debug_mask", SETTING_RW, TYPE_INT, 0, 0xffff, 1, 3226 ide_add_setting(drive, "debug_mask", SETTING_RW, TYPE_INT, 0, 0xffff, 1,
@@ -3395,8 +3266,6 @@ static void idetape_setup(ide_drive_t *drive, idetape_tape_t *tape, int minor)
3395 tape->name[2] = '0' + minor; 3266 tape->name[2] = '0' + minor;
3396 tape->chrdev_dir = IDETAPE_DIR_NONE; 3267 tape->chrdev_dir = IDETAPE_DIR_NONE;
3397 tape->pc = tape->pc_stack; 3268 tape->pc = tape->pc_stack;
3398 tape->max_insert_speed = 10000;
3399 tape->speed_control = 1;
3400 *((unsigned short *) &gcw) = drive->id->config; 3269 *((unsigned short *) &gcw) = drive->id->config;
3401 3270
3402 /* Command packet DRQ type */ 3271 /* Command packet DRQ type */