作者ucrxzero (RX-0)
看板C_and_CPP
標題[問題] -fPIC==VM的共享庫段都各一個副本嗎?
時間Mon Oct 12 20:53:56 2020
開發平台(Platform): (Ex: Win10, Linux, ...)
Linux
編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出)
gcc
額外使用到的函數庫(Library Used): (Ex: OpenGL, ...)
"動態/靜態函式庫"
問題(Question):
除了標題的問題還要問:
編執行檔有沒有fPIC有差嗎?
例如:
gcc -fPIC main.c -lboost_printf
gcc -static -fPIC main.c -lboost_printf
假設boost_printf.so跟.a都存在
這是計組的問題但我不太了解~感謝
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 43.248.19.192 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1602507240.A.DCE.html
※ 編輯: ucrxzero (43.248.19.192 臺灣), 10/12/2020 20:54:34
1F:→ Lipraxde: fPIC 是讓 compiler 編譯成 position-independent code 10/13 02:32
2F:→ Lipraxde: 的選項,用這個選項編譯的程式碼在執行的時需要做 rel 10/13 02:32
3F:→ Lipraxde: ocation,為了在不同的位置 (VM) 上執行。 10/13 02:32
4F:→ Lipraxde: Shared library 是不是會共用 PM 應該是 OS 決定的事, 10/13 02:32
5F:→ Lipraxde: PIC 對程式執行主要還是看 VM。 10/13 02:32
6F:→ ucrxzero: 可是我記得不加才要relocation ? 10/13 09:16
7F:→ ucrxzero: 感謝 10/13 09:16
8F:→ ucrxzero: 因為不加是絕對位址會有問題 10/13 09:20
9F:→ Lipraxde: 啊對,我記錯了。因為是 PIC 的關係可以把 PM 映射到不 10/13 09:39
10F:→ Lipraxde: 同的 VM,兩者之間應該是這樣的關係。 10/13 09:39
11F:→ ucrxzero: fPIC的可以同步修改PM 10/13 10:03
12F:→ ucrxzero: 而另外一個為private的copy on write這樣理解對嗎 10/13 10:03
13F:→ ucrxzero: 看到計組上的對於共享庫段的解釋是不是套用到dPIC上? 10/13 10:04
14F:→ ucrxzero: *fPIC 10/13 10:04
15F:→ Lipraxde: PIC 可以不經修改就能在不同位置上執行,因為使用的是 10/13 10:50
16F:→ Lipraxde: 相對位置而不是絕對位置。至於計組嘛...很久沒看了,也 10/13 10:50
17F:→ Lipraxde: 不太記得相關的描述 QQ 10/13 10:50
18F:→ Killercat: 「程式設計師的自我修養」我記得前幾章就在講這個...XD 10/13 11:42
19F:推 KaryuuIssen: 執行檔不要編譯成PIC PIC會繞道存取(got/plt等等) 10/13 12:24
20F:→ KaryuuIssen: 另外PIC旨在程式段共享 資料段還是各自有各自的 10/13 12:25
21F:→ Lipraxde: 想避免 got/plt 應該是盡量用 static link 吧? 10/13 13:23
22F:→ ucrxzero: 繞道存取我查查看 感謝 10/13 15:33
23F:推 KaryuuIssen: L大 你回答的是另一個問題: .so跟.a的抉擇 這點讓 10/13 16:41
24F:→ KaryuuIssen: 原PO自己考慮XD 總之fPIC除了編譯Shared library外 10/13 16:42
25F:→ KaryuuIssen: 都不需要加 就算原po選了.so而沒加fPIC 編出來的 10/13 16:42
26F:→ KaryuuIssen: 執行檔存取Shared library的部份依然會是PIC 10/13 16:42
27F:→ Lipraxde: 恩恩,我誤會您前面的意思了 10/13 18:32
28F:→ ucrxzero: 了解了感謝 10/13 21:07
29F:推 kingofsdtw: 感謝,長知識了 10/15 02:07