Redian新闻
>
dereference a NULL pointer in C
avatar
P*t
2
产生segmentation fault的具体过程是怎样的?
比如是在OS发现要访问virutal memory address为0就报seg fault,
还是会进行到访问页表获取到physical memory address并访问才会报?
avatar
p*x
3
ask your wife...

【在 n*******e 的大作中提到】
: thanks...
avatar
p*g
4
Linux的gdt表的第一项就是给这个准备的
从书里抄了这么一段
The first entry of the GDT is always set to 0. This ensures the logic
address with a null Segment Selector will be considered invalid, thus
causing a processor exception.
呵呵,要不怎么叫segmentation fault呢
avatar
o*l
5
sigh, apparently his wife doesn't have those, that's why he's asking ah...

【在 p*x 的大作中提到】
: ask your wife...
avatar
p*g
6
至于说linux怎么handle这个exception,就是另外一个topic了
avatar
O*e
7
If you don't know what they are, just go-ogle.

【在 n*******e 的大作中提到】
: thanks...
avatar
t*t
8
目前几乎所有的32位OS在应用级都是flat memory model, 不怎么用段寄存器的. 所有
的段都是base 0, size=4G.
所以0指针是DS:0, 不是0:0, 跟GDT第一项没关系.

【在 p**********g 的大作中提到】
: Linux的gdt表的第一项就是给这个准备的
: 从书里抄了这么一段
: The first entry of the GDT is always set to 0. This ensures the logic
: address with a null Segment Selector will be considered invalid, thus
: causing a processor exception.
: 呵呵,要不怎么叫segmentation fault呢

avatar
p*x
9
wahahaha...he will "mean back"...

【在 o********l 的大作中提到】
: sigh, apparently his wife doesn't have those, that's why he's asking ah...
avatar
p*g
10
"segmentation fault"是说段错误,说和段映射没有关系似乎说不过去?不过段映射一
般是intel上的。
应用根本看不到内存管理的映射(segment or paging),不过确实有很多不用段映射的
,比如arm,不过没有具体看过linux在arm上的实现以及这个"segmentation fault"
我找找看
avatar
o*l
11
hehehe, no prob, he's one of the few who can take it

【在 p*x 的大作中提到】
: wahahaha...he will "mean back"...
avatar
D*a
12
this is about null segment selector, not null pointer.
segmentation fault is generally caused by accessing non-existant memory or
denied access.

【在 p**********g 的大作中提到】
: Linux的gdt表的第一项就是给这个准备的
: 从书里抄了这么一段
: The first entry of the GDT is always set to 0. This ensures the logic
: address with a null Segment Selector will be considered invalid, thus
: causing a processor exception.
: 呵呵,要不怎么叫segmentation fault呢

avatar
p*g
13
是我搞错了

【在 D*******a 的大作中提到】
: this is about null segment selector, not null pointer.
: segmentation fault is generally caused by accessing non-existant memory or
: denied access.

avatar
m*e
14
If you really want to know how Linux virtual memory management works, dive
into copy-on-write.
Last time I looked into it, I found a bug. :-)

【在 p**********g 的大作中提到】
: "segmentation fault"是说段错误,说和段映射没有关系似乎说不过去?不过段映射一
: 般是intel上的。
: 应用根本看不到内存管理的映射(segment or paging),不过确实有很多不用段映射的
: ,比如arm,不过没有具体看过linux在arm上的实现以及这个"segmentation fault"
: 我找找看

avatar
z*e
15
现在到底还有没有segment的概念啊?我看到OS里面介绍也是说某段区域给user mode,
某段区域给别的什么什么,但是看起来都是在连续空间分配。
一直不明白386/486时期那个segment到底是什么意思。

【在 t****t 的大作中提到】
: 目前几乎所有的32位OS在应用级都是flat memory model, 不怎么用段寄存器的. 所有
: 的段都是base 0, size=4G.
: 所以0指针是DS:0, 不是0:0, 跟GDT第一项没关系.

avatar
T*9
16
vma 为0的时候是page fault
然后系统试图load page,如果load fail, 就会报seg fault

【在 P***t 的大作中提到】
: 产生segmentation fault的具体过程是怎样的?
: 比如是在OS发现要访问virutal memory address为0就报seg fault,
: 还是会进行到访问页表获取到physical memory address并访问才会报?

相关阅读
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。