summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorCrystal <crystal@wizard.tower>2024-03-07 20:54:33 +0100
committerCrystal <crystal@wizard.tower>2024-03-07 20:54:33 +0100
commit97bfcd5dd7cc5279b5865ebf638293491cf69151 (patch)
treedc86edd728077367d565ee53da9584eb231461f1
parent034a89ea75df7ced5db00669c62b504cde625cde (diff)
downloadwww-97bfcd5dd7cc5279b5865ebf638293491cf69151.tar.gz
Add stuff
-rw-r--r--blog/asm/1.html72
-rw-r--r--src/org/blog/assembly/1.org2
2 files changed, 37 insertions, 37 deletions
diff --git a/blog/asm/1.html b/blog/asm/1.html
index 4e71a1c..c4b0bf6 100644
--- a/blog/asm/1.html
+++ b/blog/asm/1.html
@@ -3,7 +3,7 @@
 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
 <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
 <head>
-<!-- 2024-03-07 Thu 20:53 -->
+<!-- 2024-03-07 Thu 20:54 -->
 <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
 <meta name="viewport" content="width=device-width, initial-scale=1" />
 <title>x86 Assembly from my understanding</title>
@@ -23,9 +23,9 @@
 <p>
 Soooo this article (or maybe even a series of articles, who knows ?) will be about x86 assembly, or rather, what I understood from it and my road from the bottom-up hopefully reaching a good level of understanding
 </p>
-<div id="outline-container-org2a24f51" class="outline-2">
-<h2 id="org2a24f51">Memory :</h2>
-<div class="outline-text-2" id="text-org2a24f51">
+<div id="outline-container-org826f92f" class="outline-2">
+<h2 id="org826f92f">Memory :</h2>
+<div class="outline-text-2" id="text-org826f92f">
 <p>
 Memory is a sequence of octets (Aka 8bits) that each have a unique integer assigned to them called <b>The Effective Address (EA)</b>, in this particular CPU Architecture (the i8086), the octet is designated by a couple (A segment number, and the offset in the segment)
 </p>
@@ -40,9 +40,9 @@ Memory is a sequence of octets (Aka 8bits) that each have a unique integer assig
 The offset and segment are encoded in 16bits, so they take a value between 0 and 65535
 </p>
 </div>
-<div id="outline-container-org342f4bf" class="outline-4">
-<h4 id="org342f4bf">Important :</h4>
-<div class="outline-text-4" id="text-org342f4bf">
+<div id="outline-container-orgdfce54b" class="outline-4">
+<h4 id="orgdfce54b">Important :</h4>
+<div class="outline-text-4" id="text-orgdfce54b">
 <p>
 The relation between the Effective Address and the Segment &amp; Offset is as follow :
 </p>
@@ -52,8 +52,8 @@ The relation between the Effective Address and the Segment &amp; Offset is as fo
 </p>
 </div>
 <ul class="org-ul">
-<li><a id="org7dc9b55"></a>Example :<br />
-<div class="outline-text-5" id="text-org7dc9b55">
+<li><a id="org3da6d39"></a>Example :<br />
+<div class="outline-text-5" id="text-org3da6d39">
 <p>
 Let the Physical address (Or Effective Address, these two terms are enterchangeable) <b>12345h</b> (the h refers to Hexadecimal, which can also be written like this <b>0x12345</b>), the register <b>DS = 1230h</b> and the register <b>SI = 0045h</b>, the CPU calculates the physical address by multiplying the content of the segment register <b>DS</b> by 10h (or 16) and adding the content of the register <b>SI</b>. so we get : <b>1230h x 10h + 45h = 12345h</b>
 </p>
@@ -66,16 +66,16 @@ Now if you are a clever one ( I know you are, since you are reading this &lt;3 )
 </li>
 </ul>
 </div>
-<div id="outline-container-org6338772" class="outline-3">
-<h3 id="org6338772">Registers</h3>
-<div class="outline-text-3" id="text-org6338772">
+<div id="outline-container-org53e7169" class="outline-3">
+<h3 id="org53e7169">Registers</h3>
+<div class="outline-text-3" id="text-org53e7169">
 <p>
 The 8086 CPU has 14 registers of 16bits of size. From the POV of the user, the 8086 has 3 groups of 4 registers of 16bits. One state register of 9bits and a counting program of 16bits inaccessible to the user (whatever this means).
 </p>
 </div>
-<div id="outline-container-org5583fa8" class="outline-4">
-<h4 id="org5583fa8">General Registers</h4>
-<div class="outline-text-4" id="text-org5583fa8">
+<div id="outline-container-org052f8dc" class="outline-4">
+<h4 id="org052f8dc">General Registers</h4>
+<div class="outline-text-4" id="text-org052f8dc">
 <p>
 General registers contribute to arithmetic&rsquo;s and logic and addressing too.
 </p>
@@ -126,28 +126,28 @@ Now here are the Registers we can find in this section:
 </div>
 </div>
 </div>
-<div id="outline-container-orga6303cd" class="outline-3">
-<h3 id="orga6303cd">Addressing and registers&#x2026;again</h3>
-<div class="outline-text-3" id="text-orga6303cd">
+<div id="outline-container-org2327321" class="outline-3">
+<h3 id="org2327321">Addressing and registers&#x2026;again</h3>
+<div class="outline-text-3" id="text-org2327321">
 </div>
-<div id="outline-container-org5b9f758" class="outline-4">
-<h4 id="org5b9f758">I realized what I wrote here before was almost gibberish, sooo here we go again I guess ?</h4>
-<div class="outline-text-4" id="text-org5b9f758">
+<div id="outline-container-orgcab6464" class="outline-4">
+<h4 id="orgcab6464">I realized what I wrote here before was almost gibberish, sooo here we go again I guess ?</h4>
+<div class="outline-text-4" id="text-orgcab6464">
 <p>
 Well lets take a step back to the notion of effective addresses VS relative ones.
 </p>
 </div>
 </div>
-<div id="outline-container-org44d3398" class="outline-4">
-<h4 id="org44d3398">Effective = 10h x Segment + Offset . Part1</h4>
-<div class="outline-text-4" id="text-org44d3398">
+<div id="outline-container-orgb2c4683" class="outline-4">
+<h4 id="orgb2c4683">Effective = 10h x Segment + Offset . Part1</h4>
+<div class="outline-text-4" id="text-orgb2c4683">
 <p>
 When trying to access a specific memory space, we use this annotation <b>[Segment:Offset]</b>, so for example, and assuming <b>DS = 0100h</b>. We want to write the value <b>0x0005</b> to the memory space defined by the physical address <b>1234h</b>, what do we do ?
 </p>
 </div>
 <ul class="org-ul">
-<li><a id="orga1b16b6"></a>Answer :<br />
-<div class="outline-text-5" id="text-orga1b16b6">
+<li><a id="orge32ff8e"></a>Answer :<br />
+<div class="outline-text-5" id="text-orge32ff8e">
 <div class="org-src-container">
 <pre class="src src-asm"><span style="color: #89b4fa;">MOV</span> [DS:0234h], 0x0005
 </pre>
@@ -155,7 +155,7 @@ When trying to access a specific memory space, we use this annotation <b>[Segmen
 
 <p>
 Why ? Let&rsquo;s break it down :
-<img src="file:///src/gifs/lain-dance.gif" alt="lain-dance.gif" />
+<img src="../../src/gifs/lain-dance.gif" alt="lain-dance.gif" />
 </p>
 
 
@@ -172,9 +172,9 @@ Simple, right ?, now for another example
 </li>
 </ul>
 </div>
-<div id="outline-container-org577af1c" class="outline-4">
-<h4 id="org577af1c">Another example :</h4>
-<div class="outline-text-4" id="text-org577af1c">
+<div id="outline-container-orga49169d" class="outline-4">
+<h4 id="orga49169d">Another example :</h4>
+<div class="outline-text-4" id="text-orga49169d">
 <p>
 What if we now have this instruction ?
 </p>
@@ -187,9 +187,9 @@ What does it do ? You might or might not be surprised that it does the exact sam
 </p>
 </div>
 </div>
-<div id="outline-container-org99e946d" class="outline-4">
-<h4 id="org99e946d">Segment + Register &lt;3</h4>
-<div class="outline-text-4" id="text-org99e946d">
+<div id="outline-container-org901ecc2" class="outline-4">
+<h4 id="org901ecc2">Segment + Register &lt;3</h4>
+<div class="outline-text-4" id="text-org901ecc2">
 <p>
 Consider <b>DS = 0100h</b> and <b>BX = BP = 0234h</b> and this code snippet:
 </p>
@@ -225,8 +225,8 @@ The General rule of thumb is as follows :
 </ul>
 </div>
 <ul class="org-ul">
-<li><a id="orgb46cb7c"></a>Note<br />
-<div class="outline-text-5" id="text-orgb46cb7c">
+<li><a id="org6cd6bc8"></a>Note<br />
+<div class="outline-text-5" id="text-org6cd6bc8">
 <p>
 The values of the registers CS DS and SS are automatically initialized by the OS when launching the program. So these segments are implicit. AKA : If we want to access a specific data in memory, we just need to specify its offset. Also you can&rsquo;t write directly into the DS or CS segment registers, so something like
 </p>
@@ -244,7 +244,7 @@ The values of the registers CS DS and SS are automatically initialized by the OS
 </div>
 <div id="postamble" class="status">
 <p class="author">Author: Crystal</p>
-<p class="date">Created: 2024-03-07 Thu 20:53</p>
+<p class="date">Created: 2024-03-07 Thu 20:54</p>
 </div>
 </body>
 </html>
diff --git a/src/org/blog/assembly/1.org b/src/org/blog/assembly/1.org
index 901e4ed..dcd205d 100644
--- a/src/org/blog/assembly/1.org
+++ b/src/org/blog/assembly/1.org
@@ -80,7 +80,7 @@ MOV [DS:0234h], 0x0005
 #+END_SRC
 
 Why ? Let's break it down :
-[[/src/gifs/lain-dance.gif]]
+[[../../src/gifs/lain-dance.gif]]