Slashdot Mirror


JavaScript Attack Breaks ASLR On 22 CPU Architectures (bleepingcomputer.com)

An anonymous reader quotes a report from BleepingComputer: Five researchers from the Vrije University in the Netherlands have put together an attack that can be carried out via JavaScript code and break ASLR protection on at least 22 microprocessor architectures from vendors such as Intel, AMD, ARM, Allwinner, Nvidia, and others. The attack, christened ASLRCache, or AnC, focuses on the memory management unit (MMU), a lesser known component of many CPU architectures, which is tasked with improving performance for cache management operations. What researchers discovered was that this component shares some of its cache with untrusted applications, including browsers. This meant that researchers could send malicious JavaScript that specifically targeted this shared memory space and attempted to read its content. In layman's terms, this means an AnC attack can break ASLR and allow the attacker to read portions of the computer's memory, which he could then use to launch more complex exploits and escalate access to the entire OS. Researchers have published two papers [1, 2] detailing the AnC attack, along with two videos[1, 2] showing the attack in action.

30 of 157 comments (clear)

  1. Layman's Terms by nuckfuts · · Score: 4, Funny

    In layman's terms, this means an AnC attack can break ASLR...

    'cause every layman knows what ASLR is.

    1. Re:Layman's Terms by El+Cubano · · Score: 5, Informative

      'cause every layman knows what ASLR is.

      I had the same thought. At first I thought it was related to digital photography. Here is what this is really all about: https://en.wikipedia.org/wiki/Address_space_layout_randomization

      In layman's terms: Keeping the locations of things in memory unpredictable so that, for example, if I am trying to exploit some arbitrary code execution flaw I can't count that my code will end up in the place I want or expect it.

    2. Re:Layman's Terms by Dunbal · · Score: 2

      Turns out it's not as random as they would want you to believe...

      --
      Seven puppies were harmed during the making of this post.
    3. Re:Layman's Terms by mnouquet · · Score: 2
    4. Re:Layman's Terms by nuckfuts · · Score: 2

      For what's it's worth, I was already familiar with that acronym. I was questioning whether a layman would be.

      You seem to be confusing "Layman's terms" with "Anything that can be looked up on Google".

    5. Re:Layman's Terms by nuckfuts · · Score: 2

      A definition of "layman's terms":

      simple language that anyone can understand

      Note how it doesn't say "...that anyone can look up the meaning of using a search engine".

    6. Re:Layman's Terms by epine · · Score: 5, Insightful

      A "layman" has no place in this discussion.

      I have trouble comprehending the small mental world you live in where all of your knowledge is equally available at all times.

      There's a reason why it's polite to gloss your acronyms on first use, even in the narrowest academic publications.

      Just yesterday I was reviewing the literature on machine learning. The Juergen Schmidhuber review alone begins with the following glossary:

      AE: Autoencoder
      BFGS: Broyden—Fletcher—Goldfarb—Shanno
      BNN: Biological Neural Network
      BM: Boltzmann Machine
      BP: Backpropagation
      BRNN: Bi-directional Recurrent Neural Network
      CAP: Credit Assignment Path
      CEC: Constant Error Carousel
      CFL: Context Free Language
      CMA-ES: Covariance Matrix Estimation ES
      CNN: Convolutional Neural Network
      CoSyNE: Co-Synaptic Neuro-Evolution
      CSL: Context Sensitive Language
      CTC: Connectionist Temporal Classification
      DBN: Deep Belief Network
      DCT: Discrete Cosine Transform
      DL: Deep Learning
      DP: Dynamic Programming
      DS: Direct Policy Search
      EA: Evolutionary Algorithm
      EM: Expectation Maximization
      ES: Evolution Strategy
      FMS: Flat Minimum Search
      FNN: Feedforward Neural Network
      FSA: Finite State Automaton
      GMDH: Group Method of Data Handling
      GOFAI: Good Old-Fashioned AI
      GP: Genetic Programming
      GPU: Graphics Processing Unit
      GPU-MPCNN: GPU-Based MPCNN
      HMM: Hidden Markov Model
      HRL: Hierarchical Reinforcement Learning
      HTM: Hierarchical Temporal Memory
      HMAX: Hierarchical Model "and X"
      LSTM: Long Short-Term Memory (RNN)
      MDL: Minimum Description Length
      MDP: Markov Decision Process
      MNIST: Mixed National Institute of Standards and Technology Database
      MP: Max-Pooling
      MPCNN: Max-Pooling CNN
      NE: NeuroEvolution
      NEAT: NE of Augmenting Topologies
      NES: Natural Evolution Strategies
      NFQ: Neural Fitted Q-Learning
      NN: Neural Network
      OCR: Optical Character Recognition
      PCC: Potential Causal Connection
      PDCC: Potential Direct Causal Connection
      PM: Predictability Minimization
      POMDP: Partially Observable MDP
      RAAM: Recursive Auto-Associative Memory
      RBM: Restricted Boltzmann Machine
      ReLU: Rectified Linear Unit
      RL: Reinforcement Learning
      RNN: Recurrent Neural Network
      R-prop: Resilient Backpropagation
      SL: Supervised Learning
      SLIM NN: Self-Delimiting Neural Network
      SOTA: Self-Organizing Tree Algorithm
      SVM: Support Vector Machine
      TDNN: Time-Delay Neural Network
      TIMIT: TI/SRI/MIT Acoustic-Phonetic Continuous Speech Corpus
      UL: Unsupervised Learning
      WTA: Winner-Take-All

      And it's but one of dozens of fields where I stick my finger into the alphabet pie.

    7. Re:Layman's Terms by Rockoon · · Score: 2

      Keeping the locations of things in memory unpredictable so that, for example, if I am trying to exploit some arbitrary code execution flaw I can't count that my code will end up in the place I want or expect it.

      Close but not quite right.

      Its so that you can't count on OS/Host code being at a specific address. Your own code doesnt need to care what address its loaded at, even if its nefarious (every architecture has relative jump instructions.) The idea is that something like the browsers file i/o routines arent being placed at a predictable address, so your nefarious code cant just branch directly into them.

      The main flaw of address randomization is that address information can still leak through the stack if you can first make sure something that calls the routine you want to call has previously been called. For instance if you can save a cookie in your javascript code immediately before your injected code executes, then any routine the browser calls to save a cookie may now have its address right there on the stack for your injected code to grab.

      Its better than not doing it, but not entirely effective w.r.t. its purpose.

      --
      "His name was James Damore."
    8. Re:Layman's Terms by DontBeAMoran · · Score: 4, Funny
      --
      #DeleteFacebook
    9. Re:Layman's Terms by DontBeAMoran · · Score: 4, Funny

      What the hell is a search engine and how many cylinders does it have?

      --
      #DeleteFacebook
    10. Re:Layman's Terms by thegarbz · · Score: 2

      oh look. I typed "aslr" into google

      Why did you do that? Because the summary was poorly written?

  2. I only hope by Anonymous Coward · · Score: 2, Funny

    Somebody can tell me how I can block this attack with a HOSTS file?

  3. crazy by Anonymous Coward · · Score: 4, Funny

    who would run anything on a machine with 22 CPUs? That's just ASKING to have your ASLR broken, right?

    1. Re:crazy by Anonymous Coward · · Score: 3, Informative

      Multi-CPU motherboards existed before multi-core CPUs. Kids these days...

      Personally, I would run my frying pan on a computer with 22 CPUs.

    2. Re:crazy by Anonymous Coward · · Score: 2

      With a special definition of 22: ARM from several manufacturers and x86 (Intel and AMD).
      So I personally count 2 (thumbs down for this way of counting).
      For example they do not mention any architecture that uses hashed page tables like Power (and others). Apparently their method only works on processors in which the MMU walks a tree on a page fault, and comes from the interaction of the page table walks with the caches. Hash based page tables do not have the same properties in this respect and (at least on Power), there are other, per memory space, kernel held secret quantities mixed up in the hash which seriously complicate getting the same information.
      I don't claim that it is impossible, but I'm sure that it is orders of magnitudes harder. In practice, the kernel secret for the hash and the ASLR offsets mix up in a way which seems impossible to separate.

  4. Not the whole story? by K.+S.+Kyosuke · · Score: 2

    So how exactly does this hurt me if the VM sandbox is secure? The paper seems to imply that you need other, much worse vulnerabilities to begin with to make use of this (beyond extracting information).

    --
    Ezekiel 23:20
    1. Re:Not the whole story? by bws111 · · Score: 2

      ASLR is not memory protection. Breaking ASLR does not give read nor write access to any memory that the process did not already have. ASLR was introduced to help mitigate a bunch of buffer overflow attacks, by not having a 'predicatable' address that the attacker could branch to to execute his malicious code.

      So exactly HOW are you going to intercept that password, using a technique that would not be possible if ASLR was not broken?

  5. BeauHD by PopeRatzo · · Score: 4, Funny

    I thought Slashdot was supposed to be a tech site. What does Javascript attacks breaking ASLR on 22 microprocessor architectures have to do with tech?

    --
    You are welcome on my lawn.
  6. Re:javascript is incompatible with security by Anonymous Coward · · Score: 5, Informative

    OK, fair enough, but if it's expressed in another language (assuming it's not part of your OS) you have to explicitly get and run the malicious software. If it's javascript you get it just by visiting a web page with default browser settings.

    Delivery is different, even if in theory you could get it via some other means.

  7. Maybe it's time to return to LISP machines by presidenteloco · · Score: 3, Interesting

    No, semi-seriously.

    The concept of a LISP machine was a computer which only executed one programming language, at least only one language in which non built-in code would execute.
    And that language was memory secure, in that it packaged memory use into high-level cells which referenced each other in a single standard way.

    There was no way that a process could "break out" and access something else's memory. A LISP program running in one process only understood and could access its own linked memory cells.

    This was enough programming freedom to program whatever you wanted, and the point is, the memory model was simple, uniform, and thereby secure.

    I'm not exactly saying return to LISP machines. I'm saying return to an architecture which includes a simple and secure memory access model, with no workarounds to the high-level memory cell access permitted. This could be enforced at the machine-language level, and/or by restricting allowed programming languages to inherently memory-secure ones.

    --

    Where are we going and why are we in a handbasket?
  8. Why? by PPH · · Score: 2

    this component shares some of its cache with untrusted applications, including browsers

    Why does the MMU need to give user space apps access to its cache? Isn't the O/S, firmware and microcode supposed to provide a logical view of hardware like memory to prevent this sort of abuse?

    --
    Have gnu, will travel.
    1. Re:Why? by phantomfive · · Score: 4, Informative

      It doesn't try to, it's a side-channel attack. So, ASLR pads elements with a random amount of free space, so a hacker doesn't know where to jump to. This attack figures out how big the free space is, by figuring out where the end of a cache line is. It figures out where the end of a cache line is by looking at the memory access times. So:

      x = a[n]; //runs in .5microseconds
      x = a[n+1]; //runs in 10 microseconds

      You know you hit a cache miss on the second access, and the end of a cache line is right between a[n] and a[n+1]. Based on the offset from where the cache would normally be, you can figure out how big the ASLR padding is. Once you know the padding size, you can know exactly which address to jump to to when you inject your shell code (ie, your compiled assembly exploit).

      There are other ways to defeat ASLR too, so I am not sure how useful this is, but the more techniques a hacker has, the better (from his perspective).

      --
      "First they came for the slanderers and i said nothing."
    2. Re:Why? by mentil · · Score: 2

      It doesn't. A high-precision timer is used to execute a timing attack to infer what the cache contains; major browsers nixed their built-in javascript high-precision timers, but they managed to cobble together their own (from allowed javascript functions, presumably), which incidentally reintroduces old timing attacks like RowHammer. Browsers can fudge javascript timing, but the larger problem would remain. Presumably, microcode updates could fix this.

      --
      Corruption is convincing someone that the selfless ideal is the same as their selfish ideal.
  9. "Lesser known" by phantomfive · · Score: 2

    If the MMU is lesser known to you, then the ALU is going to blow your mind. Just don't look at MMX, it's ugly.

    --
    "First they came for the slanderers and i said nothing."
  10. Re:CPUs, not CPU architecture by sexconker · · Score: 4, Insightful

    You're confusing CPU architecture with instruction set architecture. They used to be the same (and in some cases still are) but most processors have a physical architecture that implements an ISA via microcode translation. With memory controllers (and a whole lot of other shit) on the same package. the term "architecture" has drifted even further from ISA and more toward the entire SoC.

  11. Re:scripting is incompatible with security by sexconker · · Score: 5, Insightful

    Don't run code you don't trust.
    Javascript is code, no matter how much your browser tries to sandbox it or put shackles on it, it's going to be flying around in your CPU if you let it run.
    If you don't trust the Javascript, don't run it.

    There are 3 points to this problem:

    Shitty fucking developers write shitty fucking websites that NEED Javascript to function.
    Shitty fucking users like shiny, stupid shit and encourage that behavior.
    Shitty fucking browsers let it all run by default and focus on speed, not security to please the shitty fucking users.
    (And this loops back to shitty fucking developers seeing that they can bloat up their site even more because Chrome v8247 tweaked Javascript regex performance to be 2.8% faster.)

  12. Bad reporting by slew · · Score: 4, Informative

    This new Java script attack does *NOT* by itself compromise data, but simply allow a way to remotely extract the Address Space Layout Randomization that is currently employed by the OS. It does this by employing a javascript timer to measure page table walk times which are induced by executing javascript that accesses carefully selected offset in large objects (an earlier attempt to do this was frustrated by javascript implementations deliberately sabotaging the built-in high precision timer object). Once the specific ASLR pattern is determined for this specific boot of the kernel, other kernel vulnerabilities that involved direct access to aliased cache and/or memory locations that were mitigated by the kernel doing ASLR can now be modified to target the desired addresses on the target.

    It's like knowing how to make key to break into a specific car, but if you use it on the wrong car, it triggers the car alarm and not knowing what car the key it works on. If you magically had a way to map the VIN to the car key, you could make a key that works for that car and steal the car. The car dealers have this mapping, so they can make a key for you, but what someone came up with a way to figure out the VIN->KEY mapping over the internet?

  13. Re:In lay terms you say ... by jeremyp · · Score: 4, Funny

    You have got a car with Piers Morgan sitting in it. An attacker wants to head butt him in the face (trying to think of a backronym for AnC for this - I have Attacker Nuts... but I can't think of a word beginning with C that describes Piers Morgan) so, for his own protection, you choose where he sits in the car by a random process (Arsehole Seat Location Randomisation), so the chances are the attacker opens the wrong door.

    Anyway, it turns out that you can tell by how the car is riding on its springs where Piers Morgan is.

    --
    All I want is a secure system where it's easy to do anything I want. Is that too much to ask ~~ Randall Munroe
  14. Re:scripting is incompatible with security by Pascoea · · Score: 3, Insightful

    Yes, because every web page should be a static HTML document with zero interactivity. And web applications are a fad that will go away soon.

  15. Re:scripting is incompatible with security by thegarbz · · Score: 2

    Don't run code you don't trust.

    Not possible on a modern computer. But thanks for the advice.