亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 36062 | 回復(fù): 4
打印 上一主題 下一主題

[CPU及多核] 『求助』 關(guān)于 smp_processor_id() [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2012-08-06 10:58 |只看該作者 |倒序?yàn)g覽
首先描述一下環(huán)境,X86_64,SMP system.                                                                                                                                                                                                           
                                                                                                                                                                                                                                               
smp_processor_id() 可以最終化減成如下形式:                                                                                                                                                                                                     
                                                                                                                                                                                                                                               
asm("movl %%gs:%P1, %0"                                                                                                                                                                                                                        
        :"=q"(ret__)                                                                                                                                                                                                                           
        :"m"(per_cpu__cpu_number));                                                                                                                                                                                                            
                                                                                                                                                                                                                                               
DEFINE_PER_CPU(int, cpu_number),在 setup_per_cpu_areas() 函數(shù)中拷貝                                                                                                                                                                           
vmlinux 中的每處理器變量,每個(gè)處理器都有一份拷貝,并將地址保存到                                                                                                                                                                              
__per_cpu_offset數(shù)組中。                                                                                                                                                                                                                       
                                                                                                                                                                                                                                               
1. 那么我的問題來了,此時(shí)每個(gè)CPU 的每 cpu 變量豈不都相同?比如                                                                                                                                                                                 
cpu_number 都相同,還是每個(gè) cpu 都會(huì)去初始化自己的本地每CPU變量,比如                                                                                                                                                                          
cpu 0 將 per_cpu__cpu_number 設(shè)置為 0                                                                                                                                                                                                         
cpu 1 將 per_cpu__cpu_number 設(shè)置為 1.                                                                                                                                                                                                         
                                                                                                                                                                                                                                               
                                                                                                                                                                                                                                               
在 do_boot_cpu() 中 cpu0(BP) 會(huì)首先為每個(gè) AP 建立 0 號(hào)進(jìn)程,然后發(fā)送 IPI給                                                                                                                                                                     
AP,AP 在載入 gdt,idt 之后回根據(jù) thread.eip 跳到 start_secondary 中,可是                                                                                                                                                                       
在 do_boot_cpu() 中有這么一句:                                                                                                                                                                                                               
                                                                                                                                                                                                                                               
initial_gs = per_cpu_offset(cpu);                                                                                                                                                                                                              
                                                                                                                                                                                                                                               
然后在 arch/x86/kernel/head_64.S 中(有些不理解它的作用):                                                                                                                                                                                       
                                                                                                                                                                                                                                               
movl    $MSR_GS_BASE,%ecx                                                                                                                                                                                                                     
movq    initial_gs(%rip),%rax                                                                                                                                                                                                                  
movq    %rax,%rdx                                                                                                                                                                                                                              
shrq    $32,%rdx                                                                                                                                                                                                                              
wrmsr                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                               
                                                                                                                                                                                                                                               
2. gs:per_cpu__cpu_number ,gs 是一個(gè)段選擇子,他的 GDT 段描述符中的地址字段 和 per_cpu_offset 是什么關(guān)系?它是在什么時(shí)候被設(shè)置的?換句話說 gs:per_cpu__cpu_number 是怎么定位到每 CPU 變量的本地拷貝的 ?                                       
   smp_processor_id() 是怎么最終獲得 cpu 編號(hào)的? 比如 CPU 2 .               


非常感謝。。。                                                                                    

論壇徽章:
6
金牛座
日期:2013-10-08 10:19:10技術(shù)圖書徽章
日期:2013-10-14 16:24:09CU十二周年紀(jì)念徽章
日期:2013-10-24 15:41:34獅子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亞洲杯之阿聯(lián)酋
日期:2015-05-09 14:36:15
2 [報(bào)告]
發(fā)表于 2012-08-06 13:04 |只看該作者
回復(fù) 1# zd零
. 那么我的問題來了,此時(shí)每個(gè)CPU 的每 cpu 變量豈不都相同?比如                                                                                                                                                                                 
cpu_number 都相同,還是每個(gè) cpu 都會(huì)去初始化自己的本地每CPU變量,比如                                                                                                                                                                          
cpu 0 將 per_cpu__cpu_number 設(shè)置為 0                                                                                                                                                                                                         
cpu 1 將 per_cpu__cpu_number 設(shè)置為 1.                                                                                                                                                                                                         


既然是每cpu變量,當(dāng)然是每個(gè)cpu都有單獨(dú)的本地CPU變量。

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2012-08-06 14:17 |只看該作者
回復(fù) 2# 瀚海書香


是啊,肯定每個(gè) cpu 都有自己的單獨(dú)的 CPU 變量啊,這一點(diǎn)我已經(jīng)說了,我的問題是:
1. 可以肯定的是每個(gè) CPU 的 per cpu 變量肯定都是不同的,比如 per_cpu__cpu_number,cpu 0 它的值為 0 ,cpu 1 它的值為 1,那我想問的是這個(gè)值是在何時(shí)被修改的呢?
2. movl %%gs:%P1, %0 是怎么完成對(duì) current cpu 的 per_cpu__cpu_number 讀取 ?

論壇徽章:
8
羊年新春福章
日期:2015-03-19 02:03:312015亞冠之北京國安
日期:2015-06-16 22:04:45程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-06-23 22:20:00每日論壇發(fā)貼之星
日期:2015-06-23 22:20:002015亞冠之首爾
日期:2015-06-24 19:18:072015亞冠之廣州恒大
日期:2015-08-06 10:29:442015亞冠之柏太陽神
日期:2015-11-02 11:21:0515-16賽季CBA聯(lián)賽之遼寧
日期:2015-12-09 15:05:02
4 [報(bào)告]
發(fā)表于 2019-01-30 00:53 |只看該作者
本帖最后由 firocu 于 2019-01-30 01:29 編輯

下面初始化 GS BASE 的代碼是 所有secondary cpu串行 執(zhí)行的, 所以不會(huì)有問題。        movl    $MSR_GS_BASE,%ecx
        movl    initial_gs(%rip),%eax
        movl    initial_gs+4(%rip),%edx
        wrmsr

具體串行方法, check cpu_callin_mask in do_boot_cpu() and smp_callin() in start_secondary()





論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2021-05-03 17:53 |只看該作者
2.6.25用的是fs,原理應(yīng)該差不多。都是記錄偏移,然后定位,類似重定位。
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP