Re: kernel crash after enable ecryptfs under abnormal power off

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 2014-06-10 22:13:22, Hanks Wang wrote:
> 
> Hi Tyler,
> 
> It happened kernel crash if we enable ecryptfs in kernel-space and
> mount ecryptfs in the user-space if we reboot device after the
> device is powered off abnormally, such as the device is pulled off
> power line. At the same time, if we normally power off the device
> and reboot it, it works well. I don't try this case on the computer
> device, it just happened on my own mobile device, because I want to
> use ecryptfs on the mobile area.
> 
> I also read your formal mail thread about kernel crash
> http://lkml.iu.edu/hypermail/linux/kernel/1203.1/03801.html, which
> seems to be crashed on the same line. Actually, I used the parameter
> of ecryptfs_passthrouth to enable plain test readable. Could you
> kindly give me some suggestion about how to quick debug or resolve
> this problem?

You don't want to enable ecryptfs_passthrough. That will treat the file
as a plaintext file and writes to the file won't be encrypted. I doubt
that's what you want.

> My method to mount ecryptfs file system is following:
> 
> mount -t ecryptfs ~/encrypt  ~/encrypt  -o ecryptfs_key_bytes=32 -o
> ecryptfs_cipher=aes -o no_sig_cache -o passphrase_passwd=%s -o
> ecryptfs_enable_filename_crypto=n  -o ecryptfs_passthrough -o
> key=passphrase
> 
> 
> Detail crash information is:
> --------------------------------------------------------------------------------------------------
> [   87.924154] c3 kernel BUG at /home/abuild/rpmbuild/BUILD/kernel-pachira-3.4.5/kernel/fs/ecryptfs/crypto.c:464!
> [   87.934258] c3 Internal error: Oops - BUG: 0 [#1] PREEMPT SMP ARM
> [   87.940376] c3 Modules linked in: ittiam mali(O) ump(O)
> [   87.945661] c3 CPU: 3    Tainted: G           O  (3.4.5 #1)
> [   87.951261] c3 PC is at ecryptfs_encrypt_page+0x34/0x390
> [   87.956646] c3 LR is at ecryptfs_writepage+0x4c/0x9c
> [   87.961623] c3 pc : [<c0202a4c>]    lr : [<c0201574>]    psr: 40070013
> [   87.961635] c3 sp : c37d3c50  ip : c37d3ce0  fp : c37d3cdc
> [   87.973668] c3 r10: 00000000  r9 : db6f1948  r8 : c0fb1874
> [   87.979199] c3 r7 : c0fb1874  r6 : dc914840  r5 : dc914918  r4 : dc9149c4
> [   87.985985] c3 r3 : 00000003  r2 : c37d3ce0  r1 : c37d3e40  r0 : c0fb1874
> [   87.992836] c3 Flags: nZcv  IRQs on  FIQs on  Mode SVC_32  ISA
> ARM Segment kernel
> [   88.000477] c3 Control: 10c53c7d  Table: 9b6ec06a  DAC: 00000015
> [   88.006497] c3
> [   88.006503] c3 PC: 0xc02029cc:
> [   88.011351] c3 29cc  e0614004 ea000003 e3560000 e0855004 15834008
> e3a04000 e2800001 e2833010
> [   88.019773] c3 29ec  e1500007 a3a02000 b3a02001 e3540000 d3a02000
> e3520000 1affffd9 e3540000
> [   88.028275] c3 2a0c  c3e0000b e89daff8 c0bea5d0 e1a0c00d e92ddff0
> e24cb004 e24dd064 e92d4000
> ......
> 
> [   89.134149] c3 [<c0202a4c>] (ecryptfs_encrypt_page+0x34/0x390)
> from [<c0201574>] (ecryptfs_writepage+0x4c/0x9c)
> [   89.134173] c3 [<c0201574>] (ecryptfs_writepage+0x4c/0x9c) from
> [<c00e2a58>] (__writepage+0x24/0x48)
> [   89.134195] c3 [<c00e2a58>] (__writepage+0x24/0x48) from
> [<c00e305c>] (write_cache_pages+0x2f4/0x404)
> [   89.134215] c3 [<c00e305c>] (write_cache_pages+0x2f4/0x404) from
> [<c00e31bc>] (generic_writepages+0x50/0x6c)
> [   89.134234] c3 [<c00e31bc>] (generic_writepages+0x50/0x6c) from
> [<c00e4934>] (do_writepages+0x3c/0x48)
> [   89.134255] c3 [<c00e4934>] (do_writepages+0x3c/0x48) from
> [<c0143ca8>] (writeback_single_inode+0x1c4/0x40c)
> [   89.134276] c3 [<c0143ca8>] (writeback_single_inode+0x1c4/0x40c)
> from [<c0144200>] (writeback_sb_inodes+0x15c/0x214)
> [   89.134295] c3 [<c0144200>] (writeback_sb_inodes+0x15c/0x214)
> from [<c014432c>] (__writeback_inodes_wb+0x74/0xc0)
> [   89.134315] c3 [<c014432c>] (__writeback_inodes_wb+0x74/0xc0)
> from [<c0144538>] (wb_writeback+0x1c0/0x364)
> [   89.134333] c3 [<c0144538>] (wb_writeback+0x1c0/0x364) from
> [<c0144bd4>] (wb_do_writeback+0xf8/0x26c)
> [   89.134352] c3 [<c0144bd4>] (wb_do_writeback+0xf8/0x26c) from
> [<c0144e34>] (bdi_writeback_thread+0xec/0x2e4)
> [   89.134373] c3 [<c0144e34>] (bdi_writeback_thread+0xec/0x2e4)
> from [<c005f3d8>] (kthread+0x9c/0xa8)
> [   89.134393] c3 [<c005f3d8>] (kthread+0x9c/0xa8) from [<c000ff54>]
> (kernel_thread_exit+0x0/0x8)
> [   89.134408] c3 Code: e2864f61 e5963184 e3130004 1a000000 (e7f001f2)

This is a tough one to solve correctly. There's a small amount of time
between eCryptfs creating the file in the lower filesystem and eCryptfs
initializing that file with its metadata. Your device was likely shut
off between those two events.

I see that you're running kernel 3.4.5. In 3.5, I added a (somewhat
ugly) workaround for problems like this:

  e3ccaa9 eCryptfs: Initialize empty lower files when opening them

I think it would solve your problem if you didn't mount with
ecryptfs_passthrough. However, when ecryptfs_passthrough is used,
eCryptfs can't make an assumption about whether an uninitialized lower
file should be turned into an eCryptfs file or if it should remain as a
plaintext file.

Tyler

Attachment: signature.asc
Description: Digital signature


[Index of Archives]     [Linux Crypto]     [Device Mapper Crypto]     [LARTC]     [Bugtraq]     [Yosemite Forum]

  Powered by Linux