memory-segmentation Questions
3
I'm reading the intel manual, and I see mentions of "Linear Address Space of the processor".
I'm confused as to where or what the linear address space actually is. Where in the processor ...
Xiphoid asked 25/6, 2020 at 23:24
1
I debug a program with gdb for fun, with stack guard so it writes the canary to the stack from fs:28h. Out of curiosity, I trying to find the memory address that fs:28h points to.
I encounter two p...
Branum asked 22/7, 2023 at 20:10
1
Solved
I have stumbled upon this kernel page: https://www.kernel.org/doc/html/v5.9/x86/x86_64/fsgs.html and wanted to play around with LD_PRELOAD to see whether I can allocate a value at a load-time and r...
Wafd asked 8/7, 2023 at 22:36
3
Solved
Specifically is:
mov %eax, %ds
Slower than
mov %eax, %ebx
Or are they the same speed. I've researched online, but have been unable to find a definitive answer.
I'm not sure if this is a sill...
Ovalle asked 3/7, 2018 at 22:56
2
Solved
In what I've learned so far about segmentation:
A virtual address contains a segment selector and an offset
The segment selector is used in conjunction with the GDTR to find the linear address of...
Aqueduct asked 7/9, 2018 at 12:0
4
Solved
I was recently answering a question on the undefined behaviour of doing p < q in C when p and q are pointers into different objects/arrays. That got me thinking: C++ has the same (undefined) beh...
Torment asked 10/10, 2019 at 11:42
3
Solved
gdb provides functionality to read or write to a specific linear address, for example:
(gdb) x/1wx 0x080483e4
0x80483e4 <main>: 0x83e58955
(gdb)
but how do you specify a logical address ?...
Stephanus asked 27/4, 2012 at 16:6
1
Solved
I am studying the issue of alignment check. But I don't know whether the processor is checking on effective addresses, linear addresses or physical addresses, or all checks.
For example, the effect...
Narrows asked 16/6, 2021 at 10:38
6
Solved
So I know what the following registers and their uses are supposed to be:
CS = Code Segment (used for IP)
DS = Data Segment (used for MOV)
ES = Destination Segment (used for MOVS, etc.)
SS = Stac...
Serum asked 30/5, 2012 at 4:57
1
Solved
I am attempting to code a simple stack canary in 64-bit assembly using NASM version 2.15.04 on Ubuntu 20.10. Executing the code below results in a segmentation fault when assembling and linking wit...
Chondrite asked 27/12, 2020 at 17:31
1
Solved
I read a number of articles and S/O answers saying that (on linux x86_64) FS (or GS in some variants) references a thread-specific page table entry, which then gives an array of pointers to the act...
Sturgis asked 16/12, 2020 at 12:12
3
Solved
I am writing my own OS for 64bit processors and I am stuck with the problem of general protection. My OS will not rely on page fault to implement user space protection mechanism, so I found there i...
Barimah asked 22/10, 2011 at 17:20
1
Solved
In x86_64, fs and gs registers involve in a limited form of segmentation. Just taking, fs as an example, how does fs register, FSBase MSR work together to generate the effective address?
What happ...
Flattish asked 18/1, 2020 at 6:6
3
Solved
Is there some way to read the x86-64 model-specific registers, specifically IA32_FS_BASE and IA32_GS_BASE, while debugging a program using GDB?
Less preferable would be a solution using a dynamic ...
Yarkand asked 15/4, 2014 at 22:24
1
Solved
What are the differences among all these things : flat addresses ,base
address , linear addresses , effective addresses, physical address , effective address calculations ???
Amygdalin asked 23/10, 2019 at 7:22
2
Solved
I have learned about compilers and assembly language, so I'd like to write my own assembler as an exercise. But there I have some questions;
How can I compute the address for segments such as @DAT...
Brittle asked 20/4, 2015 at 13:58
1
Solved
This question is inspired by a Reddit question in r/osdev except that this question focuses on the SS register. One may say RTFM (ISA entry for MOV), but when this question comes up it can get vary...
Alchemy asked 9/8, 2019 at 19:33
1
In x86, when you want to access a memory address, you would specify an address that would be translated into a memory address through two stages: segmentation, and paging:
But is segmentation al...
Spiny asked 26/7, 2019 at 15:5
2
The movsb (move string, bytes) instruction fetches the byte at address
ds:si, stores it at address es:di, and then increments or decrements
the si and di registers by one.
I know esi,si and e...
Sokil asked 1/11, 2011 at 1:27
2
Solved
Looking into the internals of Linux and memory management, I just stumbled upon the segmented paging model that Linux uses.
Correct me if I am wrong, but Linux (protected mode) does use paging for...
Meow asked 20/5, 2019 at 2:4
2
Solved
What is linear address? How is it different from physical address?
Evaluate asked 17/11, 2010 at 8:31
2
Solved
In studying operating systems (primarily with Linux as reference), there are a few points that I don't find well explained in the material that I have studied.
Programs loaded into memory are ofte...
Sauerbraten asked 26/2, 2012 at 23:45
1
Solved
According to AMD manual segmentation can not be disabled.
My question is why, why it's impossible?
Another question, it says that 64-bit disables it, what does that mean? Is segmentation completly ...
Coagulate asked 13/4, 2018 at 7:22
3
Solved
void return_input (void)
{
char array[30];
gets (array);
printf("%s\n", array);
}
After compiling it in gcc, this function is converted to the following Assembly code:
push %ebp
mov %e...
Wershba asked 12/2, 2012 at 13:55
2
I have one doubt regarding the size of segments in real mode as they can't be more than 64K but can be less than that.
My question is how these segment size and base address is initialized? Like th...
Adagio asked 22/7, 2013 at 11:24
1 Next >
© 2022 - 2025 — McMap. All rights reserved.