summaryrefslogtreecommitdiff
path: root/Content
diff options
context:
space:
mode:
authorNavan Chauhan <navanchauhan@gmail.com>2023-10-23 16:17:48 -0600
committerNavan Chauhan <navanchauhan@gmail.com>2023-10-23 16:17:48 -0600
commita6908f8957d502893cfcd641d0de0bd2ea0145c2 (patch)
treef95695f3f4e84c9a1a606154beb05c2012463571 /Content
parent77bdfae24843e163052479730210177103b123aa (diff)
Update attack lab
Diffstat (limited to 'Content')
-rw-r--r--Content/posts/2023-10-05-attack-lab.md8
1 files changed, 7 insertions, 1 deletions
diff --git a/Content/posts/2023-10-05-attack-lab.md b/Content/posts/2023-10-05-attack-lab.md
index a173ab8..b31159f 100644
--- a/Content/posts/2023-10-05-attack-lab.md
+++ b/Content/posts/2023-10-05-attack-lab.md
@@ -41,8 +41,9 @@ Let us try to look into the `getbuf` from our disassembled code.
We can see that `0x18` (hex) or `24` (decimal) bytes of buffer is allocated to `getbuf` (Since, 24 bytes are being subtracted from the stack pointer).
+**Buffer Overflow**: A buffer overrun happens when the size of the data exceeds the memory size reserved for the buffer we are storing in our value.
-Now, since we know the buffer size we can try passing the address of the touch1 function.
+Now, since we know the buffer size we can try passing the address of the touch1 function after we pad it up with the buffer size.
```bash
jxxxan@jupyter-xxxxxx8:~/lab3-attacklab-xxxxxxxxuhan/target66$ cat dis.txt | grep touch1
@@ -344,6 +345,11 @@ When a gadget uses a popq instruction, it will pop data from the stack. As a res
string will contain a combination of gadget addresses and data.
<cite>Attack Lab Handout</cite>
+> What is ROP Attack?
+<br><br>
+is a computer security exploit technique in which the attacker uses control of the call stack to indirectly execute cherry-picked machine instructions
+<cite>https://resources.infosecinstitute.com</cite>
+
Let us check if we can find `popq %rdi` between `start_farm` and `end_farm`
The way a normal person would find the hex representation `58` to be between `start_farm` and `end_farm` is to find the line numbers for both and