提交 0b932ccc 编写于 作者: D Dave Chinner 提交者: Dave Chinner

xfs: Convert remaining cmn_err() callers to new API

Once converted, kill the remainder of the cmn_err() interface.
Signed-off-by: NDave Chinner <dchinner@redhat.com>
Reviewed-by: NAlex Elder <aelder@sgi.com>
Reviewed-by: NChristoph Hellwig <hch@lst.de>
上级 8221112b
...@@ -828,7 +828,7 @@ xfs_qm_dqget( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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; ...@@ -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) ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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 @@ ...@@ -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 @@ ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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) ...@@ -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, ...@@ -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) ...@@ -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) ...@@ -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) ...@@ -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) ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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) ...@@ -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) ...@@ -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) ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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( ...@@ -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 @@ xfs_trans_read_buf( ...@@ -427,7 +427,7 @@ xfs_trans_read_buf(
*/ */
#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( ...@@ -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);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册