Hacker News new | past | comments | ask | show | jobs | submit login
Inside the Operating System Edward Snowden Used to Evade the NSA (wired.com)
303 points by Osiris on April 15, 2014 | hide | past | favorite | 81 comments



One important and often overlooked feature of Tails is when you shut it down it wipes your system memory/RAM using sdmem.

Your encrypted data and sensitive files are often accessible via memory forensics even if you shut your computer down. Including the websites you visited. Your encryption keys can be in your computers memory for weeks and is easily accessible via a memory dump.

This is why people say that with physical access your computer can always be owned. Even if it's encrypted. Tails is the only one I know that handles this attack vector by default.

https://tails.boum.org/contribute/design/memory_erasure/


Data can be retrieved from DRAM not after weeks (your claim is "even if you shut your computer down (...) Your encryption keys can be in your computers memory for weeks") but only

http://en.wikipedia.org/wiki/Cold_boot_attack

"in the seconds to minutes after power has been removed."

The reason is explained here:

http://en.wikipedia.org/wiki/Memory_refresh

And even the electrons from SRAM, which doesn't need refreshes and which was for decades not used as "RAM" in the computers will leak away without the power:

http://en.wikipedia.org/wiki/Static_random-access_memory

"SRAM exhibits data remanence but it is still volatile in the conventional sense that data is eventually lost when the memory is not powered."

Of course, if you never power off your computer but just reset it (the power is never cut off) or if you shut it down and immediately power it up the content of the RAM can really survive for much longer.


The original cold boot paper was released in 2008 and they only demonstrated the attack on DDR2 memory [1]. A paper published in 2013 [2] discussed cold boot on modern hardware.

"This study is based on 5 different computer systems. While we demonstrate that simple warm reset attacks (not cutting power) are effective even against DDR3 systems, we were not able to detect any data remanence for DDR3 after cold boots. Even cooling the RAM chips did not reveal data remanence beyond cold boots. This leads us to the claim that cold boot attacks relying on RAM remanence beyond cold boots are not possible against modern DDR3 RAM chips."

[1] https://www.usenix.org/legacy/event/sec08/tech/full_papers/h...

[2] http://www1.cs.fau.de/filepool/projects/coldboot/fares_coldb... (search for DDR3 to find the relevant sections)


Thanks, this is true. Encryption keys can exist in memory for up to a week [edit: or longer] in live memory with power on. This is well after they've been used on the machine, or say after you close your Truecrypt volumes. The vast majority of people rarely shutdown their laptops for extended periods of time and often just suspend to disk, instead of a full power-off.

This is why it's good to power down or sdmem when you're finished working with sensitive data.

On a full shutdown persistence is not as big of a risk, as the other commenter pointed out, cold boots are mitigated by DDR3 similar to how modern SSDs with TRIM make deleted data-recovery nearly impossible (such as Swap data which may also contain encryption keys).


> Encryption keys can exist in memory for up to a week in live memory with power on.

No. After some high-enough RAM area contained the keys and you keep it powered and your OS uses much less physical RAM than physically available there's no hard limit. Just forget the "week."


Updated comment for HN pedanticism.


You really should replace the words 'for up to a week' with 'indefinitely'. Mentioning a time limit at all is misleading in that context. This isn't pedantry: it's mere correctness.


Why would the encryption keys sit around in RAM? Properly designed cryptographic software wipes the keys when they are no longer needed.


In real life, keys actually can unintentionally remain in RAM even if in the ideal case they shouldn't. And you want more than just the keys to be wiped: your secrets you want to keep, the reason you decided to use Tails. And the fact that the Tails cares about implementing RAM wiping is the top post from dmix.


They use memtest=n kernel parameter now instead of sdmem https://tails.boum.org/blueprint/more_efficient_memory_wipe/...

I don't really trust their tests, but DDR3 memory kind of makes this attack useless. The $FEDAGENCY also plans arrests so you're cuffed with everything turned on and no way to push buttons or yank out cables like Ross Ulbricht or Max Vision


Tails (The Amnesic Incognito Live System) http://en.wikipedia.org/wiki/The_Amnesic_Incognito_Live_Syst..., a Debian fork which forces Tor for all outgoing and incoming connections. Designed to be run from read-only media.


More info on their relationship with Debian: https://tails.boum.org/contribute/relationship_with_upstream

"For various reasons Tails tries to diverge by the smallest possible amount from its upstream projects, and especially from Debian"

"We try to push our changes upstream when we need to modify software we ship. This often requires us to write code in a generic way, rather than implementing ad-hoc hacks to fit our specific needs: e.g. we often need to make the stuff we need opt-in and add configuration options."

The official term for this is "Debian derivative" rather than "fork."


So, is this proof that tor is not completely subverted by the NSA? Recent articles here claim that the NSA has been deploying numerous nodes and can analyze traffic from multiple nodes to compromise the user.

Or is this proof of tor being better than nothing?


The latter. The NSA didn't have to analyze anything: Snowden was not a known target, and he revealed himself before any real manhunt or mass-analysis had started.


Impressive how much thought and work has gone into Tails development, e.g. it has a surprisingly-convincing XP skin that hides the fact you're even using Linux to the casual observer. Kudos to the devs.


It's called GNOME 2 and it feels exactly like you're using Linux, which is a great feeling. Kudos to the devs.

Edit: apparently I was mistaken. GNOME 2 is the default desktop, but there is an XP skin. See comments below.


GP is referring to XP Camoflauge option in Tails.

http://www.bitblokes.de/wp-content/uploads/2013/02/tails-0-1...


Oh I see.. I just skimmed the Wikipedia article. That is very interesting. Would come in handy in an environment where your superiors are looking over your shoulder. I guess it can't be that bad of an experience since it's Linux underneath.


Except now seeing an XP desktop in a corporate environment will raise eyebrows as its officially dead.

No Win7 skin?


A more cynical person would say you've not worked in many corporate environments ;)


Good thing there are no cynics here. ;) x2


Hi! I am writing this on my win Xp desktop from my corporate offices. Nice to meet you


You can hack SD cards actually unlike the article states, Bunny's blog post and presentation at Chaos Computer Congress mentions of this possibility. SD cards have microcontrollers and with enough resources their guess flash media can be subverted. Diversity of these controllers and variety of "proprietary" standards the way these flash controllers work however can be the entropy that makes SD controller hacking very unlikely - but you never know.

http://www.bunniestudios.com/blog/?p=3554

my 2c


also, in your hdd controller(s) http://spritesmods.com/?art=hddhack.

same stuff, too many cpu everywhere, making protocols meaningless.


And Macbooks can be hacked through the battery https://news.ycombinator.com/item?id=2796264


It's worth noting that Tails doesn't make you impervious. Tails uses Tor, and Tor is vulnerable to NSA and GCHQ attacks. Specifically, they have the capability of deanonymizing individual targets. I hypothesize that this capability works by monitoring Tor traffic worldwide, then performing a timing correlation between an origin and an endpoint.

Here's an example: Let's say (for the sake of example please) that the NSA can passively monitor Google searches in realtime. Let's say you search for a phrase that sets off their monitor: something like "a Tor user has Googled for Snowden." They'd like to know who you are. How would they do that?

One way is to record the fact that from your home computer originated some Tor traffic at almost the same time the Google search took place.

It's unclear exactly how they deanonymize Tor users, but one piece of info that may corroborate my hypothesis is that in a Snowden screenshot, you can see the NSA has a tab called "Tor Events" in one of their tools.

The need for websites to load quickly is Tor's Achilles heel, because it enables timing correlation. The fact that few people use Tor exacerbates the problem.


I think you mean to say that users of Tor are potentially vulnerable to NSA and GCHQ attacks. Specifically, they lack the capability to deanonymize individual targets upon request and according to the slides leaked by Snowden they are only able to deanonymize a very small fraction of the traffic and usually have to rely on attacking surrounding software, such as the Firefox browser bundled with Tor.

http://www.theguardian.com/world/2013/oct/04/nsa-gchq-attack...


https://tails.boum.org/doc/about/warning/index.en.html#index...

"Tor doesn't protect you from a global adversary

A global passive adversary would be a person or an entity able to monitor at the same time the traffic between all the computers in a network. By studying, for example, the timing and volume patterns of the different communications across the network, it would be statistically possible to identify Tor circuits and thus matching Tor users and destination servers.

It is part of Tor's initial trade-off not to address such a threat in order to create a low-latency communication service usable for web browsing, Internet chat or SSH connections.

For more expert information see Tor Project: The Second-Generation Onion Router, part 3. Design goals and assumptions. [https://svn.torproject.org/svn/projects/design-paper/tor-des...


> One way is to record the fact that from your home computer originated some Tor traffic at almost the same time the Google search took place.

This either implies someone already suspects you and are monitoring you or that you are the only person searching on Google using Tor at that particular moment. I find the latter hard to believe. Even if it is true, it can be mitigated by more people using tor at the same time.


You might want to run a non-exit node at your home. That way you have a lot of Tor traffic all the time, and the one time you really do need anonymity, it doesn't show up as anything unusual.


I don't quite know how this works, so forgive me if this is a stupid question, but couldn't someone just take the difference between your inbound and outbound tor traffic to find how much traffic originates from your computer?


If the in/out rate of your bridge was both constant And lower than the max in/out rate of your connection, but it seems a bit of a stretch.

(And of course they wouldn't know that it was your traffic to whatever site they're surveilling, they'd just have evidence that was not inconsistent with you actively using Tor to do Something Or Other at that time.)


They might know how much, but they wouldn't know which traffic was yours.


The same is still true even if you do not run a tor node.


They can see all of the packets in both directions. Which mean they could tell when more was coming out than being relayed in.


Yes, because nothing will make you less interesting to law enforcement than running a Tor node.


Google searching no, but an IRC room or being logged into something would be good for metadata. Especially a forum or chat room where you reveal timezone or other geolocation info. "It's snowing here"

Would not take long to grep ISP logs and find the known Tor bridges, Obfsproxy bridges, relays and who might have used them.

If you tunneled Tor traffic through a VPN exiting Russia then your local ISP has no Tor timing metadata to give, unless you're Snowden and your adversary is global. Running an internal relay would help obfuscate your own traffic too if you can connect to it on a local network it would be a lot harder to prove you logged into IRC channel #blowuptheembassy on the Al Qaeda IRC freenode server.


> Tails doesn't make you impervious

For all X, X does not make you impervious. All it can do is increase the cost to an attacker.


Has anyone looked into thwarting timing attacks by using Selenium to run web tasks at random times?


Another Debian based boot-from-CD OS that used to be quite popular is Knoppix [1]. I remember that was a big thing in the times of Win98 viruses when people used it for system recovery. In Germany they distributed it as add-on to computer magazines.

[1] https://en.wikipedia.org/wiki/Knoppix


Knoppix was my first introduction to Linux. The boot-from-CD aspect amazed me. At first the only thing I used it for was recovering data from a screwed up Windows install but eventually I got more into it and started installing other distress (starting with Ubuntu I think).


For some perspective, this was back in the days where it was actually quite a bit of work to get get linux configured and running correctly on your at home desktop. Knoppix was quite a miracle.


Knoppix came out in 2000, a lot of time had passed since it was "actually quite a bit of work to get get linux configured and running correctly on your at home desktop." If you were mot using a thinkpad or ibook a laptop could still cause some trouble.


I started using linux around 2004 and it still required quite a lot of technical knowledge to get working. Drivers were a big issue around sound, graphics, and network.


What I found most delightful about knoppix was that with zero configuration on the first boot every single one of my hardware devices was recognized correctly.


Knoppix and Slax were my first foray into Linux as a teenager. The latter also introduced me to the terminal, in my quest force it to boot from a HDD... Many a partition died that week.


Knoppix was really innovative for it's time, the first live CD OS that I know of, it was great for accessing drives that were toasted or even mounting other linux volumes. All the stuff we do with USBs now, but back in the early 2000s it wasn't an easy thing for them to accomplish.


Some alternatives: Whonix: (vm isolated or hardware device isolated, tor) https://www.whonix.org/ and Qubes OS: (sandboxing different processes, needs torVM to do tor things) http://qubes-os.org/trac

A nice comparison: https://www.whonix.org/wiki/Comparison_with_Others



Even wired don't know what an OS is. Or rather the definition of OS has changed. A strange time when your industry jargon enters the popular lexicon but always slightly twisted.

You can't even call yourself a Troll in the UK now without people thinking you go on Facebook and mock the dead to their nearest and dearest.


Yes, the BBC News at Ten told us that "the website Mumsnet has warned its 1.5 million users that their data may have been hacked as a result of the Heartbleed computer bug. It's the first time the virus has been found on a British website"


I have found the BBC's Technology reporting particularly irksome. Their website is filled with re-hashed press releases. I even re-wrote an article concerning turning urea into electricty for them to show what it could have been like if they had put half an hour's effort into it, naturally I didn't even get a response.


Of course not. They thought that you were taking the piss in a shocking way.

I did once mail a correction to a story about a new EU regulation which had been a high profile item across BBC News. It was quite a fundamental thing, and I got a short mail from a senior editor, thanking me and angrily lamenting that it wasn't a difficult thing for his reporter to check, state of journalists these days, etc etc. The story was changed.

--edit: make a bad pun worse.


What is Tails, if not an operating system?


A distribution of the Linux operating system. It's a Debian distribution with some userspace tools bundled.


This depends. technically linux isn't an OS, just a kernel (hence the whole GNU/linux stuff). But even the GNU + linux isn't really a full OS. I feel calling a distribution an OS is pretty valid (though it is a member of the linux family and based off of debian).

I guess the main thing would be the OS is everything which isn't an application, and Tails is definitely not a single application, though it is specialised.


A distribution of an operating system, is itself, also an operating system.


Eh... it is more correct to call a distribution an OS than to call a kernel an OS; the kernel is only a component.


"No officer, these aren't drugs, they're a distribution of drugs with some userspace fillers bundled."


> How do we now it isn’t some government plot designed to snare activists or criminals? A couple of ways, actually. One of the Snowden leaks show the NSA complaining about Tails in a Power Point Slide; if it’s bad for the NSA, it’s safe to say it’s good for privacy. And all of the Tails code is open source, so it can be inspected by anyone worried about foul play.

It does not follow that either, or both, of these points (Open source, an NSA complaint slide) make this "snare proof". I'm not saying that it isn't, but there is no logic in the Wired article's assertions.


Yeah, safe and open source are not necessarily synonymous. (see openssl "heartbleed")


I like the way I had to click the article to see what it was. I was wondering if it'd be Tails or something. Yep.


And naturally, nobody knows exactly who created it.

Shouldn't it be the opposite so we all know who we're relying on? It's the same question I'd throw at Bitcoin.


I think users would prefer that covert government agencies not know where to find the authors, either to avoid undue influence or surreptitious hacking of their development machines to insert backdoors and other nefarious things.

Plus, as TFA states, the code is all out there in the open and able to be reviewed. Does it matter who wrote it at that point?


That reminds me the movie Captain America 2. Use such a USB based OS, enter an Apple store and find a macbook. Literally an untraceable hacking.


A real inside look at it. /s


is website under ddos?


HN-DDOS, probably.


Well it's not like Snowden managed to remain anonymous forever


You mean when he did a video interview? He managed to do what he did and leave the country without being caught. I call that mission accomplished.


The article suggests security because "all of the Tails code is open source, so it can be inspected by anyone worried about foul play."

Yeah, that worked out well for openssl.


Yes it did. The heartbleed bug was found during an audit of the open source of openssl.


Found late, and found in a an error-prone environment. This weakens the oft-implied "proof by open-sourceness", and has brought up some criticism on how open source projects are ran and incentivized.

Doesn't mean "Open Source sux", just some nuanced criticism, ok?


I assume that no one in its right mind would refute a nuanced criticism of Open Source, but the grandparent just didn't think it necessary to be nuanced or elaborate or make some concrete point at all. He just went for the quick pun and is being down-voted for it.


agreed


The audit occurred because testing revealed the presence of a problem. Shutting the stable door after the horse has bolted is no vindication of open source.


How would you have found the bug without it being open source? You think companies pay for these open public audits on proprietary software?


The vulnerability was first found by a fuzzer, which would have worked equally well on closed-source software. And I believe the fuzz tester (part of Codenomicon's "Defensics") is also closed-source.


You misunderstand - how would the public have found out about the results of that audit? There is no incentive to release this information for a closed product; very much the opposite.


This point is important. Testing came first and then auditing. In other words, black box testing and then white box testing. Why pretend you are better off just because you have millions of lines of inscrutable source?


Now try to do that trick on proprietary software.




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: