Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Incorrect parsing of "meta" box for screen recording file with Quicktime #309

Open
vjeux opened this issue Jan 4, 2023 · 20 comments
Open

Comments

@vjeux
Copy link

vjeux commented Jan 4, 2023

I saved a screen recording mp4 file with sound with Quicktime (mp4_with_sound.mov.zip). If you open this file in the filereader.html, you can see this in the console:

[BoxParser] 'meta' box writing not yet implemented, keeping unparsed data in memory for later write
[BoxParser] Box of type '����' has a size 1751411826 greater than its container size 134
[BoxParser] Parsing of box 'meta' did not read the entire indicated box data size (missing 126 bytes), seeking forward
@selsamman
Copy link

I am getting a similar error with any video shot on the Samsung Galaxy S10. In my case as far as I can tell segmenting still works and the moov box is found and seems reasonable. I am able to stream the segments over WebRTC to MSE in a browser. And BTW this is an absolutely awesome package. Using the latest version of mp4box.js

[0:00:00.001] [ISOFile] Processing buffer (fileStart: 0)
[0:00:00.002] [BoxParser] Unknown box type: 'SDLN'
[0:00:00.003] [BoxParser] 'SDLN' box writing not yet implemented, keeping unparsed data in memory for later write
[0:00:00.003] [BoxParser] Unknown box type: 'smrd'
[0:00:00.003] [BoxParser] 'smrd' box writing not yet implemented, keeping unparsed data in memory for later write
[0:00:00.003] [BoxParser] Unknown box type: '©xyz'
[0:00:00.003] [BoxParser] '©xyz' box writing not yet implemented, keeping unparsed data in memory for later write
[0:00:00.003] [BoxParser] Unknown box type: 'smta'
[0:00:00.003] [BoxParser] 'smta' box writing not yet implemented, keeping unparsed data in memory for later write
[0:00:00.003] [BoxParser] 'meta' box writing not yet implemented, keeping unparsed data in memory for later write
[0:00:00.003] [BoxParser] Box of type '' has a size 1751411826 greater than its container size 165
[0:00:00.003] [BoxParser] Parsing of box 'meta' did not read the entire indicated box data size (missing 157 bytes), seeking forward
[0:00:00.005] [BoxParser] 'colr' box writing not yet implemented, keeping unparsed data in memory for later write
[0:00:00.006] [BoxParser] 'esds' box writing not yet implemented, keeping unparsed data in memory for later write
[0:00:00.008] [ISOFile] Done processing buffer (fileStart: 0) - next buffer to fetch should have a fileStart position of 5944036
[0:00:00.008] [MultiBufferStream] 1 stored buffer(s) (3436/5944036 bytes), continuous ranges: [0-5944035]
[0:00:00.008] [ISOFile] Sample data size in memory: 0
[0:00:00.008] [ISOFile] Flushing remaining samples
[0:00:00.008] [MultiBufferStream] 1 stored buffer(s) (3436/5944036 bytes), continuous ranges: [0-5944035]

@davemevans
Copy link
Contributor

The problem seems to be that the ISOBMFF and QTFF specifications define the meta box differently.

The ISOBMFF spec defines meta as FullBox, having flags and version fields after the box type, and mp4box.js parses it as such.

The QTFF spec defines meta as an atom (functionally identical to an ISOBMFF Box), so mp4box.js parses it incorrectly and gets confused about what comes next.

I'm not sure if QTFF is supposed to be supported in mp4box.js, or what should happen when the two differ in definition.

Likely related: #120

@vjeux
Copy link
Author

vjeux commented Jan 20, 2023

@davemevans great investigation work! Is there a way to distinguish which version we are using? If not, we could try to parse using one format and if it doesn't fit the number of bytes try parsing using the second format. It's not ideal but would work.

@bradh
Copy link
Contributor

bradh commented Apr 1, 2023

We could just bail after the ftyp box if we find a major brand for quicktime.

@tobiasBora
Copy link

Same error here for video taken with a Samsung XCover:

[0:00:11.885] [BoxParser] Box of type '' has a size 1751411826 greater than its container size 165

@jozefchutka
Copy link

jozefchutka commented Sep 14, 2023

I have the same error with video taken with Xiaomi phone and mp4box.js 0.52

[0:00:00.009] [BoxParser] Box of type '����' has a size 1751411826 greater than its container size 225
General
Format                                   : MPEG-4
Format profile                           : Base Media / Version 2
Codec ID                                 : mp42 (isom/mp42)
File size                                : 77.4 MiB
Duration                                 : 31 s 667 ms
Overall bit rate                         : 20.5 Mb/s
Frame rate                               : 30.000 FPS
Encoded date                             : 2023-08-30 10:22:20 UTC
Tagged date                              : 2023-08-30 10:22:20 UTC
com.android.version                      : 13
com.android.manufacturer                 : Xiaomi
com.android.model                        : M2101K6G

@RufaelDev
Copy link

RufaelDev commented Oct 12, 2023

Yes I observed the same issue as @davemevans 2 years ago filming on my mobile device (huawei p30 lite), many android phones still output quicktime type metabox, but files do not include the brand in the ftyp box (at least mine didnt).

@RufaelDev
Copy link

RufaelDev commented Oct 12, 2023

14496-12 defines meta as FullBox('meta', version = 0, 0), so maybe the best way to parse meta to look at the bytes following meta, if it is zero it is an isobmff box, if it is not it is a new box enclosed in the quicktime meta box (non full box) ? does it make sense ? I do not think the brand in ftyp will work as it is usually not set.

@bradh
Copy link
Contributor

bradh commented Oct 12, 2023

14496-12 defines meta as FullBox('meta', version = 0, 0), so maybe the best way to parse meta to look at the byte following meta, if it is zero it is an isobmff box, if it is not it is a new box enclosed in the quicktime meta box (non full box) ? does it make sense ? I do not think the brand in ftyp will work as it is usually not set.

I'm not sure that will work. What is the byte following meta in your quicktime sample? If its another box, it'll start with a four byte length, and the most likely first byte in that length is 0.

@RufaelDev
Copy link

RufaelDev commented Oct 12, 2023

@bradh you need to check 4 bytes, it will be zero for fullbox (isobmff) and non zero for quicktime box (hdlr) (bigendian 32 bit interpretation), sorry typed byte instead of bytes ;-)

@bradh
Copy link
Contributor

bradh commented Oct 12, 2023

Possible. Does quicktime use 0x00 0x00 0x00 0x00 in the same way as the ISO BMFF - to mean "to end of file"?

@RufaelDev
Copy link

@bradh I don't believe that syntax is explicitly defined, but my main point here is the difference in syntax between the metaBox from QuickTime and the MetaBox from ISOBMFF. So far no version or flags are specified for the ISOBMFF version so the typical syntax would be sizemeta0x00 0x00 0x00 0x00 for the isobmff and size meta [4 bytes > 0] for the QuickTime MetaBox.

@bradh
Copy link
Contributor

bradh commented Feb 4, 2024

https://issuetracker.google.com/issues/232971800 indicates that Google are going to keep doing this. They suggest a slightly different work around to parsing based on checking for hdlr 4cc.

@stefwalter
Copy link

I've started a set of extensions to MP4Box.js which solves this problem for me: https://github.com/stefwalter/qtffbox.js

Am I correct in assuming that such QuickTime support is outside of MP4Box.js's scope?

@rbouqueau
Copy link
Member

Am I correct in assuming that such QuickTime support is outside of MP4Box.js's scope?

I'd say it is in scope since the main GPAC support QT. As a consequence community contributions are always welcome :)

Do you feel your code should be integrated in this repo (preferred option for maintenance)? Or should we reference it from the doc?

@stefwalter
Copy link

Am I correct in assuming that such QuickTime support is outside of MP4Box.js's scope?

I'd say it is in scope since the main GPAC support QT. As a consequence community contributions are always welcome :)

Awesome.

Do you feel your code should be integrated in this repo (preferred option for maintenance)? Or should we reference it from the doc?

Yes, I'd be happy for integrating into this repo. How about I work on a pull request and we can discuss specifics there?

@rbouqueau
Copy link
Member

I guess a PR would be perfect. @DenizUgur ?

@DenizUgur
Copy link
Member

I agree, if you open a PR I'll be happy to go over it.

@stefwalter
Copy link

I agree, if you open a PR I'll be happy to go over it.

Thanks. I'm working on it. But stuck on #357 before I can contribute.

@DenizUgur
Copy link
Member

The conformance files should be accessible from here:

https://github.com/MPEGGroup/FileFormatConformance/tree/main/data%2Ffile_features%2Fpublished%2Fisobmff

The repository is due for an update on the tests but in the meantime don't hesitate to open the PR for a review.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

10 participants