aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md
diff options
context:
space:
mode:
authorMike Snitzer <snitzer@redhat.com>2012-12-21 15:23:34 -0500
committerAlasdair G Kergon <agk@redhat.com>2012-12-21 15:23:34 -0500
commitc397741c7645de7f2ead1f076f1a40e169875fe3 (patch)
treedba3e0c8ee01a50fa22f2668c34a0d2ab06dc7ba /drivers/md
parent89ddeb8cb1383bfdfaaeb458f1c4a91e890cc60b (diff)
dm thin: use DMERR_LIMIT for errors
Throttle all errors logged from the IO path by dm thin. Signed-off-by: Mike Snitzer <snitzer@redhat.com> Signed-off-by: Alasdair G Kergon <agk@redhat.com>
Diffstat (limited to 'drivers/md')
-rw-r--r--drivers/md/dm-thin.c25
1 files changed, 15 insertions, 10 deletions
diff --git a/drivers/md/dm-thin.c b/drivers/md/dm-thin.c
index 6b9322e63651..fba378f234a5 100644
--- a/drivers/md/dm-thin.c
+++ b/drivers/md/dm-thin.c
@@ -567,7 +567,7 @@ static void process_prepared_mapping(struct dm_thin_new_mapping *m)
567 */ 567 */
568 r = dm_thin_insert_block(tc->td, m->virt_block, m->data_block); 568 r = dm_thin_insert_block(tc->td, m->virt_block, m->data_block);
569 if (r) { 569 if (r) {
570 DMERR("dm_thin_insert_block() failed"); 570 DMERR_LIMIT("dm_thin_insert_block() failed");
571 dm_cell_error(m->cell); 571 dm_cell_error(m->cell);
572 goto out; 572 goto out;
573 } 573 }
@@ -622,7 +622,7 @@ static void process_prepared_discard(struct dm_thin_new_mapping *m)
622 622
623 r = dm_thin_remove_block(tc->td, m->virt_block); 623 r = dm_thin_remove_block(tc->td, m->virt_block);
624 if (r) 624 if (r)
625 DMERR("dm_thin_remove_block() failed"); 625 DMERR_LIMIT("dm_thin_remove_block() failed");
626 626
627 process_prepared_discard_passdown(m); 627 process_prepared_discard_passdown(m);
628} 628}
@@ -736,7 +736,7 @@ static void schedule_copy(struct thin_c *tc, dm_block_t virt_block,
736 0, copy_complete, m); 736 0, copy_complete, m);
737 if (r < 0) { 737 if (r < 0) {
738 mempool_free(m, pool->mapping_pool); 738 mempool_free(m, pool->mapping_pool);
739 DMERR("dm_kcopyd_copy() failed"); 739 DMERR_LIMIT("dm_kcopyd_copy() failed");
740 dm_cell_error(cell); 740 dm_cell_error(cell);
741 } 741 }
742 } 742 }
@@ -802,7 +802,7 @@ static void schedule_zero(struct thin_c *tc, dm_block_t virt_block,
802 r = dm_kcopyd_zero(pool->copier, 1, &to, 0, copy_complete, m); 802 r = dm_kcopyd_zero(pool->copier, 1, &to, 0, copy_complete, m);
803 if (r < 0) { 803 if (r < 0) {
804 mempool_free(m, pool->mapping_pool); 804 mempool_free(m, pool->mapping_pool);
805 DMERR("dm_kcopyd_zero() failed"); 805 DMERR_LIMIT("dm_kcopyd_zero() failed");
806 dm_cell_error(cell); 806 dm_cell_error(cell);
807 } 807 }
808 } 808 }
@@ -814,7 +814,7 @@ static int commit(struct pool *pool)
814 814
815 r = dm_pool_commit_metadata(pool->pmd); 815 r = dm_pool_commit_metadata(pool->pmd);
816 if (r) 816 if (r)
817 DMERR("commit failed, error = %d", r); 817 DMERR_LIMIT("commit failed: error = %d", r);
818 818
819 return r; 819 return r;
820} 820}
@@ -997,7 +997,8 @@ static void process_discard(struct thin_c *tc, struct bio *bio)
997 break; 997 break;
998 998
999 default: 999 default:
1000 DMERR("discard: find block unexpectedly returned %d", r); 1000 DMERR_LIMIT("%s: dm_thin_find_block() failed: error = %d",
1001 __func__, r);
1001 cell_defer_no_holder(tc, cell); 1002 cell_defer_no_holder(tc, cell);
1002 bio_io_error(bio); 1003 bio_io_error(bio);
1003 break; 1004 break;
@@ -1024,7 +1025,8 @@ static void break_sharing(struct thin_c *tc, struct bio *bio, dm_block_t block,
1024 break; 1025 break;
1025 1026
1026 default: 1027 default:
1027 DMERR("%s: alloc_data_block() failed, error = %d", __func__, r); 1028 DMERR_LIMIT("%s: alloc_data_block() failed: error = %d",
1029 __func__, r);
1028 dm_cell_error(cell); 1030 dm_cell_error(cell);
1029 break; 1031 break;
1030 } 1032 }
@@ -1100,7 +1102,8 @@ static void provision_block(struct thin_c *tc, struct bio *bio, dm_block_t block
1100 break; 1102 break;
1101 1103
1102 default: 1104 default:
1103 DMERR("%s: alloc_data_block() failed, error = %d", __func__, r); 1105 DMERR_LIMIT("%s: alloc_data_block() failed: error = %d",
1106 __func__, r);
1104 set_pool_mode(tc->pool, PM_READ_ONLY); 1107 set_pool_mode(tc->pool, PM_READ_ONLY);
1105 dm_cell_error(cell); 1108 dm_cell_error(cell);
1106 break; 1109 break;
@@ -1148,7 +1151,8 @@ static void process_bio(struct thin_c *tc, struct bio *bio)
1148 break; 1151 break;
1149 1152
1150 default: 1153 default:
1151 DMERR("dm_thin_find_block() failed, error = %d", r); 1154 DMERR_LIMIT("%s: dm_thin_find_block() failed: error = %d",
1155 __func__, r);
1152 cell_defer_no_holder(tc, cell); 1156 cell_defer_no_holder(tc, cell);
1153 bio_io_error(bio); 1157 bio_io_error(bio);
1154 break; 1158 break;
@@ -1190,7 +1194,8 @@ static void process_bio_read_only(struct thin_c *tc, struct bio *bio)
1190 break; 1194 break;
1191 1195
1192 default: 1196 default:
1193 DMERR("dm_thin_find_block() failed, error = %d", r); 1197 DMERR_LIMIT("%s: dm_thin_find_block() failed: error = %d",
1198 __func__, r);
1194 bio_io_error(bio); 1199 bio_io_error(bio);
1195 break; 1200 break;
1196 } 1201 }