aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/linux-2.6/xfs_super.c
diff options
context:
space:
mode:
authorDave Chinner <dchinner@redhat.com>2011-03-06 18:00:35 -0500
committerDave Chinner <david@fromorbit.com>2011-03-06 18:00:35 -0500
commit4f10700a2e4bb2ff3d3a80f08412e21109e6d4b5 (patch)
treeb530112e7c04f1c7c62b8eec2b850508905fc42a /fs/xfs/linux-2.6/xfs_super.c
parent10e38391c0e242e53e30094f6c00553418ab2f2e (diff)
xfs: Convert linux-2.6/ files to new logging interface
Convert the files in fs/xfs/linux-2.6/ to use the new xfs_<level> logging format that replaces the old Irix inherited cmn_err() interfaces. While there, also convert naked printk calls to use the relevant xfs logging function to standardise output format. Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Alex Elder <aelder@sgi.com> Reviewed-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'fs/xfs/linux-2.6/xfs_super.c')
-rw-r--r--fs/xfs/linux-2.6/xfs_super.c127
1 files changed, 57 insertions, 70 deletions
diff --git a/fs/xfs/linux-2.6/xfs_super.c b/fs/xfs/linux-2.6/xfs_super.c
index 7ec1fb8c1316..818c4cf2de86 100644
--- a/fs/xfs/linux-2.6/xfs_super.c
+++ b/fs/xfs/linux-2.6/xfs_super.c
@@ -173,6 +173,15 @@ xfs_parseargs(
173 __uint8_t iosizelog = 0; 173 __uint8_t iosizelog = 0;
174 174
175 /* 175 /*
176 * set up the mount name first so all the errors will refer to the
177 * correct device.
178 */
179 mp->m_fsname = kstrndup(sb->s_id, MAXNAMELEN, GFP_KERNEL);
180 if (!mp->m_fsname)
181 return ENOMEM;
182 mp->m_fsname_len = strlen(mp->m_fsname) + 1;
183
184 /*
176 * Copy binary VFS mount flags we are interested in. 185 * Copy binary VFS mount flags we are interested in.
177 */ 186 */
178 if (sb->s_flags & MS_RDONLY) 187 if (sb->s_flags & MS_RDONLY)
@@ -208,24 +217,21 @@ xfs_parseargs(
208 217
209 if (!strcmp(this_char, MNTOPT_LOGBUFS)) { 218 if (!strcmp(this_char, MNTOPT_LOGBUFS)) {
210 if (!value || !*value) { 219 if (!value || !*value) {
211 cmn_err(CE_WARN, 220 xfs_warn(mp, "%s option requires an argument",
212 "XFS: %s option requires an argument",
213 this_char); 221 this_char);
214 return EINVAL; 222 return EINVAL;
215 } 223 }
216 mp->m_logbufs = simple_strtoul(value, &eov, 10); 224 mp->m_logbufs = simple_strtoul(value, &eov, 10);
217 } else if (!strcmp(this_char, MNTOPT_LOGBSIZE)) { 225 } else if (!strcmp(this_char, MNTOPT_LOGBSIZE)) {
218 if (!value || !*value) { 226 if (!value || !*value) {
219 cmn_err(CE_WARN, 227 xfs_warn(mp, "%s option requires an argument",
220 "XFS: %s option requires an argument",
221 this_char); 228 this_char);
222 return EINVAL; 229 return EINVAL;
223 } 230 }
224 mp->m_logbsize = suffix_strtoul(value, &eov, 10); 231 mp->m_logbsize = suffix_strtoul(value, &eov, 10);
225 } else if (!strcmp(this_char, MNTOPT_LOGDEV)) { 232 } else if (!strcmp(this_char, MNTOPT_LOGDEV)) {
226 if (!value || !*value) { 233 if (!value || !*value) {
227 cmn_err(CE_WARN, 234 xfs_warn(mp, "%s option requires an argument",
228 "XFS: %s option requires an argument",
229 this_char); 235 this_char);
230 return EINVAL; 236 return EINVAL;
231 } 237 }
@@ -233,14 +239,12 @@ xfs_parseargs(
233 if (!mp->m_logname) 239 if (!mp->m_logname)
234 return ENOMEM; 240 return ENOMEM;
235 } else if (!strcmp(this_char, MNTOPT_MTPT)) { 241 } else if (!strcmp(this_char, MNTOPT_MTPT)) {
236 cmn_err(CE_WARN, 242 xfs_warn(mp, "%s option not allowed on this system",
237 "XFS: %s option not allowed on this system",
238 this_char); 243 this_char);
239 return EINVAL; 244 return EINVAL;
240 } else if (!strcmp(this_char, MNTOPT_RTDEV)) { 245 } else if (!strcmp(this_char, MNTOPT_RTDEV)) {
241 if (!value || !*value) { 246 if (!value || !*value) {
242 cmn_err(CE_WARN, 247 xfs_warn(mp, "%s option requires an argument",
243 "XFS: %s option requires an argument",
244 this_char); 248 this_char);
245 return EINVAL; 249 return EINVAL;
246 } 250 }
@@ -249,8 +253,7 @@ xfs_parseargs(
249 return ENOMEM; 253 return ENOMEM;
250 } else if (!strcmp(this_char, MNTOPT_BIOSIZE)) { 254 } else if (!strcmp(this_char, MNTOPT_BIOSIZE)) {
251 if (!value || !*value) { 255 if (!value || !*value) {
252 cmn_err(CE_WARN, 256 xfs_warn(mp, "%s option requires an argument",
253 "XFS: %s option requires an argument",
254 this_char); 257 this_char);
255 return EINVAL; 258 return EINVAL;
256 } 259 }
@@ -258,8 +261,7 @@ xfs_parseargs(
258 iosizelog = ffs(iosize) - 1; 261 iosizelog = ffs(iosize) - 1;
259 } else if (!strcmp(this_char, MNTOPT_ALLOCSIZE)) { 262 } else if (!strcmp(this_char, MNTOPT_ALLOCSIZE)) {
260 if (!value || !*value) { 263 if (!value || !*value) {
261 cmn_err(CE_WARN, 264 xfs_warn(mp, "%s option requires an argument",
262 "XFS: %s option requires an argument",
263 this_char); 265 this_char);
264 return EINVAL; 266 return EINVAL;
265 } 267 }
@@ -281,16 +283,14 @@ xfs_parseargs(
281 mp->m_flags |= XFS_MOUNT_SWALLOC; 283 mp->m_flags |= XFS_MOUNT_SWALLOC;
282 } else if (!strcmp(this_char, MNTOPT_SUNIT)) { 284 } else if (!strcmp(this_char, MNTOPT_SUNIT)) {
283 if (!value || !*value) { 285 if (!value || !*value) {
284 cmn_err(CE_WARN, 286 xfs_warn(mp, "%s option requires an argument",
285 "XFS: %s option requires an argument",
286 this_char); 287 this_char);
287 return EINVAL; 288 return EINVAL;
288 } 289 }
289 dsunit = simple_strtoul(value, &eov, 10); 290 dsunit = simple_strtoul(value, &eov, 10);
290 } else if (!strcmp(this_char, MNTOPT_SWIDTH)) { 291 } else if (!strcmp(this_char, MNTOPT_SWIDTH)) {
291 if (!value || !*value) { 292 if (!value || !*value) {
292 cmn_err(CE_WARN, 293 xfs_warn(mp, "%s option requires an argument",
293 "XFS: %s option requires an argument",
294 this_char); 294 this_char);
295 return EINVAL; 295 return EINVAL;
296 } 296 }
@@ -298,8 +298,7 @@ xfs_parseargs(
298 } else if (!strcmp(this_char, MNTOPT_64BITINODE)) { 298 } else if (!strcmp(this_char, MNTOPT_64BITINODE)) {
299 mp->m_flags &= ~XFS_MOUNT_SMALL_INUMS; 299 mp->m_flags &= ~XFS_MOUNT_SMALL_INUMS;
300#if !XFS_BIG_INUMS 300#if !XFS_BIG_INUMS
301 cmn_err(CE_WARN, 301 xfs_warn(mp, "%s option not allowed on this system",
302 "XFS: %s option not allowed on this system",
303 this_char); 302 this_char);
304 return EINVAL; 303 return EINVAL;
305#endif 304#endif
@@ -357,20 +356,19 @@ xfs_parseargs(
357 } else if (!strcmp(this_char, MNTOPT_NODELAYLOG)) { 356 } else if (!strcmp(this_char, MNTOPT_NODELAYLOG)) {
358 mp->m_flags &= ~XFS_MOUNT_DELAYLOG; 357 mp->m_flags &= ~XFS_MOUNT_DELAYLOG;
359 } else if (!strcmp(this_char, "ihashsize")) { 358 } else if (!strcmp(this_char, "ihashsize")) {
360 cmn_err(CE_WARN, 359 xfs_warn(mp,
361 "XFS: ihashsize no longer used, option is deprecated."); 360 "ihashsize no longer used, option is deprecated.");
362 } else if (!strcmp(this_char, "osyncisdsync")) { 361 } else if (!strcmp(this_char, "osyncisdsync")) {
363 cmn_err(CE_WARN, 362 xfs_warn(mp,
364 "XFS: osyncisdsync has no effect, option is deprecated."); 363 "osyncisdsync has no effect, option is deprecated.");
365 } else if (!strcmp(this_char, "osyncisosync")) { 364 } else if (!strcmp(this_char, "osyncisosync")) {
366 cmn_err(CE_WARN, 365 xfs_warn(mp,
367 "XFS: osyncisosync has no effect, option is deprecated."); 366 "osyncisosync has no effect, option is deprecated.");
368 } else if (!strcmp(this_char, "irixsgid")) { 367 } else if (!strcmp(this_char, "irixsgid")) {
369 cmn_err(CE_WARN, 368 xfs_warn(mp,
370 "XFS: irixsgid is now a sysctl(2) variable, option is deprecated."); 369 "irixsgid is now a sysctl(2) variable, option is deprecated.");
371 } else { 370 } else {
372 cmn_err(CE_WARN, 371 xfs_warn(mp, "unknown mount option [%s].", this_char);
373 "XFS: unknown mount option [%s].", this_char);
374 return EINVAL; 372 return EINVAL;
375 } 373 }
376 } 374 }
@@ -380,40 +378,37 @@ xfs_parseargs(
380 */ 378 */
381 if ((mp->m_flags & XFS_MOUNT_NORECOVERY) && 379 if ((mp->m_flags & XFS_MOUNT_NORECOVERY) &&
382 !(mp->m_flags & XFS_MOUNT_RDONLY)) { 380 !(mp->m_flags & XFS_MOUNT_RDONLY)) {
383 cmn_err(CE_WARN, "XFS: no-recovery mounts must be read-only."); 381 xfs_warn(mp, "no-recovery mounts must be read-only.");
384 return EINVAL; 382 return EINVAL;
385 } 383 }
386 384
387 if ((mp->m_flags & XFS_MOUNT_NOALIGN) && (dsunit || dswidth)) { 385 if ((mp->m_flags & XFS_MOUNT_NOALIGN) && (dsunit || dswidth)) {
388 cmn_err(CE_WARN, 386 xfs_warn(mp,
389 "XFS: sunit and swidth options incompatible with the noalign option"); 387 "sunit and swidth options incompatible with the noalign option");
390 return EINVAL; 388 return EINVAL;
391 } 389 }
392 390
393#ifndef CONFIG_XFS_QUOTA 391#ifndef CONFIG_XFS_QUOTA
394 if (XFS_IS_QUOTA_RUNNING(mp)) { 392 if (XFS_IS_QUOTA_RUNNING(mp)) {
395 cmn_err(CE_WARN, 393 xfs_warn(mp, "quota support not available in this kernel.");
396 "XFS: quota support not available in this kernel.");
397 return EINVAL; 394 return EINVAL;
398 } 395 }
399#endif 396#endif
400 397
401 if ((mp->m_qflags & (XFS_GQUOTA_ACCT | XFS_GQUOTA_ACTIVE)) && 398 if ((mp->m_qflags & (XFS_GQUOTA_ACCT | XFS_GQUOTA_ACTIVE)) &&
402 (mp->m_qflags & (XFS_PQUOTA_ACCT | XFS_PQUOTA_ACTIVE))) { 399 (mp->m_qflags & (XFS_PQUOTA_ACCT | XFS_PQUOTA_ACTIVE))) {
403 cmn_err(CE_WARN, 400 xfs_warn(mp, "cannot mount with both project and group quota");
404 "XFS: cannot mount with both project and group quota");
405 return EINVAL; 401 return EINVAL;
406 } 402 }
407 403
408 if ((dsunit && !dswidth) || (!dsunit && dswidth)) { 404 if ((dsunit && !dswidth) || (!dsunit && dswidth)) {
409 cmn_err(CE_WARN, 405 xfs_warn(mp, "sunit and swidth must be specified together");
410 "XFS: sunit and swidth must be specified together");
411 return EINVAL; 406 return EINVAL;
412 } 407 }
413 408
414 if (dsunit && (dswidth % dsunit != 0)) { 409 if (dsunit && (dswidth % dsunit != 0)) {
415 cmn_err(CE_WARN, 410 xfs_warn(mp,
416 "XFS: stripe width (%d) must be a multiple of the stripe unit (%d)", 411 "stripe width (%d) must be a multiple of the stripe unit (%d)",
417 dswidth, dsunit); 412 dswidth, dsunit);
418 return EINVAL; 413 return EINVAL;
419 } 414 }
@@ -439,8 +434,7 @@ done:
439 mp->m_logbufs != 0 && 434 mp->m_logbufs != 0 &&
440 (mp->m_logbufs < XLOG_MIN_ICLOGS || 435 (mp->m_logbufs < XLOG_MIN_ICLOGS ||
441 mp->m_logbufs > XLOG_MAX_ICLOGS)) { 436 mp->m_logbufs > XLOG_MAX_ICLOGS)) {
442 cmn_err(CE_WARN, 437 xfs_warn(mp, "invalid logbufs value: %d [not %d-%d]",
443 "XFS: invalid logbufs value: %d [not %d-%d]",
444 mp->m_logbufs, XLOG_MIN_ICLOGS, XLOG_MAX_ICLOGS); 438 mp->m_logbufs, XLOG_MIN_ICLOGS, XLOG_MAX_ICLOGS);
445 return XFS_ERROR(EINVAL); 439 return XFS_ERROR(EINVAL);
446 } 440 }
@@ -449,22 +443,16 @@ done:
449 (mp->m_logbsize < XLOG_MIN_RECORD_BSIZE || 443 (mp->m_logbsize < XLOG_MIN_RECORD_BSIZE ||
450 mp->m_logbsize > XLOG_MAX_RECORD_BSIZE || 444 mp->m_logbsize > XLOG_MAX_RECORD_BSIZE ||
451 !is_power_of_2(mp->m_logbsize))) { 445 !is_power_of_2(mp->m_logbsize))) {
452 cmn_err(CE_WARN, 446 xfs_warn(mp,
453 "XFS: invalid logbufsize: %d [not 16k,32k,64k,128k or 256k]", 447 "invalid logbufsize: %d [not 16k,32k,64k,128k or 256k]",
454 mp->m_logbsize); 448 mp->m_logbsize);
455 return XFS_ERROR(EINVAL); 449 return XFS_ERROR(EINVAL);
456 } 450 }
457 451
458 mp->m_fsname = kstrndup(sb->s_id, MAXNAMELEN, GFP_KERNEL);
459 if (!mp->m_fsname)
460 return ENOMEM;
461 mp->m_fsname_len = strlen(mp->m_fsname) + 1;
462
463 if (iosizelog) { 452 if (iosizelog) {
464 if (iosizelog > XFS_MAX_IO_LOG || 453 if (iosizelog > XFS_MAX_IO_LOG ||
465 iosizelog < XFS_MIN_IO_LOG) { 454 iosizelog < XFS_MIN_IO_LOG) {
466 cmn_err(CE_WARN, 455 xfs_warn(mp, "invalid log iosize: %d [not %d-%d]",
467 "XFS: invalid log iosize: %d [not %d-%d]",
468 iosizelog, XFS_MIN_IO_LOG, 456 iosizelog, XFS_MIN_IO_LOG,
469 XFS_MAX_IO_LOG); 457 XFS_MAX_IO_LOG);
470 return XFS_ERROR(EINVAL); 458 return XFS_ERROR(EINVAL);
@@ -611,7 +599,7 @@ xfs_blkdev_get(
611 mp); 599 mp);
612 if (IS_ERR(*bdevp)) { 600 if (IS_ERR(*bdevp)) {
613 error = PTR_ERR(*bdevp); 601 error = PTR_ERR(*bdevp);
614 printk("XFS: Invalid device [%s], error=%d\n", name, error); 602 xfs_warn(mp, "Invalid device [%s], error=%d\n", name, error);
615 } 603 }
616 604
617 return -error; 605 return -error;
@@ -665,23 +653,23 @@ xfs_mountfs_check_barriers(xfs_mount_t *mp)
665 int error; 653 int error;
666 654
667 if (mp->m_logdev_targp != mp->m_ddev_targp) { 655 if (mp->m_logdev_targp != mp->m_ddev_targp) {
668 xfs_fs_cmn_err(CE_NOTE, mp, 656 xfs_notice(mp,
669 "Disabling barriers, not supported with external log device"); 657 "Disabling barriers, not supported with external log device");
670 mp->m_flags &= ~XFS_MOUNT_BARRIER; 658 mp->m_flags &= ~XFS_MOUNT_BARRIER;
671 return; 659 return;
672 } 660 }
673 661
674 if (xfs_readonly_buftarg(mp->m_ddev_targp)) { 662 if (xfs_readonly_buftarg(mp->m_ddev_targp)) {
675 xfs_fs_cmn_err(CE_NOTE, mp, 663 xfs_notice(mp,
676 "Disabling barriers, underlying device is readonly"); 664 "Disabling barriers, underlying device is readonly");
677 mp->m_flags &= ~XFS_MOUNT_BARRIER; 665 mp->m_flags &= ~XFS_MOUNT_BARRIER;
678 return; 666 return;
679 } 667 }
680 668
681 error = xfs_barrier_test(mp); 669 error = xfs_barrier_test(mp);
682 if (error) { 670 if (error) {
683 xfs_fs_cmn_err(CE_NOTE, mp, 671 xfs_notice(mp,
684 "Disabling barriers, trial barrier write failed"); 672 "Disabling barriers, trial barrier write failed");
685 mp->m_flags &= ~XFS_MOUNT_BARRIER; 673 mp->m_flags &= ~XFS_MOUNT_BARRIER;
686 return; 674 return;
687 } 675 }
@@ -744,8 +732,8 @@ xfs_open_devices(
744 goto out_close_logdev; 732 goto out_close_logdev;
745 733
746 if (rtdev == ddev || rtdev == logdev) { 734 if (rtdev == ddev || rtdev == logdev) {
747 cmn_err(CE_WARN, 735 xfs_warn(mp,
748 "XFS: Cannot mount filesystem with identical rtdev and ddev/logdev."); 736 "Cannot mount filesystem with identical rtdev and ddev/logdev.");
749 error = EINVAL; 737 error = EINVAL;
750 goto out_close_rtdev; 738 goto out_close_rtdev;
751 } 739 }
@@ -1346,8 +1334,8 @@ xfs_fs_remount(
1346 * options that we can't actually change. 1334 * options that we can't actually change.
1347 */ 1335 */
1348#if 0 1336#if 0
1349 printk(KERN_INFO 1337 xfs_info(mp,
1350 "XFS: mount option \"%s\" not supported for remount\n", p); 1338 "mount option \"%s\" not supported for remount\n", p);
1351 return -EINVAL; 1339 return -EINVAL;
1352#else 1340#else
1353 break; 1341 break;
@@ -1368,8 +1356,7 @@ xfs_fs_remount(
1368 if (mp->m_update_flags) { 1356 if (mp->m_update_flags) {
1369 error = xfs_mount_log_sb(mp, mp->m_update_flags); 1357 error = xfs_mount_log_sb(mp, mp->m_update_flags);
1370 if (error) { 1358 if (error) {
1371 cmn_err(CE_WARN, 1359 xfs_warn(mp, "failed to write sb changes");
1372 "XFS: failed to write sb changes");
1373 return error; 1360 return error;
1374 } 1361 }
1375 mp->m_update_flags = 0; 1362 mp->m_update_flags = 0;
@@ -1453,15 +1440,15 @@ xfs_finish_flags(
1453 mp->m_logbsize = mp->m_sb.sb_logsunit; 1440 mp->m_logbsize = mp->m_sb.sb_logsunit;
1454 } else if (mp->m_logbsize > 0 && 1441 } else if (mp->m_logbsize > 0 &&
1455 mp->m_logbsize < mp->m_sb.sb_logsunit) { 1442 mp->m_logbsize < mp->m_sb.sb_logsunit) {
1456 cmn_err(CE_WARN, 1443 xfs_warn(mp,
1457 "XFS: logbuf size must be greater than or equal to log stripe size"); 1444 "logbuf size must be greater than or equal to log stripe size");
1458 return XFS_ERROR(EINVAL); 1445 return XFS_ERROR(EINVAL);
1459 } 1446 }
1460 } else { 1447 } else {
1461 /* Fail a mount if the logbuf is larger than 32K */ 1448 /* Fail a mount if the logbuf is larger than 32K */
1462 if (mp->m_logbsize > XLOG_BIG_RECORD_BSIZE) { 1449 if (mp->m_logbsize > XLOG_BIG_RECORD_BSIZE) {
1463 cmn_err(CE_WARN, 1450 xfs_warn(mp,
1464 "XFS: logbuf size for version 1 logs must be 16K or 32K"); 1451 "logbuf size for version 1 logs must be 16K or 32K");
1465 return XFS_ERROR(EINVAL); 1452 return XFS_ERROR(EINVAL);
1466 } 1453 }
1467 } 1454 }
@@ -1478,8 +1465,8 @@ xfs_finish_flags(
1478 * prohibit r/w mounts of read-only filesystems 1465 * prohibit r/w mounts of read-only filesystems
1479 */ 1466 */
1480 if ((mp->m_sb.sb_flags & XFS_SBF_READONLY) && !ronly) { 1467 if ((mp->m_sb.sb_flags & XFS_SBF_READONLY) && !ronly) {
1481 cmn_err(CE_WARN, 1468 xfs_warn(mp,
1482 "XFS: cannot mount a read-only filesystem as read-write"); 1469 "cannot mount a read-only filesystem as read-write");
1483 return XFS_ERROR(EROFS); 1470 return XFS_ERROR(EROFS);
1484 } 1471 }
1485 1472