mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
xfs: Convert remaining cmn_err() callers to new API
Once converted, kill the remainder of the cmn_err() interface. Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Alex Elder <aelder@sgi.com> Reviewed-by: Christoph Hellwig <hch@lst.de>
This commit is contained in:
parent
8221112b43
commit
0b932cccbd
20 changed files with 169 additions and 238 deletions
|
@ -828,7 +828,7 @@ xfs_qm_dqget(
|
||||||
if (xfs_do_dqerror) {
|
if (xfs_do_dqerror) {
|
||||||
if ((xfs_dqerror_target == mp->m_ddev_targp) &&
|
if ((xfs_dqerror_target == mp->m_ddev_targp) &&
|
||||||
(xfs_dqreq_num++ % xfs_dqerror_mod) == 0) {
|
(xfs_dqreq_num++ % xfs_dqerror_mod) == 0) {
|
||||||
cmn_err(CE_DEBUG, "Returning error in dqget");
|
xfs_debug(mp, "Returning error in dqget");
|
||||||
return (EIO);
|
return (EIO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1427,36 +1427,38 @@ xfs_qm_dqpurge(
|
||||||
void
|
void
|
||||||
xfs_qm_dqprint(xfs_dquot_t *dqp)
|
xfs_qm_dqprint(xfs_dquot_t *dqp)
|
||||||
{
|
{
|
||||||
cmn_err(CE_DEBUG, "-----------KERNEL DQUOT----------------");
|
struct xfs_mount *mp = dqp->q_mount;
|
||||||
cmn_err(CE_DEBUG, "---- dquotID = %d",
|
|
||||||
|
xfs_debug(mp, "-----------KERNEL DQUOT----------------");
|
||||||
|
xfs_debug(mp, "---- dquotID = %d",
|
||||||
(int)be32_to_cpu(dqp->q_core.d_id));
|
(int)be32_to_cpu(dqp->q_core.d_id));
|
||||||
cmn_err(CE_DEBUG, "---- type = %s", DQFLAGTO_TYPESTR(dqp));
|
xfs_debug(mp, "---- type = %s", DQFLAGTO_TYPESTR(dqp));
|
||||||
cmn_err(CE_DEBUG, "---- fs = 0x%p", dqp->q_mount);
|
xfs_debug(mp, "---- fs = 0x%p", dqp->q_mount);
|
||||||
cmn_err(CE_DEBUG, "---- blkno = 0x%x", (int) dqp->q_blkno);
|
xfs_debug(mp, "---- blkno = 0x%x", (int) dqp->q_blkno);
|
||||||
cmn_err(CE_DEBUG, "---- boffset = 0x%x", (int) dqp->q_bufoffset);
|
xfs_debug(mp, "---- boffset = 0x%x", (int) dqp->q_bufoffset);
|
||||||
cmn_err(CE_DEBUG, "---- blkhlimit = %Lu (0x%x)",
|
xfs_debug(mp, "---- blkhlimit = %Lu (0x%x)",
|
||||||
be64_to_cpu(dqp->q_core.d_blk_hardlimit),
|
be64_to_cpu(dqp->q_core.d_blk_hardlimit),
|
||||||
(int)be64_to_cpu(dqp->q_core.d_blk_hardlimit));
|
(int)be64_to_cpu(dqp->q_core.d_blk_hardlimit));
|
||||||
cmn_err(CE_DEBUG, "---- blkslimit = %Lu (0x%x)",
|
xfs_debug(mp, "---- blkslimit = %Lu (0x%x)",
|
||||||
be64_to_cpu(dqp->q_core.d_blk_softlimit),
|
be64_to_cpu(dqp->q_core.d_blk_softlimit),
|
||||||
(int)be64_to_cpu(dqp->q_core.d_blk_softlimit));
|
(int)be64_to_cpu(dqp->q_core.d_blk_softlimit));
|
||||||
cmn_err(CE_DEBUG, "---- inohlimit = %Lu (0x%x)",
|
xfs_debug(mp, "---- inohlimit = %Lu (0x%x)",
|
||||||
be64_to_cpu(dqp->q_core.d_ino_hardlimit),
|
be64_to_cpu(dqp->q_core.d_ino_hardlimit),
|
||||||
(int)be64_to_cpu(dqp->q_core.d_ino_hardlimit));
|
(int)be64_to_cpu(dqp->q_core.d_ino_hardlimit));
|
||||||
cmn_err(CE_DEBUG, "---- inoslimit = %Lu (0x%x)",
|
xfs_debug(mp, "---- inoslimit = %Lu (0x%x)",
|
||||||
be64_to_cpu(dqp->q_core.d_ino_softlimit),
|
be64_to_cpu(dqp->q_core.d_ino_softlimit),
|
||||||
(int)be64_to_cpu(dqp->q_core.d_ino_softlimit));
|
(int)be64_to_cpu(dqp->q_core.d_ino_softlimit));
|
||||||
cmn_err(CE_DEBUG, "---- bcount = %Lu (0x%x)",
|
xfs_debug(mp, "---- bcount = %Lu (0x%x)",
|
||||||
be64_to_cpu(dqp->q_core.d_bcount),
|
be64_to_cpu(dqp->q_core.d_bcount),
|
||||||
(int)be64_to_cpu(dqp->q_core.d_bcount));
|
(int)be64_to_cpu(dqp->q_core.d_bcount));
|
||||||
cmn_err(CE_DEBUG, "---- icount = %Lu (0x%x)",
|
xfs_debug(mp, "---- icount = %Lu (0x%x)",
|
||||||
be64_to_cpu(dqp->q_core.d_icount),
|
be64_to_cpu(dqp->q_core.d_icount),
|
||||||
(int)be64_to_cpu(dqp->q_core.d_icount));
|
(int)be64_to_cpu(dqp->q_core.d_icount));
|
||||||
cmn_err(CE_DEBUG, "---- btimer = %d",
|
xfs_debug(mp, "---- btimer = %d",
|
||||||
(int)be32_to_cpu(dqp->q_core.d_btimer));
|
(int)be32_to_cpu(dqp->q_core.d_btimer));
|
||||||
cmn_err(CE_DEBUG, "---- itimer = %d",
|
xfs_debug(mp, "---- itimer = %d",
|
||||||
(int)be32_to_cpu(dqp->q_core.d_itimer));
|
(int)be32_to_cpu(dqp->q_core.d_itimer));
|
||||||
cmn_err(CE_DEBUG, "---------------------------");
|
xfs_debug(mp, "---------------------------");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -80,7 +80,7 @@ xfs_qm_dquot_list_print(
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
list_for_each_entry(dqp, &mp->m_quotainfo->qi_dqlist_lock, qi_mplist) {
|
list_for_each_entry(dqp, &mp->m_quotainfo->qi_dqlist_lock, qi_mplist) {
|
||||||
cmn_err(CE_DEBUG, " %d. \"%d (%s)\" "
|
xfs_debug(mp, " %d. \"%d (%s)\" "
|
||||||
"bcnt = %lld, icnt = %lld, refs = %d",
|
"bcnt = %lld, icnt = %lld, refs = %d",
|
||||||
i++, be32_to_cpu(dqp->q_core.d_id),
|
i++, be32_to_cpu(dqp->q_core.d_id),
|
||||||
DQFLAGTO_TYPESTR(dqp),
|
DQFLAGTO_TYPESTR(dqp),
|
||||||
|
@ -205,7 +205,7 @@ xfs_qm_destroy(
|
||||||
list_for_each_entry_safe(dqp, n, &xqm->qm_dqfrlist, q_freelist) {
|
list_for_each_entry_safe(dqp, n, &xqm->qm_dqfrlist, q_freelist) {
|
||||||
xfs_dqlock(dqp);
|
xfs_dqlock(dqp);
|
||||||
#ifdef QUOTADEBUG
|
#ifdef QUOTADEBUG
|
||||||
cmn_err(CE_DEBUG, "FREELIST destroy 0x%p", dqp);
|
xfs_debug(dqp->q_mount, "FREELIST destroy 0x%p", dqp);
|
||||||
#endif
|
#endif
|
||||||
list_del_init(&dqp->q_freelist);
|
list_del_init(&dqp->q_freelist);
|
||||||
xfs_Gqm->qm_dqfrlist_cnt--;
|
xfs_Gqm->qm_dqfrlist_cnt--;
|
||||||
|
@ -341,9 +341,7 @@ xfs_qm_mount_quotas(
|
||||||
* quotas immediately.
|
* quotas immediately.
|
||||||
*/
|
*/
|
||||||
if (mp->m_sb.sb_rextents) {
|
if (mp->m_sb.sb_rextents) {
|
||||||
cmn_err(CE_NOTE,
|
xfs_notice(mp, "Cannot turn on quotas for realtime filesystem");
|
||||||
"Cannot turn on quotas for realtime filesystem %s",
|
|
||||||
mp->m_fsname);
|
|
||||||
mp->m_qflags = 0;
|
mp->m_qflags = 0;
|
||||||
goto write_changes;
|
goto write_changes;
|
||||||
}
|
}
|
||||||
|
@ -1668,7 +1666,7 @@ xfs_qm_quotacheck(
|
||||||
*/
|
*/
|
||||||
ASSERT(list_empty(&mp->m_quotainfo->qi_dqlist));
|
ASSERT(list_empty(&mp->m_quotainfo->qi_dqlist));
|
||||||
|
|
||||||
cmn_err(CE_NOTE, "XFS quotacheck %s: Please wait.", mp->m_fsname);
|
xfs_notice(mp, "Quotacheck needed: Please wait.");
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* First we go thru all the dquots on disk, USR and GRP/PRJ, and reset
|
* First we go thru all the dquots on disk, USR and GRP/PRJ, and reset
|
||||||
|
@ -1746,9 +1744,9 @@ xfs_qm_quotacheck(
|
||||||
|
|
||||||
error_return:
|
error_return:
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN, "XFS quotacheck %s: Unsuccessful (Error %d): "
|
xfs_warn(mp,
|
||||||
"Disabling quotas.",
|
"Quotacheck: Unsuccessful (Error %d): Disabling quotas.",
|
||||||
mp->m_fsname, error);
|
error);
|
||||||
/*
|
/*
|
||||||
* We must turn off quotas.
|
* We must turn off quotas.
|
||||||
*/
|
*/
|
||||||
|
@ -1756,12 +1754,11 @@ xfs_qm_quotacheck(
|
||||||
ASSERT(xfs_Gqm != NULL);
|
ASSERT(xfs_Gqm != NULL);
|
||||||
xfs_qm_destroy_quotainfo(mp);
|
xfs_qm_destroy_quotainfo(mp);
|
||||||
if (xfs_mount_reset_sbqflags(mp)) {
|
if (xfs_mount_reset_sbqflags(mp)) {
|
||||||
cmn_err(CE_WARN, "XFS quotacheck %s: "
|
xfs_warn(mp,
|
||||||
"Failed to reset quota flags.", mp->m_fsname);
|
"Quotacheck: Failed to reset quota flags.");
|
||||||
}
|
}
|
||||||
} else {
|
} else
|
||||||
cmn_err(CE_NOTE, "XFS quotacheck %s: Done.", mp->m_fsname);
|
xfs_notice(mp, "Quotacheck: Done.");
|
||||||
}
|
|
||||||
return (error);
|
return (error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2107,7 +2104,7 @@ xfs_qm_write_sb_changes(
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
#ifdef QUOTADEBUG
|
#ifdef QUOTADEBUG
|
||||||
cmn_err(CE_NOTE, "Writing superblock quota changes :%s", mp->m_fsname);
|
xfs_notice(mp, "Writing superblock quota changes");
|
||||||
#endif
|
#endif
|
||||||
tp = xfs_trans_alloc(mp, XFS_TRANS_QM_SBCHANGE);
|
tp = xfs_trans_alloc(mp, XFS_TRANS_QM_SBCHANGE);
|
||||||
if ((error = xfs_trans_reserve(tp, 0,
|
if ((error = xfs_trans_reserve(tp, 0,
|
||||||
|
|
|
@ -119,8 +119,7 @@ xfs_qm_newmount(
|
||||||
(gquotaondisk && !XFS_IS_GQUOTA_ON(mp)) ||
|
(gquotaondisk && !XFS_IS_GQUOTA_ON(mp)) ||
|
||||||
(!gquotaondisk && XFS_IS_OQUOTA_ON(mp))) &&
|
(!gquotaondisk && XFS_IS_OQUOTA_ON(mp))) &&
|
||||||
xfs_dev_is_read_only(mp, "changing quota state")) {
|
xfs_dev_is_read_only(mp, "changing quota state")) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "please mount with%s%s%s%s.",
|
||||||
"XFS: please mount with%s%s%s%s.",
|
|
||||||
(!quotaondisk ? "out quota" : ""),
|
(!quotaondisk ? "out quota" : ""),
|
||||||
(uquotaondisk ? " usrquota" : ""),
|
(uquotaondisk ? " usrquota" : ""),
|
||||||
(pquotaondisk ? " prjquota" : ""),
|
(pquotaondisk ? " prjquota" : ""),
|
||||||
|
|
|
@ -936,10 +936,11 @@ struct mutex qcheck_lock;
|
||||||
#define DQTEST_LIST_PRINT(l, NXT, title) \
|
#define DQTEST_LIST_PRINT(l, NXT, title) \
|
||||||
{ \
|
{ \
|
||||||
xfs_dqtest_t *dqp; int i = 0;\
|
xfs_dqtest_t *dqp; int i = 0;\
|
||||||
cmn_err(CE_DEBUG, "%s (#%d)", title, (int) (l)->qh_nelems); \
|
xfs_debug(NULL, "%s (#%d)", title, (int) (l)->qh_nelems); \
|
||||||
for (dqp = (xfs_dqtest_t *)(l)->qh_next; dqp != NULL; \
|
for (dqp = (xfs_dqtest_t *)(l)->qh_next; dqp != NULL; \
|
||||||
dqp = (xfs_dqtest_t *)dqp->NXT) { \
|
dqp = (xfs_dqtest_t *)dqp->NXT) { \
|
||||||
cmn_err(CE_DEBUG, " %d. \"%d (%s)\" bcnt = %d, icnt = %d", \
|
xfs_debug(dqp->q_mount, \
|
||||||
|
" %d. \"%d (%s)\" bcnt = %d, icnt = %d", \
|
||||||
++i, dqp->d_id, DQFLAGTO_TYPESTR(dqp), \
|
++i, dqp->d_id, DQFLAGTO_TYPESTR(dqp), \
|
||||||
dqp->d_bcount, dqp->d_icount); } \
|
dqp->d_bcount, dqp->d_icount); } \
|
||||||
}
|
}
|
||||||
|
@ -963,16 +964,17 @@ xfs_qm_hashinsert(xfs_dqhash_t *h, xfs_dqtest_t *dqp)
|
||||||
}
|
}
|
||||||
STATIC void
|
STATIC void
|
||||||
xfs_qm_dqtest_print(
|
xfs_qm_dqtest_print(
|
||||||
xfs_dqtest_t *d)
|
struct xfs_mount *mp,
|
||||||
|
struct dqtest *d)
|
||||||
{
|
{
|
||||||
cmn_err(CE_DEBUG, "-----------DQTEST DQUOT----------------");
|
xfs_debug(mp, "-----------DQTEST DQUOT----------------");
|
||||||
cmn_err(CE_DEBUG, "---- dquot ID = %d", d->d_id);
|
xfs_debug(mp, "---- dquot ID = %d", d->d_id);
|
||||||
cmn_err(CE_DEBUG, "---- fs = 0x%p", d->q_mount);
|
xfs_debug(mp, "---- fs = 0x%p", d->q_mount);
|
||||||
cmn_err(CE_DEBUG, "---- bcount = %Lu (0x%x)",
|
xfs_debug(mp, "---- bcount = %Lu (0x%x)",
|
||||||
d->d_bcount, (int)d->d_bcount);
|
d->d_bcount, (int)d->d_bcount);
|
||||||
cmn_err(CE_DEBUG, "---- icount = %Lu (0x%x)",
|
xfs_debug(mp, "---- icount = %Lu (0x%x)",
|
||||||
d->d_icount, (int)d->d_icount);
|
d->d_icount, (int)d->d_icount);
|
||||||
cmn_err(CE_DEBUG, "---------------------------");
|
xfs_debug(mp, "---------------------------");
|
||||||
}
|
}
|
||||||
|
|
||||||
STATIC void
|
STATIC void
|
||||||
|
@ -986,12 +988,14 @@ xfs_qm_dqtest_failed(
|
||||||
{
|
{
|
||||||
qmtest_nfails++;
|
qmtest_nfails++;
|
||||||
if (error)
|
if (error)
|
||||||
cmn_err(CE_DEBUG, "quotacheck failed id=%d, err=%d\nreason: %s",
|
xfs_debug(dqp->q_mount,
|
||||||
d->d_id, error, reason);
|
"quotacheck failed id=%d, err=%d\nreason: %s",
|
||||||
|
d->d_id, error, reason);
|
||||||
else
|
else
|
||||||
cmn_err(CE_DEBUG, "quotacheck failed id=%d (%s) [%d != %d]",
|
xfs_debug(dqp->q_mount,
|
||||||
d->d_id, reason, (int)a, (int)b);
|
"quotacheck failed id=%d (%s) [%d != %d]",
|
||||||
xfs_qm_dqtest_print(d);
|
d->d_id, reason, (int)a, (int)b);
|
||||||
|
xfs_qm_dqtest_print(dqp->q_mount, d);
|
||||||
if (dqp)
|
if (dqp)
|
||||||
xfs_qm_dqprint(dqp);
|
xfs_qm_dqprint(dqp);
|
||||||
}
|
}
|
||||||
|
@ -1018,9 +1022,9 @@ xfs_dqtest_cmp2(
|
||||||
be64_to_cpu(dqp->q_core.d_bcount) >=
|
be64_to_cpu(dqp->q_core.d_bcount) >=
|
||||||
be64_to_cpu(dqp->q_core.d_blk_softlimit)) {
|
be64_to_cpu(dqp->q_core.d_blk_softlimit)) {
|
||||||
if (!dqp->q_core.d_btimer && dqp->q_core.d_id) {
|
if (!dqp->q_core.d_btimer && dqp->q_core.d_id) {
|
||||||
cmn_err(CE_DEBUG,
|
xfs_debug(dqp->q_mount,
|
||||||
"%d [%s] [0x%p] BLK TIMER NOT STARTED",
|
"%d [%s] BLK TIMER NOT STARTED",
|
||||||
d->d_id, DQFLAGTO_TYPESTR(d), d->q_mount);
|
d->d_id, DQFLAGTO_TYPESTR(d));
|
||||||
err++;
|
err++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1028,16 +1032,16 @@ xfs_dqtest_cmp2(
|
||||||
be64_to_cpu(dqp->q_core.d_icount) >=
|
be64_to_cpu(dqp->q_core.d_icount) >=
|
||||||
be64_to_cpu(dqp->q_core.d_ino_softlimit)) {
|
be64_to_cpu(dqp->q_core.d_ino_softlimit)) {
|
||||||
if (!dqp->q_core.d_itimer && dqp->q_core.d_id) {
|
if (!dqp->q_core.d_itimer && dqp->q_core.d_id) {
|
||||||
cmn_err(CE_DEBUG,
|
xfs_debug(dqp->q_mount,
|
||||||
"%d [%s] [0x%p] INO TIMER NOT STARTED",
|
"%d [%s] INO TIMER NOT STARTED",
|
||||||
d->d_id, DQFLAGTO_TYPESTR(d), d->q_mount);
|
d->d_id, DQFLAGTO_TYPESTR(d));
|
||||||
err++;
|
err++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#ifdef QUOTADEBUG
|
#ifdef QUOTADEBUG
|
||||||
if (!err) {
|
if (!err) {
|
||||||
cmn_err(CE_DEBUG, "%d [%s] [0x%p] qchecked",
|
xfs_debug(dqp->q_mount, "%d [%s] qchecked",
|
||||||
d->d_id, DQFLAGTO_TYPESTR(d), d->q_mount);
|
d->d_id, DQFLAGTO_TYPESTR(d));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return (err);
|
return (err);
|
||||||
|
@ -1220,12 +1224,12 @@ xfs_qm_internalqcheck(
|
||||||
xfs_qm_internalqcheck_adjust,
|
xfs_qm_internalqcheck_adjust,
|
||||||
0, NULL, &done);
|
0, NULL, &done);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_DEBUG, "Bulkstat returned error 0x%x", error);
|
xfs_debug(mp, "Bulkstat returned error 0x%x", error);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} while (!done);
|
} while (!done);
|
||||||
|
|
||||||
cmn_err(CE_DEBUG, "Checking results against system dquots");
|
xfs_debug(mp, "Checking results against system dquots");
|
||||||
for (i = 0; i < qmtest_hashmask; i++) {
|
for (i = 0; i < qmtest_hashmask; i++) {
|
||||||
xfs_dqtest_t *d, *n;
|
xfs_dqtest_t *d, *n;
|
||||||
xfs_dqhash_t *h;
|
xfs_dqhash_t *h;
|
||||||
|
@ -1243,10 +1247,10 @@ xfs_qm_internalqcheck(
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qmtest_nfails) {
|
if (qmtest_nfails) {
|
||||||
cmn_err(CE_DEBUG, "******** quotacheck failed ********");
|
xfs_debug(mp, "******** quotacheck failed ********");
|
||||||
cmn_err(CE_DEBUG, "failures = %d", qmtest_nfails);
|
xfs_debug(mp, "failures = %d", qmtest_nfails);
|
||||||
} else {
|
} else {
|
||||||
cmn_err(CE_DEBUG, "******** quotacheck successful! ********");
|
xfs_debug(mp, "******** quotacheck successful! ********");
|
||||||
}
|
}
|
||||||
kmem_free(qmtest_udqtab);
|
kmem_free(qmtest_udqtab);
|
||||||
kmem_free(qmtest_gdqtab);
|
kmem_free(qmtest_gdqtab);
|
||||||
|
|
|
@ -643,8 +643,9 @@ xfs_trans_dqresv(
|
||||||
(XFS_IS_OQUOTA_ENFORCED(dqp->q_mount) &&
|
(XFS_IS_OQUOTA_ENFORCED(dqp->q_mount) &&
|
||||||
(XFS_QM_ISPDQ(dqp) || XFS_QM_ISGDQ(dqp))))) {
|
(XFS_QM_ISPDQ(dqp) || XFS_QM_ISGDQ(dqp))))) {
|
||||||
#ifdef QUOTADEBUG
|
#ifdef QUOTADEBUG
|
||||||
cmn_err(CE_DEBUG, "BLK Res: nblks=%ld + resbcount=%Ld"
|
xfs_debug(mp,
|
||||||
" > hardlimit=%Ld?", nblks, *resbcountp, hardlimit);
|
"BLK Res: nblks=%ld + resbcount=%Ld > hardlimit=%Ld?",
|
||||||
|
nblks, *resbcountp, hardlimit);
|
||||||
#endif
|
#endif
|
||||||
if (nblks > 0) {
|
if (nblks > 0) {
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -18,32 +18,6 @@
|
||||||
#include <xfs.h>
|
#include <xfs.h>
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
/* xfs_mount.h drags a lot of crap in, sorry.. */
|
|
||||||
#include "xfs_sb.h"
|
|
||||||
#include "xfs_inum.h"
|
|
||||||
#include "xfs_ag.h"
|
|
||||||
#include "xfs_mount.h"
|
|
||||||
#include "xfs_error.h"
|
|
||||||
|
|
||||||
void
|
|
||||||
cmn_err(
|
|
||||||
const char *lvl,
|
|
||||||
const char *fmt,
|
|
||||||
...)
|
|
||||||
{
|
|
||||||
struct va_format vaf;
|
|
||||||
va_list args;
|
|
||||||
|
|
||||||
va_start(args, fmt);
|
|
||||||
vaf.fmt = fmt;
|
|
||||||
vaf.va = &args;
|
|
||||||
|
|
||||||
printk("%s%pV", lvl, &vaf);
|
|
||||||
va_end(args);
|
|
||||||
|
|
||||||
BUG_ON(strncmp(lvl, KERN_EMERG, strlen(KERN_EMERG)) == 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
assfail(char *expr, char *file, int line)
|
assfail(char *expr, char *file, int line)
|
||||||
{
|
{
|
||||||
|
|
|
@ -20,18 +20,6 @@
|
||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
struct xfs_mount;
|
|
||||||
|
|
||||||
#define CE_DEBUG KERN_DEBUG
|
|
||||||
#define CE_CONT KERN_INFO
|
|
||||||
#define CE_NOTE KERN_NOTICE
|
|
||||||
#define CE_WARN KERN_WARNING
|
|
||||||
#define CE_ALERT KERN_ALERT
|
|
||||||
#define CE_PANIC KERN_EMERG
|
|
||||||
|
|
||||||
void cmn_err(const char *lvl, const char *fmt, ...)
|
|
||||||
__attribute__ ((format (printf, 2, 3)));
|
|
||||||
|
|
||||||
extern void assfail(char *expr, char *f, int l);
|
extern void assfail(char *expr, char *f, int l);
|
||||||
|
|
||||||
#define ASSERT_ALWAYS(expr) \
|
#define ASSERT_ALWAYS(expr) \
|
||||||
|
|
|
@ -5778,7 +5778,7 @@ xfs_check_block(
|
||||||
else
|
else
|
||||||
thispa = XFS_BMBT_PTR_ADDR(mp, block, j, dmxr);
|
thispa = XFS_BMBT_PTR_ADDR(mp, block, j, dmxr);
|
||||||
if (*thispa == *pp) {
|
if (*thispa == *pp) {
|
||||||
cmn_err(CE_WARN, "%s: thispa(%d) == pp(%d) %Ld",
|
xfs_warn(mp, "%s: thispa(%d) == pp(%d) %Ld",
|
||||||
__func__, j, i,
|
__func__, j, i,
|
||||||
(unsigned long long)be64_to_cpu(*thispa));
|
(unsigned long long)be64_to_cpu(*thispa));
|
||||||
panic("%s: ptrs are equal in node\n",
|
panic("%s: ptrs are equal in node\n",
|
||||||
|
@ -5943,11 +5943,11 @@ xfs_bmap_check_leaf_extents(
|
||||||
return;
|
return;
|
||||||
|
|
||||||
error0:
|
error0:
|
||||||
cmn_err(CE_WARN, "%s: at error0", __func__);
|
xfs_warn(mp, "%s: at error0", __func__);
|
||||||
if (bp_release)
|
if (bp_release)
|
||||||
xfs_trans_brelse(NULL, bp);
|
xfs_trans_brelse(NULL, bp);
|
||||||
error_norelse:
|
error_norelse:
|
||||||
cmn_err(CE_WARN, "%s: BAD after btree leaves for %d extents",
|
xfs_warn(mp, "%s: BAD after btree leaves for %d extents",
|
||||||
__func__, i);
|
__func__, i);
|
||||||
panic("%s: CORRUPTED BTREE OR SOMETHING", __func__);
|
panic("%s: CORRUPTED BTREE OR SOMETHING", __func__);
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -130,10 +130,12 @@ xfs_buf_item_log_check(
|
||||||
orig = bip->bli_orig;
|
orig = bip->bli_orig;
|
||||||
buffer = XFS_BUF_PTR(bp);
|
buffer = XFS_BUF_PTR(bp);
|
||||||
for (x = 0; x < XFS_BUF_COUNT(bp); x++) {
|
for (x = 0; x < XFS_BUF_COUNT(bp); x++) {
|
||||||
if (orig[x] != buffer[x] && !btst(bip->bli_logged, x))
|
if (orig[x] != buffer[x] && !btst(bip->bli_logged, x)) {
|
||||||
cmn_err(CE_PANIC,
|
xfs_emerg(bp->b_mount,
|
||||||
"xfs_buf_item_log_check bip %x buffer %x orig %x index %d",
|
"%s: bip %x buffer %x orig %x index %d",
|
||||||
bip, bp, orig, x);
|
__func__, bip, bp, orig, x);
|
||||||
|
ASSERT(0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
@ -983,10 +985,9 @@ xfs_buf_iodone_callbacks(
|
||||||
if (XFS_BUF_TARGET(bp) != lasttarg ||
|
if (XFS_BUF_TARGET(bp) != lasttarg ||
|
||||||
time_after(jiffies, (lasttime + 5*HZ))) {
|
time_after(jiffies, (lasttime + 5*HZ))) {
|
||||||
lasttime = jiffies;
|
lasttime = jiffies;
|
||||||
cmn_err(CE_ALERT, "Device %s, XFS metadata write error"
|
xfs_alert(mp, "Device %s: metadata write error block 0x%llx",
|
||||||
" block 0x%llx in %s",
|
|
||||||
XFS_BUFTARG_NAME(XFS_BUF_TARGET(bp)),
|
XFS_BUFTARG_NAME(XFS_BUF_TARGET(bp)),
|
||||||
(__uint64_t)XFS_BUF_ADDR(bp), mp->m_fsname);
|
(__uint64_t)XFS_BUF_ADDR(bp));
|
||||||
}
|
}
|
||||||
lasttarg = XFS_BUF_TARGET(bp);
|
lasttarg = XFS_BUF_TARGET(bp);
|
||||||
|
|
||||||
|
|
|
@ -1995,13 +1995,12 @@ xfs_da_do_buf(
|
||||||
error = mappedbno == -2 ? 0 : XFS_ERROR(EFSCORRUPTED);
|
error = mappedbno == -2 ? 0 : XFS_ERROR(EFSCORRUPTED);
|
||||||
if (unlikely(error == EFSCORRUPTED)) {
|
if (unlikely(error == EFSCORRUPTED)) {
|
||||||
if (xfs_error_level >= XFS_ERRLEVEL_LOW) {
|
if (xfs_error_level >= XFS_ERRLEVEL_LOW) {
|
||||||
cmn_err(CE_ALERT, "xfs_da_do_buf: bno %lld\n",
|
xfs_alert(mp, "%s: bno %lld dir: inode %lld",
|
||||||
(long long)bno);
|
__func__, (long long)bno,
|
||||||
cmn_err(CE_ALERT, "dir: inode %lld\n",
|
|
||||||
(long long)dp->i_ino);
|
(long long)dp->i_ino);
|
||||||
for (i = 0; i < nmap; i++) {
|
for (i = 0; i < nmap; i++) {
|
||||||
cmn_err(CE_ALERT,
|
xfs_alert(mp,
|
||||||
"[%02d] br_startoff %lld br_startblock %lld br_blockcount %lld br_state %d\n",
|
"[%02d] br_startoff %lld br_startblock %lld br_blockcount %lld br_state %d",
|
||||||
i,
|
i,
|
||||||
(long long)mapp[i].br_startoff,
|
(long long)mapp[i].br_startoff,
|
||||||
(long long)mapp[i].br_startblock,
|
(long long)mapp[i].br_startblock,
|
||||||
|
|
|
@ -899,10 +899,9 @@ xfs_dir2_leafn_rebalance(
|
||||||
if(blk2->index < 0) {
|
if(blk2->index < 0) {
|
||||||
state->inleaf = 1;
|
state->inleaf = 1;
|
||||||
blk2->index = 0;
|
blk2->index = 0;
|
||||||
cmn_err(CE_ALERT,
|
xfs_alert(args->dp->i_mount,
|
||||||
"xfs_dir2_leafn_rebalance: picked the wrong leaf? reverting original leaf: "
|
"%s: picked the wrong leaf? reverting original leaf: blk1->index %d\n",
|
||||||
"blk1->index %d\n",
|
__func__, blk1->index);
|
||||||
blk1->index);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1641,26 +1640,22 @@ xfs_dir2_node_addname_int(
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unlikely(xfs_dir2_db_to_fdb(mp, dbno) != fbno)) {
|
if (unlikely(xfs_dir2_db_to_fdb(mp, dbno) != fbno)) {
|
||||||
cmn_err(CE_ALERT,
|
xfs_alert(mp,
|
||||||
"xfs_dir2_node_addname_int: dir ino "
|
"%s: dir ino " "%llu needed freesp block %lld for\n"
|
||||||
"%llu needed freesp block %lld for\n"
|
" data block %lld, got %lld ifbno %llu lastfbno %d",
|
||||||
" data block %lld, got %lld\n"
|
__func__, (unsigned long long)dp->i_ino,
|
||||||
" ifbno %llu lastfbno %d\n",
|
|
||||||
(unsigned long long)dp->i_ino,
|
|
||||||
(long long)xfs_dir2_db_to_fdb(mp, dbno),
|
(long long)xfs_dir2_db_to_fdb(mp, dbno),
|
||||||
(long long)dbno, (long long)fbno,
|
(long long)dbno, (long long)fbno,
|
||||||
(unsigned long long)ifbno, lastfbno);
|
(unsigned long long)ifbno, lastfbno);
|
||||||
if (fblk) {
|
if (fblk) {
|
||||||
cmn_err(CE_ALERT,
|
xfs_alert(mp,
|
||||||
" fblk 0x%p blkno %llu "
|
" fblk 0x%p blkno %llu index %d magic 0x%x",
|
||||||
"index %d magic 0x%x\n",
|
|
||||||
fblk,
|
fblk,
|
||||||
(unsigned long long)fblk->blkno,
|
(unsigned long long)fblk->blkno,
|
||||||
fblk->index,
|
fblk->index,
|
||||||
fblk->magic);
|
fblk->magic);
|
||||||
} else {
|
} else {
|
||||||
cmn_err(CE_ALERT,
|
xfs_alert(mp, " ... fblk is NULL");
|
||||||
" ... fblk is NULL\n");
|
|
||||||
}
|
}
|
||||||
XFS_ERROR_REPORT("xfs_dir2_node_addname_int",
|
XFS_ERROR_REPORT("xfs_dir2_node_addname_int",
|
||||||
XFS_ERRLEVEL_LOW, mp);
|
XFS_ERRLEVEL_LOW, mp);
|
||||||
|
|
|
@ -48,7 +48,7 @@ xfs_error_trap(int e)
|
||||||
break;
|
break;
|
||||||
if (e != xfs_etrap[i])
|
if (e != xfs_etrap[i])
|
||||||
continue;
|
continue;
|
||||||
cmn_err(CE_NOTE, "xfs_error_trap: error %d", e);
|
xfs_notice(NULL, "%s: error %d", __func__, e);
|
||||||
BUG();
|
BUG();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -74,7 +74,7 @@ xfs_error_test(int error_tag, int *fsidp, char *expression,
|
||||||
|
|
||||||
for (i = 0; i < XFS_NUM_INJECT_ERROR; i++) {
|
for (i = 0; i < XFS_NUM_INJECT_ERROR; i++) {
|
||||||
if (xfs_etest[i] == error_tag && xfs_etest_fsid[i] == fsid) {
|
if (xfs_etest[i] == error_tag && xfs_etest_fsid[i] == fsid) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(NULL,
|
||||||
"Injecting error (%s) at file %s, line %d, on filesystem \"%s\"",
|
"Injecting error (%s) at file %s, line %d, on filesystem \"%s\"",
|
||||||
expression, file, line, xfs_etest_fsname[i]);
|
expression, file, line, xfs_etest_fsname[i]);
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -95,14 +95,14 @@ xfs_errortag_add(int error_tag, xfs_mount_t *mp)
|
||||||
|
|
||||||
for (i = 0; i < XFS_NUM_INJECT_ERROR; i++) {
|
for (i = 0; i < XFS_NUM_INJECT_ERROR; i++) {
|
||||||
if (xfs_etest_fsid[i] == fsid && xfs_etest[i] == error_tag) {
|
if (xfs_etest_fsid[i] == fsid && xfs_etest[i] == error_tag) {
|
||||||
cmn_err(CE_WARN, "XFS error tag #%d on", error_tag);
|
xfs_warn(mp, "error tag #%d on", error_tag);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < XFS_NUM_INJECT_ERROR; i++) {
|
for (i = 0; i < XFS_NUM_INJECT_ERROR; i++) {
|
||||||
if (xfs_etest[i] == 0) {
|
if (xfs_etest[i] == 0) {
|
||||||
cmn_err(CE_WARN, "Turned on XFS error tag #%d",
|
xfs_warn(mp, "Turned on XFS error tag #%d",
|
||||||
error_tag);
|
error_tag);
|
||||||
xfs_etest[i] = error_tag;
|
xfs_etest[i] = error_tag;
|
||||||
xfs_etest_fsid[i] = fsid;
|
xfs_etest_fsid[i] = fsid;
|
||||||
|
@ -114,7 +114,7 @@ xfs_errortag_add(int error_tag, xfs_mount_t *mp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cmn_err(CE_WARN, "error tag overflow, too many turned on");
|
xfs_warn(mp, "error tag overflow, too many turned on");
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -133,7 +133,7 @@ xfs_errortag_clearall(xfs_mount_t *mp, int loud)
|
||||||
if ((fsid == 0LL || xfs_etest_fsid[i] == fsid) &&
|
if ((fsid == 0LL || xfs_etest_fsid[i] == fsid) &&
|
||||||
xfs_etest[i] != 0) {
|
xfs_etest[i] != 0) {
|
||||||
cleared = 1;
|
cleared = 1;
|
||||||
cmn_err(CE_WARN, "Clearing XFS error tag #%d",
|
xfs_warn(mp, "Clearing XFS error tag #%d",
|
||||||
xfs_etest[i]);
|
xfs_etest[i]);
|
||||||
xfs_etest[i] = 0;
|
xfs_etest[i] = 0;
|
||||||
xfs_etest_fsid[i] = 0LL;
|
xfs_etest_fsid[i] = 0LL;
|
||||||
|
@ -144,9 +144,7 @@ xfs_errortag_clearall(xfs_mount_t *mp, int loud)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (loud || cleared)
|
if (loud || cleared)
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "Cleared all XFS error tags for filesystem");
|
||||||
"Cleared all XFS error tags for filesystem \"%s\"",
|
|
||||||
mp->m_fsname);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1055,28 +1055,23 @@ xfs_difree(
|
||||||
*/
|
*/
|
||||||
agno = XFS_INO_TO_AGNO(mp, inode);
|
agno = XFS_INO_TO_AGNO(mp, inode);
|
||||||
if (agno >= mp->m_sb.sb_agcount) {
|
if (agno >= mp->m_sb.sb_agcount) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "%s: agno >= mp->m_sb.sb_agcount (%d >= %d).",
|
||||||
"xfs_difree: agno >= mp->m_sb.sb_agcount (%d >= %d) on %s. Returning EINVAL.",
|
__func__, agno, mp->m_sb.sb_agcount);
|
||||||
agno, mp->m_sb.sb_agcount, mp->m_fsname);
|
|
||||||
ASSERT(0);
|
ASSERT(0);
|
||||||
return XFS_ERROR(EINVAL);
|
return XFS_ERROR(EINVAL);
|
||||||
}
|
}
|
||||||
agino = XFS_INO_TO_AGINO(mp, inode);
|
agino = XFS_INO_TO_AGINO(mp, inode);
|
||||||
if (inode != XFS_AGINO_TO_INO(mp, agno, agino)) {
|
if (inode != XFS_AGINO_TO_INO(mp, agno, agino)) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "%s: inode != XFS_AGINO_TO_INO() (%llu != %llu).",
|
||||||
"xfs_difree: inode != XFS_AGINO_TO_INO() "
|
__func__, (unsigned long long)inode,
|
||||||
"(%llu != %llu) on %s. Returning EINVAL.",
|
(unsigned long long)XFS_AGINO_TO_INO(mp, agno, agino));
|
||||||
(unsigned long long)inode,
|
|
||||||
(unsigned long long)XFS_AGINO_TO_INO(mp, agno, agino),
|
|
||||||
mp->m_fsname);
|
|
||||||
ASSERT(0);
|
ASSERT(0);
|
||||||
return XFS_ERROR(EINVAL);
|
return XFS_ERROR(EINVAL);
|
||||||
}
|
}
|
||||||
agbno = XFS_AGINO_TO_AGBNO(mp, agino);
|
agbno = XFS_AGINO_TO_AGBNO(mp, agino);
|
||||||
if (agbno >= mp->m_sb.sb_agblocks) {
|
if (agbno >= mp->m_sb.sb_agblocks) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "%s: agbno >= mp->m_sb.sb_agblocks (%d >= %d).",
|
||||||
"xfs_difree: agbno >= mp->m_sb.sb_agblocks (%d >= %d) on %s. Returning EINVAL.",
|
__func__, agbno, mp->m_sb.sb_agblocks);
|
||||||
agbno, mp->m_sb.sb_agblocks, mp->m_fsname);
|
|
||||||
ASSERT(0);
|
ASSERT(0);
|
||||||
return XFS_ERROR(EINVAL);
|
return XFS_ERROR(EINVAL);
|
||||||
}
|
}
|
||||||
|
@ -1085,9 +1080,8 @@ xfs_difree(
|
||||||
*/
|
*/
|
||||||
error = xfs_ialloc_read_agi(mp, tp, agno, &agbp);
|
error = xfs_ialloc_read_agi(mp, tp, agno, &agbp);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "%s: xfs_ialloc_read_agi() returned error %d.",
|
||||||
"xfs_difree: xfs_ialloc_read_agi() returned an error %d on %s. Returning error.",
|
__func__, error);
|
||||||
error, mp->m_fsname);
|
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
agi = XFS_BUF_TO_AGI(agbp);
|
agi = XFS_BUF_TO_AGI(agbp);
|
||||||
|
@ -1106,17 +1100,15 @@ xfs_difree(
|
||||||
* Look for the entry describing this inode.
|
* Look for the entry describing this inode.
|
||||||
*/
|
*/
|
||||||
if ((error = xfs_inobt_lookup(cur, agino, XFS_LOOKUP_LE, &i))) {
|
if ((error = xfs_inobt_lookup(cur, agino, XFS_LOOKUP_LE, &i))) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "%s: xfs_inobt_lookup() returned error %d.",
|
||||||
"xfs_difree: xfs_inobt_lookup returned() an error %d on %s. Returning error.",
|
__func__, error);
|
||||||
error, mp->m_fsname);
|
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
XFS_WANT_CORRUPTED_GOTO(i == 1, error0);
|
XFS_WANT_CORRUPTED_GOTO(i == 1, error0);
|
||||||
error = xfs_inobt_get_rec(cur, &rec, &i);
|
error = xfs_inobt_get_rec(cur, &rec, &i);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "%s: xfs_inobt_get_rec() returned error %d.",
|
||||||
"xfs_difree: xfs_inobt_get_rec() returned an error %d on %s. Returning error.",
|
__func__, error);
|
||||||
error, mp->m_fsname);
|
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
XFS_WANT_CORRUPTED_GOTO(i == 1, error0);
|
XFS_WANT_CORRUPTED_GOTO(i == 1, error0);
|
||||||
|
@ -1157,8 +1149,8 @@ xfs_difree(
|
||||||
xfs_trans_mod_sb(tp, XFS_TRANS_SB_IFREE, -(ilen - 1));
|
xfs_trans_mod_sb(tp, XFS_TRANS_SB_IFREE, -(ilen - 1));
|
||||||
|
|
||||||
if ((error = xfs_btree_delete(cur, &i))) {
|
if ((error = xfs_btree_delete(cur, &i))) {
|
||||||
cmn_err(CE_WARN, "xfs_difree: xfs_btree_delete returned an error %d on %s.\n",
|
xfs_warn(mp, "%s: xfs_btree_delete returned error %d.",
|
||||||
error, mp->m_fsname);
|
__func__, error);
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1170,9 +1162,8 @@ xfs_difree(
|
||||||
|
|
||||||
error = xfs_inobt_update(cur, &rec);
|
error = xfs_inobt_update(cur, &rec);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "%s: xfs_inobt_update returned error %d.",
|
||||||
"xfs_difree: xfs_inobt_update returned an error %d on %s.",
|
__func__, error);
|
||||||
error, mp->m_fsname);
|
|
||||||
goto error0;
|
goto error0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -142,10 +142,9 @@ xfs_imap_to_bp(
|
||||||
(int)imap->im_len, buf_flags, &bp);
|
(int)imap->im_len, buf_flags, &bp);
|
||||||
if (error) {
|
if (error) {
|
||||||
if (error != EAGAIN) {
|
if (error != EAGAIN) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp,
|
||||||
"xfs_imap_to_bp: xfs_trans_read_buf()returned "
|
"%s: xfs_trans_read_buf() returned error %d.",
|
||||||
"an error %d on %s. Returning error.",
|
__func__, error);
|
||||||
error, mp->m_fsname);
|
|
||||||
} else {
|
} else {
|
||||||
ASSERT(buf_flags & XBF_TRYLOCK);
|
ASSERT(buf_flags & XBF_TRYLOCK);
|
||||||
}
|
}
|
||||||
|
@ -180,12 +179,11 @@ xfs_imap_to_bp(
|
||||||
XFS_CORRUPTION_ERROR("xfs_imap_to_bp",
|
XFS_CORRUPTION_ERROR("xfs_imap_to_bp",
|
||||||
XFS_ERRLEVEL_HIGH, mp, dip);
|
XFS_ERRLEVEL_HIGH, mp, dip);
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
cmn_err(CE_PANIC,
|
xfs_emerg(mp,
|
||||||
"Device %s - bad inode magic/vsn "
|
"bad inode magic/vsn daddr %lld #%d (magic=%x)",
|
||||||
"daddr %lld #%d (magic=%x)",
|
|
||||||
XFS_BUFTARG_NAME(mp->m_ddev_targp),
|
|
||||||
(unsigned long long)imap->im_blkno, i,
|
(unsigned long long)imap->im_blkno, i,
|
||||||
be16_to_cpu(dip->di_magic));
|
be16_to_cpu(dip->di_magic));
|
||||||
|
ASSERT(0);
|
||||||
#endif
|
#endif
|
||||||
xfs_trans_brelse(tp, bp);
|
xfs_trans_brelse(tp, bp);
|
||||||
return XFS_ERROR(EFSCORRUPTED);
|
return XFS_ERROR(EFSCORRUPTED);
|
||||||
|
@ -1811,9 +1809,8 @@ xfs_iunlink_remove(
|
||||||
*/
|
*/
|
||||||
error = xfs_itobp(mp, tp, ip, &dip, &ibp, XBF_LOCK);
|
error = xfs_itobp(mp, tp, ip, &dip, &ibp, XBF_LOCK);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "%s: xfs_itobp() returned error %d.",
|
||||||
"xfs_iunlink_remove: xfs_itobp() returned an error %d on %s. Returning error.",
|
__func__, error);
|
||||||
error, mp->m_fsname);
|
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
next_agino = be32_to_cpu(dip->di_next_unlinked);
|
next_agino = be32_to_cpu(dip->di_next_unlinked);
|
||||||
|
@ -1858,9 +1855,9 @@ xfs_iunlink_remove(
|
||||||
error = xfs_inotobp(mp, tp, next_ino, &last_dip,
|
error = xfs_inotobp(mp, tp, next_ino, &last_dip,
|
||||||
&last_ibp, &last_offset, 0);
|
&last_ibp, &last_offset, 0);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp,
|
||||||
"xfs_iunlink_remove: xfs_inotobp() returned an error %d on %s. Returning error.",
|
"%s: xfs_inotobp() returned error %d.",
|
||||||
error, mp->m_fsname);
|
__func__, error);
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
next_agino = be32_to_cpu(last_dip->di_next_unlinked);
|
next_agino = be32_to_cpu(last_dip->di_next_unlinked);
|
||||||
|
@ -1873,9 +1870,8 @@ xfs_iunlink_remove(
|
||||||
*/
|
*/
|
||||||
error = xfs_itobp(mp, tp, ip, &dip, &ibp, XBF_LOCK);
|
error = xfs_itobp(mp, tp, ip, &dip, &ibp, XBF_LOCK);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "%s: xfs_itobp(2) returned error %d.",
|
||||||
"xfs_iunlink_remove: xfs_itobp() returned an error %d on %s. Returning error.",
|
__func__, error);
|
||||||
error, mp->m_fsname);
|
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
next_agino = be32_to_cpu(dip->di_next_unlinked);
|
next_agino = be32_to_cpu(dip->di_next_unlinked);
|
||||||
|
|
|
@ -133,9 +133,7 @@ xfs_uuid_mount(
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (uuid_is_nil(uuid)) {
|
if (uuid_is_nil(uuid)) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "Filesystem has nil UUID - can't mount");
|
||||||
"XFS: Filesystem %s has nil UUID - can't mount",
|
|
||||||
mp->m_fsname);
|
|
||||||
return XFS_ERROR(EINVAL);
|
return XFS_ERROR(EINVAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -163,8 +161,7 @@ xfs_uuid_mount(
|
||||||
|
|
||||||
out_duplicate:
|
out_duplicate:
|
||||||
mutex_unlock(&xfs_uuid_table_mutex);
|
mutex_unlock(&xfs_uuid_table_mutex);
|
||||||
cmn_err(CE_WARN, "XFS: Filesystem %s has duplicate UUID - can't mount",
|
xfs_warn(mp, "Filesystem has duplicate UUID - can't mount");
|
||||||
mp->m_fsname);
|
|
||||||
return XFS_ERROR(EINVAL);
|
return XFS_ERROR(EINVAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -867,8 +864,7 @@ xfs_update_alignment(xfs_mount_t *mp)
|
||||||
if ((BBTOB(mp->m_dalign) & mp->m_blockmask) ||
|
if ((BBTOB(mp->m_dalign) & mp->m_blockmask) ||
|
||||||
(BBTOB(mp->m_swidth) & mp->m_blockmask)) {
|
(BBTOB(mp->m_swidth) & mp->m_blockmask)) {
|
||||||
if (mp->m_flags & XFS_MOUNT_RETERR) {
|
if (mp->m_flags & XFS_MOUNT_RETERR) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "alignment check 1 failed");
|
||||||
"XFS: alignment check 1 failed");
|
|
||||||
return XFS_ERROR(EINVAL);
|
return XFS_ERROR(EINVAL);
|
||||||
}
|
}
|
||||||
mp->m_dalign = mp->m_swidth = 0;
|
mp->m_dalign = mp->m_swidth = 0;
|
||||||
|
@ -1041,14 +1037,14 @@ xfs_check_sizes(xfs_mount_t *mp)
|
||||||
|
|
||||||
d = (xfs_daddr_t)XFS_FSB_TO_BB(mp, mp->m_sb.sb_dblocks);
|
d = (xfs_daddr_t)XFS_FSB_TO_BB(mp, mp->m_sb.sb_dblocks);
|
||||||
if (XFS_BB_TO_FSB(mp, d) != mp->m_sb.sb_dblocks) {
|
if (XFS_BB_TO_FSB(mp, d) != mp->m_sb.sb_dblocks) {
|
||||||
cmn_err(CE_WARN, "XFS: filesystem size mismatch detected");
|
xfs_warn(mp, "filesystem size mismatch detected");
|
||||||
return XFS_ERROR(EFBIG);
|
return XFS_ERROR(EFBIG);
|
||||||
}
|
}
|
||||||
bp = xfs_buf_read_uncached(mp, mp->m_ddev_targp,
|
bp = xfs_buf_read_uncached(mp, mp->m_ddev_targp,
|
||||||
d - XFS_FSS_TO_BB(mp, 1),
|
d - XFS_FSS_TO_BB(mp, 1),
|
||||||
BBTOB(XFS_FSS_TO_BB(mp, 1)), 0);
|
BBTOB(XFS_FSS_TO_BB(mp, 1)), 0);
|
||||||
if (!bp) {
|
if (!bp) {
|
||||||
cmn_err(CE_WARN, "XFS: last sector read failed");
|
xfs_warn(mp, "last sector read failed");
|
||||||
return EIO;
|
return EIO;
|
||||||
}
|
}
|
||||||
xfs_buf_relse(bp);
|
xfs_buf_relse(bp);
|
||||||
|
@ -1056,14 +1052,14 @@ xfs_check_sizes(xfs_mount_t *mp)
|
||||||
if (mp->m_logdev_targp != mp->m_ddev_targp) {
|
if (mp->m_logdev_targp != mp->m_ddev_targp) {
|
||||||
d = (xfs_daddr_t)XFS_FSB_TO_BB(mp, mp->m_sb.sb_logblocks);
|
d = (xfs_daddr_t)XFS_FSB_TO_BB(mp, mp->m_sb.sb_logblocks);
|
||||||
if (XFS_BB_TO_FSB(mp, d) != mp->m_sb.sb_logblocks) {
|
if (XFS_BB_TO_FSB(mp, d) != mp->m_sb.sb_logblocks) {
|
||||||
cmn_err(CE_WARN, "XFS: log size mismatch detected");
|
xfs_warn(mp, "log size mismatch detected");
|
||||||
return XFS_ERROR(EFBIG);
|
return XFS_ERROR(EFBIG);
|
||||||
}
|
}
|
||||||
bp = xfs_buf_read_uncached(mp, mp->m_logdev_targp,
|
bp = xfs_buf_read_uncached(mp, mp->m_logdev_targp,
|
||||||
d - XFS_FSB_TO_BB(mp, 1),
|
d - XFS_FSB_TO_BB(mp, 1),
|
||||||
XFS_FSB_TO_B(mp, 1), 0);
|
XFS_FSB_TO_B(mp, 1), 0);
|
||||||
if (!bp) {
|
if (!bp) {
|
||||||
cmn_err(CE_WARN, "XFS: log device read failed");
|
xfs_warn(mp, "log device read failed");
|
||||||
return EIO;
|
return EIO;
|
||||||
}
|
}
|
||||||
xfs_buf_relse(bp);
|
xfs_buf_relse(bp);
|
||||||
|
@ -1175,8 +1171,7 @@ xfs_mountfs(
|
||||||
* transaction subsystem is online.
|
* transaction subsystem is online.
|
||||||
*/
|
*/
|
||||||
if (xfs_sb_has_mismatched_features2(sbp)) {
|
if (xfs_sb_has_mismatched_features2(sbp)) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp, "correcting sb_features alignment problem");
|
||||||
"XFS: correcting sb_features alignment problem");
|
|
||||||
sbp->sb_features2 |= sbp->sb_bad_features2;
|
sbp->sb_features2 |= sbp->sb_bad_features2;
|
||||||
sbp->sb_bad_features2 = sbp->sb_features2;
|
sbp->sb_bad_features2 = sbp->sb_features2;
|
||||||
mp->m_update_flags |= XFS_SB_FEATURES2 | XFS_SB_BAD_FEATURES2;
|
mp->m_update_flags |= XFS_SB_FEATURES2 | XFS_SB_BAD_FEATURES2;
|
||||||
|
@ -1255,7 +1250,7 @@ xfs_mountfs(
|
||||||
*/
|
*/
|
||||||
error = xfs_rtmount_init(mp);
|
error = xfs_rtmount_init(mp);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN, "XFS: RT mount failed");
|
xfs_warn(mp, "RT mount failed");
|
||||||
goto out_remove_uuid;
|
goto out_remove_uuid;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1286,12 +1281,12 @@ xfs_mountfs(
|
||||||
INIT_RADIX_TREE(&mp->m_perag_tree, GFP_ATOMIC);
|
INIT_RADIX_TREE(&mp->m_perag_tree, GFP_ATOMIC);
|
||||||
error = xfs_initialize_perag(mp, sbp->sb_agcount, &mp->m_maxagi);
|
error = xfs_initialize_perag(mp, sbp->sb_agcount, &mp->m_maxagi);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN, "XFS: Failed per-ag init: %d", error);
|
xfs_warn(mp, "Failed per-ag init: %d", error);
|
||||||
goto out_remove_uuid;
|
goto out_remove_uuid;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!sbp->sb_logblocks) {
|
if (!sbp->sb_logblocks) {
|
||||||
cmn_err(CE_WARN, "XFS: no log defined");
|
xfs_warn(mp, "no log defined");
|
||||||
XFS_ERROR_REPORT("xfs_mountfs", XFS_ERRLEVEL_LOW, mp);
|
XFS_ERROR_REPORT("xfs_mountfs", XFS_ERRLEVEL_LOW, mp);
|
||||||
error = XFS_ERROR(EFSCORRUPTED);
|
error = XFS_ERROR(EFSCORRUPTED);
|
||||||
goto out_free_perag;
|
goto out_free_perag;
|
||||||
|
@ -1304,7 +1299,7 @@ xfs_mountfs(
|
||||||
XFS_FSB_TO_DADDR(mp, sbp->sb_logstart),
|
XFS_FSB_TO_DADDR(mp, sbp->sb_logstart),
|
||||||
XFS_FSB_TO_BB(mp, sbp->sb_logblocks));
|
XFS_FSB_TO_BB(mp, sbp->sb_logblocks));
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN, "XFS: log mount failed");
|
xfs_warn(mp, "log mount failed");
|
||||||
goto out_free_perag;
|
goto out_free_perag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1341,16 +1336,14 @@ xfs_mountfs(
|
||||||
*/
|
*/
|
||||||
error = xfs_iget(mp, NULL, sbp->sb_rootino, 0, XFS_ILOCK_EXCL, &rip);
|
error = xfs_iget(mp, NULL, sbp->sb_rootino, 0, XFS_ILOCK_EXCL, &rip);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN, "XFS: failed to read root inode");
|
xfs_warn(mp, "failed to read root inode");
|
||||||
goto out_log_dealloc;
|
goto out_log_dealloc;
|
||||||
}
|
}
|
||||||
|
|
||||||
ASSERT(rip != NULL);
|
ASSERT(rip != NULL);
|
||||||
|
|
||||||
if (unlikely((rip->i_d.di_mode & S_IFMT) != S_IFDIR)) {
|
if (unlikely((rip->i_d.di_mode & S_IFMT) != S_IFDIR)) {
|
||||||
cmn_err(CE_WARN, "XFS: corrupted root inode");
|
xfs_warn(mp, "corrupted root inode %llu: not a directory",
|
||||||
cmn_err(CE_WARN, "Device %s - root %llu is not a directory",
|
|
||||||
XFS_BUFTARG_NAME(mp->m_ddev_targp),
|
|
||||||
(unsigned long long)rip->i_ino);
|
(unsigned long long)rip->i_ino);
|
||||||
xfs_iunlock(rip, XFS_ILOCK_EXCL);
|
xfs_iunlock(rip, XFS_ILOCK_EXCL);
|
||||||
XFS_ERROR_REPORT("xfs_mountfs_int(2)", XFS_ERRLEVEL_LOW,
|
XFS_ERROR_REPORT("xfs_mountfs_int(2)", XFS_ERRLEVEL_LOW,
|
||||||
|
@ -1370,7 +1363,7 @@ xfs_mountfs(
|
||||||
/*
|
/*
|
||||||
* Free up the root inode.
|
* Free up the root inode.
|
||||||
*/
|
*/
|
||||||
cmn_err(CE_WARN, "XFS: failed to read RT inodes");
|
xfs_warn(mp, "failed to read RT inodes");
|
||||||
goto out_rele_rip;
|
goto out_rele_rip;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1382,7 +1375,7 @@ xfs_mountfs(
|
||||||
if (mp->m_update_flags && !(mp->m_flags & XFS_MOUNT_RDONLY)) {
|
if (mp->m_update_flags && !(mp->m_flags & XFS_MOUNT_RDONLY)) {
|
||||||
error = xfs_mount_log_sb(mp, mp->m_update_flags);
|
error = xfs_mount_log_sb(mp, mp->m_update_flags);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN, "XFS: failed to write sb changes");
|
xfs_warn(mp, "failed to write sb changes");
|
||||||
goto out_rtunmount;
|
goto out_rtunmount;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1403,10 +1396,7 @@ xfs_mountfs(
|
||||||
* quotachecked license.
|
* quotachecked license.
|
||||||
*/
|
*/
|
||||||
if (mp->m_sb.sb_qflags & XFS_ALL_QUOTA_ACCT) {
|
if (mp->m_sb.sb_qflags & XFS_ALL_QUOTA_ACCT) {
|
||||||
cmn_err(CE_NOTE,
|
xfs_notice(mp, "resetting quota flags");
|
||||||
"XFS: resetting qflags for filesystem %s",
|
|
||||||
mp->m_fsname);
|
|
||||||
|
|
||||||
error = xfs_mount_reset_sbqflags(mp);
|
error = xfs_mount_reset_sbqflags(mp);
|
||||||
if (error)
|
if (error)
|
||||||
return error;
|
return error;
|
||||||
|
@ -1420,7 +1410,7 @@ xfs_mountfs(
|
||||||
*/
|
*/
|
||||||
error = xfs_log_mount_finish(mp);
|
error = xfs_log_mount_finish(mp);
|
||||||
if (error) {
|
if (error) {
|
||||||
cmn_err(CE_WARN, "XFS: log mount finish failed");
|
xfs_warn(mp, "log mount finish failed");
|
||||||
goto out_rtunmount;
|
goto out_rtunmount;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1449,8 +1439,8 @@ xfs_mountfs(
|
||||||
resblks = xfs_default_resblks(mp);
|
resblks = xfs_default_resblks(mp);
|
||||||
error = xfs_reserve_blocks(mp, &resblks, NULL);
|
error = xfs_reserve_blocks(mp, &resblks, NULL);
|
||||||
if (error)
|
if (error)
|
||||||
cmn_err(CE_WARN, "XFS: Unable to allocate reserve "
|
xfs_warn(mp,
|
||||||
"blocks. Continuing without a reserve pool.");
|
"Unable to allocate reserve blocks. Continuing without reserve pool.");
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1539,12 +1529,12 @@ xfs_unmountfs(
|
||||||
resblks = 0;
|
resblks = 0;
|
||||||
error = xfs_reserve_blocks(mp, &resblks, NULL);
|
error = xfs_reserve_blocks(mp, &resblks, NULL);
|
||||||
if (error)
|
if (error)
|
||||||
cmn_err(CE_WARN, "XFS: Unable to free reserved block pool. "
|
xfs_warn(mp, "Unable to free reserved block pool. "
|
||||||
"Freespace may not be correct on next mount.");
|
"Freespace may not be correct on next mount.");
|
||||||
|
|
||||||
error = xfs_log_sbcount(mp, 1);
|
error = xfs_log_sbcount(mp, 1);
|
||||||
if (error)
|
if (error)
|
||||||
cmn_err(CE_WARN, "XFS: Unable to update superblock counters. "
|
xfs_warn(mp, "Unable to update superblock counters. "
|
||||||
"Freespace may not be correct on next mount.");
|
"Freespace may not be correct on next mount.");
|
||||||
xfs_unmountfs_writesb(mp);
|
xfs_unmountfs_writesb(mp);
|
||||||
xfs_unmountfs_wait(mp); /* wait for async bufs */
|
xfs_unmountfs_wait(mp); /* wait for async bufs */
|
||||||
|
@ -2027,10 +2017,8 @@ xfs_dev_is_read_only(
|
||||||
if (xfs_readonly_buftarg(mp->m_ddev_targp) ||
|
if (xfs_readonly_buftarg(mp->m_ddev_targp) ||
|
||||||
xfs_readonly_buftarg(mp->m_logdev_targp) ||
|
xfs_readonly_buftarg(mp->m_logdev_targp) ||
|
||||||
(mp->m_rtdev_targp && xfs_readonly_buftarg(mp->m_rtdev_targp))) {
|
(mp->m_rtdev_targp && xfs_readonly_buftarg(mp->m_rtdev_targp))) {
|
||||||
cmn_err(CE_NOTE,
|
xfs_notice(mp, "%s required on read-only device.", message);
|
||||||
"XFS: %s required on read-only device.", message);
|
xfs_notice(mp, "write access unavailable, cannot proceed.");
|
||||||
cmn_err(CE_NOTE,
|
|
||||||
"XFS: write access unavailable, cannot proceed.");
|
|
||||||
return EROFS;
|
return EROFS;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -2210,8 +2210,8 @@ xfs_rtmount_init(
|
||||||
if (sbp->sb_rblocks == 0)
|
if (sbp->sb_rblocks == 0)
|
||||||
return 0;
|
return 0;
|
||||||
if (mp->m_rtdev_targp == NULL) {
|
if (mp->m_rtdev_targp == NULL) {
|
||||||
cmn_err(CE_WARN,
|
xfs_warn(mp,
|
||||||
"XFS: This filesystem has a realtime volume, use rtdev=device option");
|
"Filesystem has a realtime volume, use rtdev=device option");
|
||||||
return XFS_ERROR(ENODEV);
|
return XFS_ERROR(ENODEV);
|
||||||
}
|
}
|
||||||
mp->m_rsumlevels = sbp->sb_rextslog + 1;
|
mp->m_rsumlevels = sbp->sb_rextslog + 1;
|
||||||
|
@ -2225,7 +2225,7 @@ xfs_rtmount_init(
|
||||||
*/
|
*/
|
||||||
d = (xfs_daddr_t)XFS_FSB_TO_BB(mp, mp->m_sb.sb_rblocks);
|
d = (xfs_daddr_t)XFS_FSB_TO_BB(mp, mp->m_sb.sb_rblocks);
|
||||||
if (XFS_BB_TO_FSB(mp, d) != mp->m_sb.sb_rblocks) {
|
if (XFS_BB_TO_FSB(mp, d) != mp->m_sb.sb_rblocks) {
|
||||||
cmn_err(CE_WARN, "XFS: realtime mount -- %llu != %llu",
|
xfs_warn(mp, "realtime mount -- %llu != %llu",
|
||||||
(unsigned long long) XFS_BB_TO_FSB(mp, d),
|
(unsigned long long) XFS_BB_TO_FSB(mp, d),
|
||||||
(unsigned long long) mp->m_sb.sb_rblocks);
|
(unsigned long long) mp->m_sb.sb_rblocks);
|
||||||
return XFS_ERROR(EFBIG);
|
return XFS_ERROR(EFBIG);
|
||||||
|
@ -2234,7 +2234,7 @@ xfs_rtmount_init(
|
||||||
d - XFS_FSB_TO_BB(mp, 1),
|
d - XFS_FSB_TO_BB(mp, 1),
|
||||||
XFS_FSB_TO_B(mp, 1), 0);
|
XFS_FSB_TO_B(mp, 1), 0);
|
||||||
if (!bp) {
|
if (!bp) {
|
||||||
cmn_err(CE_WARN, "XFS: realtime device size check failed");
|
xfs_warn(mp, "realtime device size check failed");
|
||||||
return EIO;
|
return EIO;
|
||||||
}
|
}
|
||||||
xfs_buf_relse(bp);
|
xfs_buf_relse(bp);
|
||||||
|
|
|
@ -154,7 +154,7 @@ xfs_rtmount_init(
|
||||||
if (mp->m_sb.sb_rblocks == 0)
|
if (mp->m_sb.sb_rblocks == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
cmn_err(CE_WARN, "XFS: Not built with CONFIG_XFS_RT");
|
xfs_warn(mp, "Not built with CONFIG_XFS_RT");
|
||||||
return ENOSYS;
|
return ENOSYS;
|
||||||
}
|
}
|
||||||
# define xfs_rtmount_inodes(m) (((mp)->m_sb.sb_rblocks == 0)? 0 : (ENOSYS))
|
# define xfs_rtmount_inodes(m) (((mp)->m_sb.sb_rblocks == 0)? 0 : (ENOSYS))
|
||||||
|
|
|
@ -49,9 +49,9 @@ xfs_do_force_shutdown(
|
||||||
logerror = flags & SHUTDOWN_LOG_IO_ERROR;
|
logerror = flags & SHUTDOWN_LOG_IO_ERROR;
|
||||||
|
|
||||||
if (!(flags & SHUTDOWN_FORCE_UMOUNT)) {
|
if (!(flags & SHUTDOWN_FORCE_UMOUNT)) {
|
||||||
cmn_err(CE_NOTE, "xfs_force_shutdown(%s,0x%x) called from "
|
xfs_notice(mp,
|
||||||
"line %d of file %s. Return address = 0x%p",
|
"%s(0x%x) called from line %d of file %s. Return address = 0x%p",
|
||||||
mp->m_fsname, flags, lnnum, fname, __return_address);
|
__func__, flags, lnnum, fname, __return_address);
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
* No need to duplicate efforts.
|
* No need to duplicate efforts.
|
||||||
|
@ -86,8 +86,8 @@ xfs_do_force_shutdown(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!(flags & SHUTDOWN_FORCE_UMOUNT)) {
|
if (!(flags & SHUTDOWN_FORCE_UMOUNT)) {
|
||||||
cmn_err(CE_ALERT, "Please umount the filesystem, "
|
xfs_alert(mp,
|
||||||
"and rectify the problem(s)");
|
"Please umount the filesystem and rectify the problem(s)");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -101,10 +101,9 @@ xfs_ioerror_alert(
|
||||||
xfs_buf_t *bp,
|
xfs_buf_t *bp,
|
||||||
xfs_daddr_t blkno)
|
xfs_daddr_t blkno)
|
||||||
{
|
{
|
||||||
cmn_err(CE_ALERT,
|
xfs_alert(mp,
|
||||||
"I/O error in filesystem (\"%s\") meta-data dev %s block 0x%llx"
|
"I/O error occurred: meta-data dev %s block 0x%llx"
|
||||||
" (\"%s\") error %d buf count %zd",
|
" (\"%s\") error %d buf count %zd",
|
||||||
(!mp || !mp->m_fsname) ? "(fs name not set)" : mp->m_fsname,
|
|
||||||
XFS_BUFTARG_NAME(XFS_BUF_TARGET(bp)),
|
XFS_BUFTARG_NAME(XFS_BUF_TARGET(bp)),
|
||||||
(__uint64_t)blkno, func,
|
(__uint64_t)blkno, func,
|
||||||
XFS_BUF_GETERROR(bp), XFS_BUF_COUNT(bp));
|
XFS_BUF_GETERROR(bp), XFS_BUF_COUNT(bp));
|
||||||
|
|
|
@ -305,7 +305,7 @@ xfs_trans_read_buf(
|
||||||
if (xfs_error_target == target) {
|
if (xfs_error_target == target) {
|
||||||
if (((xfs_req_num++) % xfs_error_mod) == 0) {
|
if (((xfs_req_num++) % xfs_error_mod) == 0) {
|
||||||
xfs_buf_relse(bp);
|
xfs_buf_relse(bp);
|
||||||
cmn_err(CE_DEBUG, "Returning error!\n");
|
xfs_debug(mp, "Returning error!");
|
||||||
return XFS_ERROR(EIO);
|
return XFS_ERROR(EIO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -403,7 +403,7 @@ xfs_trans_read_buf(
|
||||||
xfs_force_shutdown(tp->t_mountp,
|
xfs_force_shutdown(tp->t_mountp,
|
||||||
SHUTDOWN_META_IO_ERROR);
|
SHUTDOWN_META_IO_ERROR);
|
||||||
xfs_buf_relse(bp);
|
xfs_buf_relse(bp);
|
||||||
cmn_err(CE_DEBUG, "Returning trans error!\n");
|
xfs_debug(mp, "Returning trans error!");
|
||||||
return XFS_ERROR(EIO);
|
return XFS_ERROR(EIO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -427,7 +427,7 @@ shutdown_abort:
|
||||||
*/
|
*/
|
||||||
#if defined(DEBUG)
|
#if defined(DEBUG)
|
||||||
if (XFS_BUF_ISSTALE(bp) && XFS_BUF_ISDELAYWRITE(bp))
|
if (XFS_BUF_ISSTALE(bp) && XFS_BUF_ISDELAYWRITE(bp))
|
||||||
cmn_err(CE_NOTE, "about to pop assert, bp == 0x%p", bp);
|
xfs_notice(mp, "about to pop assert, bp == 0x%p", bp);
|
||||||
#endif
|
#endif
|
||||||
ASSERT((XFS_BUF_BFLAGS(bp) & (XBF_STALE|XBF_DELWRI)) !=
|
ASSERT((XFS_BUF_BFLAGS(bp) & (XBF_STALE|XBF_DELWRI)) !=
|
||||||
(XBF_STALE|XBF_DELWRI));
|
(XBF_STALE|XBF_DELWRI));
|
||||||
|
|
|
@ -1189,9 +1189,8 @@ xfs_inactive(
|
||||||
* inode might be lost for a long time or forever.
|
* inode might be lost for a long time or forever.
|
||||||
*/
|
*/
|
||||||
if (!XFS_FORCED_SHUTDOWN(mp)) {
|
if (!XFS_FORCED_SHUTDOWN(mp)) {
|
||||||
cmn_err(CE_NOTE,
|
xfs_notice(mp, "%s: xfs_ifree returned error %d",
|
||||||
"xfs_inactive: xfs_ifree() returned an error = %d on %s",
|
__func__, error);
|
||||||
error, mp->m_fsname);
|
|
||||||
xfs_force_shutdown(mp, SHUTDOWN_META_IO_ERROR);
|
xfs_force_shutdown(mp, SHUTDOWN_META_IO_ERROR);
|
||||||
}
|
}
|
||||||
xfs_trans_cancel(tp, XFS_TRANS_RELEASE_LOG_RES|XFS_TRANS_ABORT);
|
xfs_trans_cancel(tp, XFS_TRANS_RELEASE_LOG_RES|XFS_TRANS_ABORT);
|
||||||
|
|
Loading…
Reference in a new issue