Bug 3467 - MCE 2005 can not record and play at the same time with a Samba Share
Summary: MCE 2005 can not record and play at the same time with a Samba Share
Status: RESOLVED FIXED
Alias: None
Product: Samba 3.0
Classification: Unclassified
Component: File Services (show other bugs)
Version: 3.0.21a
Hardware: Other Windows XP
: P3 normal
Target Milestone: none
Assignee: Samba Bugzilla Account
QA Contact: Samba QA Contact
URL:
Keywords:
Depends on: 3347
Blocks:
  Show dependency treegraph
 
Reported: 2006-01-30 16:46 UTC by jason qian (e-mail address couldn't be found)
Modified: 2006-04-20 08:28 UTC (History)
0 users

See Also:


Attachments
log.smbd for 3.0.21b test with MCE 2005 (winrar used) (616.20 KB, application/octet-stream)
2006-01-31 14:55 UTC, jason qian (e-mail address couldn't be found)
no flags Details
Patch (6.48 KB, patch)
2006-01-31 21:10 UTC, Jeremy Allison
no flags Details

Note You need to log in before you can comment on or make changes to this bug.
Description jason qian (e-mail address couldn't be found) 2006-01-30 16:46:04 UTC
Here is the problem:
1. Use a MCE (Microsoft Media Center) 2005 PC to record live TV and play at the same time, default it records into local hard drive. To record into a network share, you need install TweakMCE from Microsoft: http://www.microsoft.com/downloads/details.aspx?FamilyID=3400190a-511a-4a3a-9b89-524511a76f58&DisplayLang=en
And use TweakMCE, you can setup "Record" and "Watch" folder like "\\192.168.1.100\media", and restart Media Center application to refresh it, not restart MCE PC, because it will back to local disk after reboot.
2. Use a Linux 2.4.20 PC and Samba 3.0.21a, glibc 2.3.2 to setup a network share for MCE to store record files.
3. Then use MCE live TV, select Record to start recording.
4. Then you will see the MCE play is freezed.

But the MCE 2005 can record and play at the same time in local disk and Samba 3.0.11 seems work OK too.

So this seems a problem in Samba 3.0.21a.
Comment 1 Gerald (Jerry) Carter (dead mail address) 2006-01-31 07:36:34 UTC
Jason, please retest 3.0.21b.  We fixed a few significant file
sharing bugs and I'm curious whether or not that will help you.
Comment 2 jason qian (e-mail address couldn't be found) 2006-01-31 14:21:10 UTC
I test the 3.0.21b release with MCE 2005 today. It still freeze the play while recording to Samba Share.
Comment 3 Jeremy Allison 2006-01-31 14:24:27 UTC
Ok, can you get us a debug level 10 log from smbd whilst this is going on, as well as an ethereal trace between client and server ?
That would help a lot.
Thanks,
Jeremy.
Comment 4 jason qian (e-mail address couldn't be found) 2006-01-31 14:32:59 UTC
Here is smbstats for 3.0.21b, and I will send log.smbd and ethereal soon.

Samba version 3.0.21b
PID     Username      Group         Machine                        
-------------------------------------------------------------------

Service      pid     machine       Connected at
-------------------------------------------------------
media        10718   192.168.7.162  Tue Jan 31 14:19:39 2006

Locked files:
Pid          DenyMode   Access      R/W        Oplock           SharePath           Name
----------------------------------------------------------------------------------------
10718        DENY_WRITE 0x3019f     RDWR       LEVEL_II         /c/media   MSDVRMM_927466607_14848_131074.tmp   Tue Jan 31 14:19:41 2006
10718        DENY_ALL   0x0         RDONLY     NONE             /c/media   MSDVRMM_927466607_14848_131074.tmp   Tue Jan 31 14:19:41 2006
10718        DENY_NONE  0x3019f     RDWR       EXCLUSIVE+BATCH  /c/media   MSDVRMM_927466607_14848_131074   Tue Jan 31 14:19:41 2006
10718        DENY_NONE  0x20196     WRONLY     NONE             /c/media   Manual Recording__31_01_2006_13_26_07.dvr-ms   Tue Jan 31 14:19:41 2006
10718        DENY_NONE  0x20089     RDONLY     NONE             /c/media   Manual Recording__31_01_2006_13_26_07.dvr-ms   Tue Jan 31 14:19:41 2006

And here is the smbstats for 3.0.11 for compare:

Samba version 3.0.11
PID     Username      Group         Machine                        
-------------------------------------------------------------------

Service      pid     machine       Connected at
-------------------------------------------------------
media         8246   192.168.7.162  Tue Jan 31 12:02:03 2006
media         8246   192.168.7.162  Tue Jan 31 12:02:05 2006

Locked files:
Pid    DenyMode   Access      R/W        Oplock           Name
--------------------------------------------------------------
8246   DENY_NONE  0x30089     RDONLY     LEVEL_II         /c/media/MSDVRMM_927466607_131074_14848.tmp   Tue Jan 31 12:02:05 2006
8246   DENY_WRITE 0x3019f     RDWR       LEVEL_II         /c/media/MSDVRMM_927466607_131074_14848.tmp   Tue Jan 31 12:02:05 2006
8246   DENY_NONE  0x20089     RDONLY     NONE             /c/media/Manual Recording__31_01_2006_11_08_11.dvr-ms   Tue Jan 31 12:02:05 2006
8246   DENY_NONE  0x20196     WRONLY     NONE             /c/media/Manual Recording__31_01_2006_11_08_11.dvr-ms   Tue Jan 31 12:02:05 2006
8246   DENY_NONE  0x3019f     RDWR       EXCLUSIVE+BATCH  /c/media/MSDVRMM_927466607_131074_14848   Tue Jan 31 12:02:05 2006
Comment 5 Jeremy Allison 2006-01-31 14:46:47 UTC
Thanks for the quick response. The second entry in the share mode table with 3.0.21b is probably not valid - it's a placeholder being printed by mistake.
I really need the ethereal log and smbd debug level 10 to be sure though, thanks.
Jeremy.
Comment 6 jason qian (e-mail address couldn't be found) 2006-01-31 14:48:52 UTC
I did one more test and upload the log.smbd-3021b and ethereal trace (mce-3021b).
In this test, the first try to record somehow was rejected, and the second time try to record was started and play just freezed in MCE 2005 PC.
Comment 7 jason qian (e-mail address couldn't be found) 2006-01-31 14:49:03 UTC
I did one more test and upload the log.smbd-3021b and ethereal trace (mce-3021b).
In this test, the first try to record somehow was rejected, and the second time try to record was started and play just freezed in MCE 2005 PC.
Comment 8 jason qian (e-mail address couldn't be found) 2006-01-31 14:55:24 UTC
Created attachment 1715 [details]
log.smbd for 3.0.21b test with MCE 2005 (winrar used)
Comment 9 jason qian (e-mail address couldn't be found) 2006-01-31 14:57:49 UTC
I can not upload ethereal trace file, it is 9M after compresed. Pleaes tell me how to send it to you.
Comment 10 jason qian (e-mail address couldn't be found) 2006-01-31 14:59:52 UTC
Oh, it is 25M instead of 9M.
Comment 11 Jeremy Allison 2006-01-31 15:00:29 UTC
Can you put these files somewhere on the web I can fetch them from ?
Jeremy.
Comment 12 Jeremy Allison 2006-01-31 15:26:23 UTC
I'm looking at your smbd log at the moment, and I don't see any place it freezes yet. What does the client do when it freezes ? Can you still use a cmd.exe process to go into the Samba share and do a directory listing ? I need to understand more about the problem (also the network trace would really help :-).

Jeremy.
Comment 13 Jeremy Allison 2006-01-31 15:33:11 UTC
What kind of file system is mounted on /c/media... ? Just wondering ?
Jeremy
Comment 14 jason qian (e-mail address couldn't be found) 2006-01-31 15:42:08 UTC
The /c is mount on EXT3 file system in the Linux 2.4.20.

OK. I upload both the ethereal trace and smbd log in ftp2.infrant.com.
user: infrant_support
pass: starwars
Comment 15 jason qian (e-mail address couldn't be found) 2006-01-31 15:53:25 UTC
By the way, the 192.168.7.239 is the Samba Server.
Comment 16 jason qian (e-mail address couldn't be found) 2006-01-31 16:09:56 UTC
I still can use File explorer in MCE 2005 to browse the media share when MCE 2005 play freeze.
Comment 17 Jeremy Allison 2006-01-31 16:30:12 UTC
Ok, I've analysed your capture trace.
Very interesting. It doesn't look like a Samba bug.
Have you ever tried to do the same test against a remote Windows 2000
or 2003 server ?
What I'm seeing in the trace is that writes completely dominate reads.
ie. once you tell the mce to write the media file it just does nothing but streaming writes of 64k until the entrire file is completed. This is very efficient and almost certainly what you want (the incoming data from TV is very time critical and should take precedence over reads on being written onto disk). I'm willing to bet that against a Win2k or W2k3 server it would behave the same way.

Since 3.0.11 we've put a lot more work into making us look much more like a wk2 server, and I'm guessing that one of the initial protocol exchange parameters (max write size etc.) makes this difference. We're now identical to W2K.

I don't actually think this is a bug as we're probably behaving the same way as Windows does here, although if you could make an ethereal trace from 3.0.11 available I'd be able to check.

Jeremy.


Comment 18 jason qian (e-mail address couldn't be found) 2006-01-31 17:01:21 UTC
I upload the mce-3011 and mce-winxp to ftp2.infrant.com. Both of them have no problem for MCE 2005 play when recording.

I think the 3.0.21b just return something ??? when MCE try to open the file to read during recording. It seems the MCE 2005 try to open same file twice, one is for recording (write) another is for playing (read).
Comment 19 jason qian (e-mail address couldn't be found) 2006-01-31 17:12:40 UTC
FYI, change oplocks to 0 in Samba 3.0.21b does not resolve this problem.
Comment 20 Jeremy Allison 2006-01-31 17:40:03 UTC
Thanks, I'll take another look. I didn't see the open failing though. I'll look again. I appreciate your help on this. If it works against Windows then I guess we're doing something wrong..... although I need to understand what.
Jeremy.
Comment 21 Jeremy Allison 2006-01-31 18:27:13 UTC
Ok, I think I've now spotted the error. If it's what I think it is, it's 
in delete on close semantics and is *incredibly* subtle :-). We didn't correctly implement delete on close semantics in 3.0.11 so that's why it works there.
More debugging work to do....
Jeremy.
Comment 22 jason qian (e-mail address couldn't be found) 2006-01-31 18:52:57 UTC
Yes, there are 2 system temp/hidden files created as "delete on close" when MCE 2005 start recording. So do you mean the MCE 2005 try to open them (for playing) while Samba 3.0.21b try to delete on close?

And I can help on your debugging on this problem.
Comment 23 Jeremy Allison 2006-01-31 21:10:55 UTC
Created attachment 1716 [details]
Patch

Please apply this patch to 3.0.21b and retry. I think this will fix the bug.
Thanks a *lot* for your help on this one - it was *really* nasty to track down :-).
Not a show-stopper, so we won't be doing a 3.0.21c though.
Jeremy.
Comment 24 jason qian (e-mail address couldn't be found) 2006-02-01 11:26:25 UTC
I try the patch, it works pretty good with MCE 2005. I will do more test.

Thanks a lot. 
Comment 25 jason qian (e-mail address couldn't be found) 2006-02-01 11:30:43 UTC
One problem comes out is the MSDVRMM_* files are not deleted after close recordings.
Comment 26 Jeremy Allison 2006-02-01 11:49:31 UTC
Can you get me another ethereal trace (and level 10 debug log) with the new code in place please ? The .tmp files should be being deleted on close (they are in the
test code I wrote), so more info on fixing this would be helpful.
Jeremy.
Comment 27 jason qian (e-mail address couldn't be found) 2006-02-01 11:59:27 UTC
Each MCE recording makes 2 system temp file, one is MSDVRMM_*, another is MSDVRMM_*.tmp. Both of them shall be deleted after stop recording, which is the way mce-winxp do.

Without the patch, 3.0.21b will delete both of them correctly.
Comment 28 Jeremy Allison 2006-02-01 12:02:43 UTC
Yes I understand that, but I need to see the logs to see why this isn't being done (the trace would help also). If you can make them available at the same ftp site that would help.
Jeremy.
Comment 29 jason qian (e-mail address couldn't be found) 2006-02-01 12:23:29 UTC
OK. I upload the logsmbd-3021b-p1 and ethereal trace mce-3021b-p1 to ftp2.infrant.com.
Comment 30 Jeremy Allison 2006-02-01 15:27:12 UTC
Ok I see what the problem is. The file with delete-on-close set is held open by the client at the time the client disconnects. We treat disconnectin differently than ordinary close as we're always root at disconnect time, and so can't just arbitrarily delete a file marked delete on close (what if the user who did that shouldn't have rights to delete ?).
This is now the same issue as bug #3347 and needs to be fixed in the same way.
Jeremy.
Comment 31 jason qian (e-mail address couldn't be found) 2006-02-01 15:38:03 UTC
Is there a fix for #3347 now or will be a fix in the future? I see there is a special patch for #3347. Can I just use it?
Comment 32 Jeremy Allison 2006-02-01 15:42:12 UTC
That patch would work for you but would make generic Samba insecure. I'm working on a more correct fix but this will only be for 3.0.22.
Jeremy.
Comment 33 jason qian (e-mail address couldn't be found) 2006-02-01 15:49:10 UTC
I prefer to waiting for 3.0.22. Do you know when it will come out?
Comment 34 Jeremy Allison 2006-02-01 16:06:06 UTC
No date yet - probably 4 - 6 weeks, that's our usual schedule.
Jeremy.
Comment 35 Gerald (Jerry) Carter (dead mail address) 2006-04-20 08:28:00 UTC
fixes in 3.0.23pre1