[tor-bugs] #19316 [Applications/Tor Browser]: Make sure our updates are dealing with SSE requirement properly
Tor Bug Tracker & Wiki
blackhole at torproject.org
Mon Mar 13 22:12:31 UTC 2017
#19316: Make sure our updates are dealing with SSE requirement properly
-------------------------------------------------+-------------------------
Reporter: gk | Owner: tbb-
| team
Type: task | Status:
| needs_revision
Priority: Medium | Milestone:
Component: Applications/Tor Browser | Version:
Severity: Normal | Resolution:
Keywords: ff52-esr, tbb-7.0-must, | Actual Points:
TorBrowserTeam201703 |
Parent ID: | Points:
Reviewer: | Sponsor:
-------------------------------------------------+-------------------------
Comment (by boklm):
Replying to [comment:10 mcs]:
> Replying to [comment:7 boklm]:
> > Replying to [comment:1 mcs]:
> > > Similar to the minSupportedOSVersion update manifest attribute that
we added for the Mac OS 10.6 issue (see
https://trac.torproject.org/projects/tor/ticket/13047#comment:3), we
should add support for a new attribute such as: `minInstructionSet="SSE2"`
> >
> > I attached a first version of a patch to do that, but I did not test
it yet, so it may not work.
>
> It seems like we just need one attribute in the update manifest, e.g.,
minSupportedInstructionSet.
>
> Also, I think your patch is missing a !. Maybe just do something like:
> {{{
> if (!this.unsupported &&
update.hasAttribute("minSupportedInstructionSet")) {
> let minInstructionSet =
update.getAttribute("minSupportedInstructionSet");
> if (['MMX', 'SSE', 'SSE2', 'SSE3',
> 'SSE4A', 'SSE4_1', 'SSE4_2'].indexOf(minInstructionSet) >= 0) {
> try {
> this.unsupported = !Services.sysinfo.getProperty("has" +
minInstructionSet);
> } catch (e) {}
> }
> }}}
>
> (untested).
This looks better, thanks.
> > I think there will still be an issue with people upgrading to the new
ESR52 version from Tor Browser <= 6.5.1 (skipping the version that added
support for the minInstructionSet attribute), as their browser will not
know this attribute. If we want to avoid this, we will need to change the
`update_2` from the updates URL to `update_3` (similar to what we did in
#13047).
>
> Do we really need to change to update3? We are not changing the request
URL. We should add support for the new instruction set attribute to TB
6.5.2 and then advertise to older Windows browsers an update to 6.5.2.
Then, after that update is done, the 6.5.2 browser will recognize the new
attribute and make the appropriate instruction set check. Mozilla does
this kind of thing once in a while; they call it a step-wise update or
flag day or something ;)
I think we have no easy way to continue advertising 6.5.2 to older Windows
browsers after 7.0 is released, with what we use to generate the update
responses files. We can add support for that, but it will probably require
keeping a copy of the 6.5.2 mar files when generating update response
files for many of the future releases. I think an easier way to do that is
changing the update url to `update_3` in 6.5.2, and not advertising 7.0 in
`update_2`. We can also add `update_2` -> `update_3` redirects for the
Linux and OSX URLs so that Linux and OSX browsers are updated to the
latest version directly.
--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/19316#comment:11>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online
More information about the tor-bugs
mailing list