From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-lf0-f68.google.com ([209.85.215.68]:35421 "EHLO mail-lf0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752354AbdGLNLc (ORCPT ); Wed, 12 Jul 2017 09:11:32 -0400 Received: by mail-lf0-f68.google.com with SMTP id z78so2717575lff.2 for ; Wed, 12 Jul 2017 06:11:32 -0700 (PDT) From: Filippe LeMarchand To: Qu Wenruo Cc: Lu Fengqi , linux-btrfs@vger.kernel.org, Qu Wenruo Subject: Re: Btrfs check reports errors, filesystem seems fine Date: Wed, 12 Jul 2017 16:11:23 +0300 Message-ID: <1890561.EoWiig1PuT@carbide> In-Reply-To: References: <2049018.boNrIqZ5uI@carbide> <4618180.XOrZWPbqUa@carbide> MIME-Version: 1.0 Content-Type: multipart/signed; boundary="nextPart3138102.tkaniBDuKa"; micalg="sha256"; protocol="application/pkcs7-signature" Sender: linux-btrfs-owner@vger.kernel.org List-ID: --nextPart3138102.tkaniBDuKa Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="UTF-8" Done, files added to same GDrive folder with corresponding names. If it matters, subvol 4546 is my root filesystem (r/w snapshot created with= snapper rollback), and 5134 is its snapshot. In a letter dated Wednesday, July 12, 2017 15:44:52 MSK user Qu Wenruo wrot= e: >=20 > On 2017=E5=B9=B407=E6=9C=8812=E6=97=A5 19:12, Filippe LeMarchand wrote: > >> Maybe something wrong in grep happened which skip "(79177" ? > > Yes, my bad. Now I used grep -E "\(79177| 79177" pattern, file on GDriv= e updated. >=20 > It looks much better, thanks. >=20 > >=20 > > And btrfs check --mode=3Dlowmem gives this: > >=20 > > checking extents > > ERROR: extent[1609877700608, 94208] referencer count mismatch (root: 26= 0, owner: 61720, offset: 6742016) wanted: 2, have: 5 > > ERROR: extent[1630301675520, 39583744] referencer count mismatch (root:= 260, owner: 5847554, offset: 0) wanted: 36, have: 114 > > ERROR: extent[1658646986752, 10551296] referencer count mismatch (root:= 274, owner: 283675, offset: 0) wanted: 2, have: 5 > > ERROR: extent[1672239132672, 84381696] referencer count mismatch (root:= 274, owner: 2521382, offset: 0) wanted: 21, have: 25 > > ERROR: errors found in extent allocation tree or chunk allocation >=20 > Looks much like an exposed lowmem mode bug. > Feel free to ignore these error from extent tree, they are just false=20 > alerts. >=20 > > checking free space cache > > checking fs roots > > ERROR: root 4546 DIR_ITEM[79177 54846528] relative INODE_REF missing na= melen 14 filename deprecated.sxt filetype 1 >=20 > The error report is much better than original mode, and that's what I nee= d. >=20 > Now I can wipe out all other noise as we know exactly which tree and=20 > which DIR_ITEM/INODE_REF is causing the problem. >=20 > Would you please update the dump result with "-t 4546" passed to=20 > btrfs-debug-tree like: >=20 > # btrfs-debug-tree -t 4546 | grep 79177 >=20 > Only "-t 4546" is added, to only dump the result of subvolume 4546. > As always, all 3 grep results (2 "deprecated" and one 79177) need to be=20 > updated. >=20 > And it seems that my previous assumption is still right for this case. > If it's caused by kernel, your dump would definitely help us to locate=20 > the problem. >=20 > > ERROR: root 4546 INODE REF[4222342 79177] and DIR_ITEM[79177 54846528] = mismatch namelen 14 filename deprecated.txt filetype 1 > > ERROR: root 5134 DIR_ITEM[79177 54846528] relative INODE_REF missing na= melen 14 filename deprecated.sxt filetype 1 >=20 > Also for root 5134 please. >=20 > Thanks, > Qu >=20 > > ERROR: errors found in fs roots > > Checking filesystem on /dev/sda2 > > UUID: 12c84aa3-ce65-4390-807e-a72cc8a7445e > > found 153429872640 bytes used, error(s) found > > total csum bytes: 121991672 > > total tree bytes: 1940160512 > > total fs tree bytes: 1683767296 > > total extent tree bytes: 103841792 > > btree space waste bytes: 310722480 > > file data blocks allocated: 842455031808 > > referenced 159286636544 > >=20 > > In a letter from Wednesday, July 12, 2017 10:15:18 MSK user Qu Wenruo w= rote: > >> Sorry for the late reply. > >> > >> After investigating the dumps, I found the output is quite strange. > >> > >> 1) Mismatching output. > >> In "btrfs-debug-tree-grep-79177.txt" I found only 79177 as offset for > >> INODE_REF is here, while 79177 as objectid for DIR_ITEM/DIR_INDEX is n= ot > >> here at all. > >> > >> While in "btrfs-debug-tree-grep-deprecated-txt.txt" there is epected > >> 79177 DIR_ITEM/DIR_INDEX. > >> > >> Maybe something wrong in grep happened which skip "(79177" ? > >> > >> 2) Mismatched hash > >> The main problem I found is that, for key (79177 DIR_ITEM 54846528), t= he > >> number 54846528 is the hash(crc32c) of filename, and it contains 2 > >> items, one for "deprecated.txt" and one for "deprecated.sxt". > >> > >> But we found that 54846528 only matches the hash for "deprecated.txt", > >> not "deprecated.sxt". > >> > >> I think that's the main problem. > >> > >> BTW, would you please try "btrfs check --mode=3Dlowmem" to see if lowm= em > >> mode reports similar (well, output may differ) error? > >> > >> If lowmem mode also reports error on such DIR_ITEM, I'm pretty sure > >> that's the problem. > >> > >> However it may take some time before we can fix it in repair mode. > >> > >> Thanks, > >> Qu > >> > >> > >> > >> =E5=9C=A8 2017=E5=B9=B407=E6=9C=8804=E6=97=A5 21:24, Filippe LeMarchan= d =E5=86=99=E9=81=93: > >>> Sure, here it is: > >>> https://drive.google.com/drive/folders/0B1ax9Am81gx9YjJBVVA0LXRHeGc > >>> > >>> In a letter dated Tuesday, July 4, 2017 16:16:36 MSK user Lu Fengqi w= rote: > >>>> On Mon, Jul 03, 2017 at 08:34:52AM +0800, Qu Wenruo wrote: > >>>>> > >>>>> > >>>>> At 07/01/2017 07:59 PM, Filippe LeMarchand wrote: > >>>>>> Hello everyone. > >>>>>> > >>>>>> I have an btrfs root partition on Intel 530 ssd, which mounts with= out errors and seem to work fine, > >>>>>> but `btrfs check` gives me foloowing output (and --repair doesn't = remove errors): > >>>>>> > >>>>>> enabling repair mode > >>>>>> Checking filesystem on /dev/sda2 > >>>>>> UUID: 12c84aa3-ce65-4390-807e-a72cc8a7445e > >>>>>> checking extents > >>>>>> Fixed 0 roots. > >>>>>> checking free space cache > >>>>>> cache and super generation don't match, space cache will be invali= dated > >>>>>> checking fs roots > >>>>>> unresolved ref dir 79177 index 0 namelen 14 name deprecated.sxt f= iletype 1 errors 6, no dir index, no inode ref > >>>>> > >>>>> This means that in dir whose inode number is 79177, it has a child = inode > >>>>> pointer pointing to depercated.sxt. > >>>>> > >>>>> But it doesn't have dir index and corresponding inode ref, which is= breaking > >>>>> the cross reference rule of btrfs. > >>>>> > >>>>> Would you please run the following command to dump needed info for = us to > >>>>> debug? > >>>>> > >>>>> # btrfs-debug-tree /dev/sda2 | grep 79177 -C 10 > >>>>> > >>>>> and > >>>>> > >>>>> # btrfs-debug-tree /dev/sda2 | grep deprecated.sxt -C 10 > >>>>> > >>>>> and > >>>>> > >>>>> # btrfs-debug-tree /dev/sda2 | grep deprecated.txt -C 10 > >>>>> > >>>>> > >>>>> Considering the output has both .txt and .sxt, I think that's the p= roblem. > >>>>> But such bit-flip should be detected by tree block csum. > >>>>> I'm not sure what's wrong with it. > >>>>> > >>>>> Thanks, > >>>>> Qu > >>>>> > >>>>>> unresolved ref dir 79177 index 417 namelen 14 name deprecated.txt= filetype 1 errors 1, no dir item > >>>>>> unresolved ref dir 79177 index 0 namelen 14 name deprecated.sxt f= iletype 1 errors 6, no dir index, no inode ref > >>>>>> unresolved ref dir 79177 index 417 namelen 14 name deprecated.txt= filetype 1 errors 1, no dir item > >>>>>> unresolved ref dir 79177 index 0 namelen 14 name deprecated.sxt f= iletype 1 errors 6, no dir index, no inode ref > >>>>>> unresolved ref dir 79177 index 417 namelen 14 name deprecated.txt= filetype 1 errors 1, no dir item > >>>>>> unresolved ref dir 79177 index 0 namelen 14 name deprecated.sxt f= iletype 1 errors 6, no dir index, no inode ref > >>>>>> unresolved ref dir 79177 index 417 namelen 14 name deprecated.txt= filetype 1 errors 1, no dir item > >>>>>> unresolved ref dir 79177 index 0 namelen 14 name deprecated.sxt f= iletype 1 errors 6, no dir index, no inode ref > >>>>>> unresolved ref dir 79177 index 417 namelen 14 name deprecated.txt= filetype 1 errors 1, no dir item > >>>>>> unresolved ref dir 79177 index 0 namelen 14 name deprecated.sxt f= iletype 1 errors 6, no dir index, no inode ref > >>>>>> unresolved ref dir 79177 index 417 namelen 14 name deprecated.txt= filetype 1 errors 1, no dir item > >>>>>> unresolved ref dir 79177 index 0 namelen 14 name deprecated.sxt f= iletype 1 errors 6, no dir index, no inode ref > >>>>>> unresolved ref dir 79177 index 417 namelen 14 name deprecated.txt= filetype 1 errors 1, no dir item > >>>>>> unresolved ref dir 79177 index 0 namelen 14 name deprecated.sxt f= iletype 1 errors 6, no dir index, no inode ref > >>>>>> unresolved ref dir 79177 index 417 namelen 14 name deprecated.txt= filetype 1 errors 1, no dir item > >>>>>> unresolved ref dir 79177 index 0 namelen 14 name deprecated.sxt f= iletype 1 errors 6, no dir index, no inode ref > >>>>>> unresolved ref dir 79177 index 417 namelen 14 name deprecated.txt= filetype 1 errors 1, no dir item > >>>>>> checking csums > >>>>>> checking root refs > >>>>>> found 23421812736 bytes used err is 0 > >>>>>> total csum bytes: 21531608 > >>>>>> total tree bytes: 776650752 > >>>>>> total fs tree bytes: 711278592 > >>>>>> total extent tree bytes: 36798464 > >>>>>> btree space waste bytes: 116002036 > >>>>>> file data blocks allocated: 850546470912 > >>>>>> referenced 27611987968 > >>>>>> > >>>>>> Is it dangerous and what should I do about it? > >>>>>> > >>>>>> I also tried --clear-space-cache, but it just removes the line abo= ut space cache. > >>>>>> > >>>>> > >>>>> > >>>>> -- > >>>>> To unsubscribe from this list: send the line "unsubscribe linux-btr= fs" in > >>>>> the body of a message to majordomo@vger.kernel.org > >>>>> More majordomo info at http://vger.kernel.org/majordomo-info.html > >>>> > >>>> I'm afraid that your mail may be rejected because the attachment size > >>>> exceeds the allowable limit(100kB) of btrfs mailing list. Could you > >>>> share the attachment by google drive? > >>>> > >>>> Lastly, while Qu's timing is too tight, I will assist you on this is= sue. > >>>> >=20 --nextPart3138102.tkaniBDuKa Content-Type: application/pkcs7-signature; name="smime.p7s" Content-Disposition: attachment; filename="smime.p7s" Content-Transfer-Encoding: base64 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 EwdTYWxmb3JkMRowGAYDVQQKExFDT01PRE8gQ0EgTGltaXRlZDE9MDsGA1UEAxM0Q09NT0RPIFJT QSBDbGllbnQgQXV0aGVudGljYXRpb24gYW5kIFNlY3VyZSBFbWFpbCBDQTCCASIwDQYJKoZIhvcN AQEBBQADggEPADCCAQoCggEBAL6znlesKHZ1QBbHOAOY08YYdiFQ8yV5C0y1oNF9Olg+nKcxLqf2 NHbZhGra0D00SOTq9bus3/mxgUsg/Wh/eXQ0pnp8tZ8XZWAnlyKMpjL+qUByRjXCA6RQyDMqVaVU kbIr5SU0RDX/kSsKwer3H1pT/HUrBN0X8sKtPTdGX8XAWt/VdMLBrZBlgvnkCos+KQWWCo63OTTq Rvaq8aWccm+KOMjTcE6s2mj6RkalweyDI7X+7U5lNo6jzC8RTXtVV4/Vwdax720YpMPJQaDaElmO upyTf1Qib+cpukNJnQmwygjD8m046DQkLnpXNCAGjuJy1F5NATksUsbfJAr7FLUCAwEAAaOCATww ggE4MB8GA1UdIwQYMBaAFLuvfgI9+qbxPISOre44mOzZMjLUMB0GA1UdDgQWBBSCr2yM+MX+lmF8 6B89K3FIXsSLwDAOBgNVHQ8BAf8EBAMCAYYwEgYDVR0TAQH/BAgwBgEB/wIBADARBgNVHSAECjAI MAYGBFUdIAAwTAYDVR0fBEUwQzBBoD+gPYY7aHR0cDovL2NybC5jb21vZG9jYS5jb20vQ09NT0RP UlNBQ2VydGlmaWNhdGlvbkF1dGhvcml0eS5jcmwwcQYIKwYBBQUHAQEEZTBjMDsGCCsGAQUFBzAC hi9odHRwOi8vY3J0LmNvbW9kb2NhLmNvbS9DT01PRE9SU0FBZGRUcnVzdENBLmNydDAkBggrBgEF BQcwAYYYaHR0cDovL29jc3AuY29tb2RvY2EuY29tMA0GCSqGSIb3DQEBDAUAA4ICAQB4XLKBKDRP PO5fVs6fl1bsj6JrF/bz9kkIBtTYLzXN30D+03Hj6OxCDBEaIeNmsBhrJmuubvyE7HtoSmR809Ag cYboW+rcTNZ/8u/Hv+GTrNI/AhqX2/kiQNxmgUPt/eJPs92Qclj0HnVyy9TnSvGkSDU7I5Px+TbO +88G4zipA2psZaWeEykgzClZlPz1FjTCkk77ZXp5cQYYexE6zeeN4/0OqqoAloFrjAF4o50YJafX 8mnahjp3I2Y2mkjhk0xQfhNqbzlLWPoT3m7j7U26u7zg6swjOq8hITYc3/np5tM5aVyu6t99p17b TbY7+1RTWBviN9YJzK8HxzObXYWBf/L+VGOYNsQDTxAk0Hbvb1j6KjUhg7fO294F29QIhhmiNOr8 4JHoy+fNLpfvYc/Q9EtFOI5ISYgOxLk3nD/whbUe9rmEQXLp8MB933Ij474gwwCPUpwv9mj2PMnX oc7mbrS22XUSeTwxCTP9bcmUdp4jmIoWfhQm7X9w/Zgddg+JZ/YnIHOwsGsaTUgj7fIvxqith7Do JC91WJ8Lce3CVJqb1XWeKIJ84F7YLXZN0oa7TktYgDdmQVxYkZo1c5noaDKH9Oq9cbm/vOYRUM1c Wcef20Wkyk5S/GFyyPJwG0fR1nRas3DqAf4cXxMiEKcff7PNa4M3RGTqH0pWR8p6EjCCBTIwggQa oAMCAQICEQDXdDjI2wGDsxF6weHvf8mUMA0GCSqGSIb3DQEBCwUAMIGXMQswCQYDVQQGEwJHQjEb MBkGA1UECBMSR3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHEwdTYWxmb3JkMRowGAYDVQQKExFD T01PRE8gQ0EgTGltaXRlZDE9MDsGA1UEAxM0Q09NT0RPIFJTQSBDbGllbnQgQXV0aGVudGljYXRp b24gYW5kIFNlY3VyZSBFbWFpbCBDQTAeFw0xNzA2MDgwMDAwMDBaFw0xODA2MDgyMzU5NTlaMCQx IjAgBgkqhkiG9w0BCQEWE2dhc2ludmVpbkBnbWFpbC5jb20wggEiMA0GCSqGSIb3DQEBAQUAA4IB DwAwggEKAoIBAQDIMvvH6x4GgcmPVYk/zAxFsdpSHo9zqW5CnI+fLlGLnEvn5TdcutXr0ToCsfeD MXPO5c+pmR9bHjQTYIYHb6WPA6xvxjv1ZO/YkGDmSaiA7wxDdOAmsJVgaqV/ijNCZZBRkxoEXNQb ABYij3fQYbcyoHEmT6lTu+AcBKf0M7yeclqSpwGABfco3/WLs7Dts4aDgsg2xxA/d2ZtU8+Bgw6J ePSysugO1/xjJFO9g/OZksOTdm1GaEp/XpCmzQp2YNFiBSzLbphowdryOAWj5ypwvm237rfO1vEk EUdrd/XXKQGs49lAzPcV4bZChnnrTR1BGJdZh3uWi/FO4XG55bA7AgMBAAGjggHpMIIB5TAfBgNV HSMEGDAWgBSCr2yM+MX+lmF86B89K3FIXsSLwDAdBgNVHQ4EFgQUrzUVgwSsp6awdPonAkbSCzmP LdQwDgYDVR0PAQH/BAQDAgWgMAwGA1UdEwEB/wQCMAAwIAYDVR0lBBkwFwYIKwYBBQUHAwQGCysG AQQBsjEBAwUCMBEGCWCGSAGG+EIBAQQEAwIFIDBGBgNVHSAEPzA9MDsGDCsGAQQBsjEBAgEBATAr MCkGCCsGAQUFBwIBFh1odHRwczovL3NlY3VyZS5jb21vZG8ubmV0L0NQUzBaBgNVHR8EUzBRME+g TaBLhklodHRwOi8vY3JsLmNvbW9kb2NhLmNvbS9DT01PRE9SU0FDbGllbnRBdXRoZW50aWNhdGlv bmFuZFNlY3VyZUVtYWlsQ0EuY3JsMIGLBggrBgEFBQcBAQR/MH0wVQYIKwYBBQUHMAKGSWh0dHA6 Ly9jcnQuY29tb2RvY2EuY29tL0NPTU9ET1JTQUNsaWVudEF1dGhlbnRpY2F0aW9uYW5kU2VjdXJl RW1haWxDQS5jcnQwJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmNvbW9kb2NhLmNvbTAeBgNVHREE FzAVgRNnYXNpbnZlaW5AZ21haWwuY29tMA0GCSqGSIb3DQEBCwUAA4IBAQC2YT8zrjNlQIP1roMw sopvoUtJO/yDAP5M4GPdkS2VQc+gVygV2OhjyHCZcdBBgUwtMpNivjxcqjWtSYh6F5pernYPZXtz cMn9oYG6S7H9JmKDYObF0w6WadMUAdbpnSJD2MydLsjOTE5timdd42ncTkZq3dVICCHSvXMs5sJG DaQo3Vha5ECosxs9zC6wmDRlBghLeTppq/d1HHCksSkhUlCHEorNqEFm+hB1FHh/1akSVT8/GdRd 1f2IGsOZDSZCcBdR5c2wLz9RqwEQmuV6MUqeVRLuKRg1C27lhpCPmEeq+Y8LHNOFeT1P/uL0VVDM skktNX6qc13tni1zDzZAMYICbzCCAmsCAQEwga0wgZcxCzAJBgNVBAYTAkdCMRswGQYDVQQIExJH cmVhdGVyIE1hbmNoZXN0ZXIxEDAOBgNVBAcTB1NhbGZvcmQxGjAYBgNVBAoTEUNPTU9ETyBDQSBM aW1pdGVkMT0wOwYDVQQDEzRDT01PRE8gUlNBIENsaWVudCBBdXRoZW50aWNhdGlvbiBhbmQgU2Vj dXJlIEVtYWlsIENBAhEA13Q4yNsBg7MResHh73/JlDANBglghkgBZQMEAgEFAKCBkzAYBgkqhkiG 9w0BCQMxCwYJKoZIhvcNAQcBMBwGCSqGSIb3DQEJBTEPFw0xNzA3MTIxMzExMjNaMCgGCSqGSIb3 DQEJDzEbMBkwCwYJYIZIAWUDBAECMAoGCCqGSIb3DQMHMC8GCSqGSIb3DQEJBDEiBCD2KT9IetLx yYOjTy0FyqWxm70OYULkwg3/BTvZLSbMfTANBgkqhkiG9w0BAQEFAASCAQCUl1pPMVVrbLiTTwtH zDXHa2gF9dAGj7t6Z8ggXY0I67SoXoc+juk+m5vEm/zfL4Gga2uibg09LyyrZCjL6m7B2rHbnsQh aFUAVs/A2qgxNJbLGWtew0P3LHaIfUGVXqWayQFn3GXL9x8fbvmUfeQgoM2jQ3wcwSYxmKHRvOy7 M3EJZCs+cZkO/0iqDQL+wVgHeKZRcJqrslDxh4nOy/L+KFzBpSIOlsOX8qWx8nr/ov9uj83iXLqF uXYUopIss789Y0uBDCIxuZmJYfspZG+VoER4nr0gLhfwBw2SzbP9gUWAz45etJN9vzJ0lSzKXYJz gdcK2hzpJUpGtHYwuVJJAAAAAAAA --nextPart3138102.tkaniBDuKa--