Open Bug 1192544 Opened 9 years ago Updated 2 years ago

Nested XML <!ENTITY> definitions in XML/SVG attributes can cause crash due to OOM

Categories

(Core :: DOM: HTML Parser, defect)

defect

Tracking

()

People

(Reporter: filippogasbarro, Unassigned)

References

(Depends on 1 open bug, Blocks 1 open bug)

Details

(4 keywords)

Attachments

(4 files)

User Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/44.0.2403.130 Safari/537.36 Steps to reproduce: I create a simple html page which contains the bugged "data:image" URI in <img> tag. Obviously it can be added to any web page, and the result is the same. <html> <head> <meta charset="utf-8" /> <title>Your browser just crashed</title> </head> <body> <img alt="exploit" src=""></img> </body> </html> Actual results: The web browser and the system could to crash if you have a little RAM memory because the browser write in RAM a lot of data and generate a lot of I/O with the HDD/SSD. This exploit could be very dangerous also for who has a lot of RAM if it is exploited well; for example with the automatic opening of other tab or pop-up with this html code. This exploit is more dangerous in GNU/linux because write in RAM about 2 GB of data instead on Windows about 400 MB. Expected results: The web browser could ignore this content inside the <img> html tag to prevent the crash of the web browser or the system
Severity: normal → major
Component: Untriaged → Security
Keywords: crash
This is just a memory bomb, not exploitable except to annoy someone. Daniel: is there any reasonably limits we could put on SVG to give up before we get to this point? or is it safer to just let the memory allocator fail-safe death happen?
Group: core-security
Status: UNCONFIRMED → NEW
Component: Security → SVG
Ever confirmed: true
Flags: needinfo?(dholbert)
Product: Firefox → Core
Attached image svg_from_b64.svg (deleted) —
(In reply to Daniel Veditz [:dveditz] from comment #1) > This is just a memory bomb, not exploitable except to annoy someone. > > Daniel: is there any reasonably limits we could put on SVG to give up before > we get to this point? or is it safer to just let the memory allocator > fail-safe death happen? So, there's no point in having any SVG-specific limits here, because there's nothing SVG-specific about this. The testcase is basically just a series of elements with extremely long attribute-values (using XML entities as a trick to get extremely long values without needing much markup). You can do the exact same thing with XHTML. [Testcase coming up.] To the extent that we want to avoid this with limits, we'd need to place a limit on the length of an attribute-value, and/or a limit on the length of the document. I can imagine semi-legitimate content running up against those limits, though -- e.g. suppose a site stores an uploaded file as a base64 data URI in an attribute somewhere, and a user uploads a largeish file. We could avoid breaking those edge cases by making the limit arbitrarily huge, but that prevents us from getting any wins here, too. So, I don't know that there's much we can do here. Reclassifying as an HTML Parser bug, since we're OOM'ing in parser code. Here's a crash report that I generated from original testcase (quoted in comment 0), to demonstrate that: bp-1adb3951-2b22-43f9-9a80-a9a972150811
Component: SVG → HTML: Parser
Flags: needinfo?(dholbert)
Version: unspecified → Trunk
One other solution here might be to avoid expanding XML entities (or nested XML entities) beyond a certain length. That would make it harder for attackers to construct such a small testcase that triggers an OOM via this route. I think this might be what Chrome does -- they immediately bails on rendering either testcase, and report an XML error for an "entity reference loop". Though there's not actually a "loop" -- they seem to report this error for any nested <!ENTITY> expansion that surpasses a certain length.
This is basically the same issue as bug 616361, I think. The crash is a different place -- in bug 616361, it looks like we crash in layout, when we try to deal with a huge amount of text (based on bug 616361 comment 1). In this bug here, we crash in parsing, due to huge attribute-values. But the underlying cause is the same - nested ENTITY values being huge.
Depends on: 616361
Summary: An <img> html tag could crash the web browser and the system → Nested XML <!ENTITY> definitions can cause crash/hang due to OOM
Summary: Nested XML <!ENTITY> definitions can cause crash/hang due to OOM → Nested XML <!ENTITY> definitions in XML/SVG attributes can cause crash due to OOM
Keywords: sec-other

Hi

The steps on this bug mention that in order to reproduce this bug a very slow old pc is needed with less than 2gb of ram, but i don´t have any machine that uses just 2gb of ram. Do you know if this issue can be resolved? the reporter has a deactivated account.

regards.

Flags: needinfo?(htsai)

(In reply to Pablo from comment #10)

Hi

The steps on this bug mention that in order to reproduce this bug a very slow old pc is needed with less than 2gb of ram, but i don´t have any machine that uses just 2gb of ram. Do you know if this issue can be resolved? the reporter has a deactivated account.

regards.

This is still reproducible when you open the test case attached in comment 6.

Flags: needinfo?(htsai)
Severity: major → S2

I can't actually reproduce the crash. I probably just have too much RAM. But even so, I don't think this is a major issue. It's just one of the many ways to produce an OOM. It would be nice to handle it better, but I don't think it's likely to come up in the real world by accident very often, if at all, and the only result is a content process crash (and possibly a slow system due to thrashing). But that's pretty easy to produce in any number of other ways too.

Severity: S2 → S3
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: