第1章 迴顧UNIX內核原理 1
1.1 引言 1
1.2 進程、程序和綫程 2
1.3 進程地址空間 3
1.3.1 地址空間映射 5
1.4 上下文切換 6
1.5 內存管理和進程管理的係統調用 6
1.5.1 係統調用fork 7
1.5.2 係統調用exec 9
1.5.3 係統調用exit 9
1.5.4 係統調用sbrk和brk 9
1.5.5 共享內存 10
1.5.6 I/O操作 10
1.5.7 映射文件 11
1.6 小結 11
1.7 習題 11
1.8 進一步的讀物 12
第一部分 高速緩存存儲係統
第2章 高速緩存存儲係統概述 17
2.1 存儲器層次結構 17
2.2 高速緩存基本原理 19
2.2.1 如何存取高速緩存 19
2.2.2 虛擬地址還是物理地址 21
2.2.3 搜索高速緩存 21
2.2.4 替換策略 22
2.2.5 寫策略 22
2.3 直接映射高速緩存 24
2.3.1 直接映射高速緩存的散列算法 25
2.3.2 直接映射高速緩存的實例 27
2.3.3 直接映射高速緩存的缺失處理和替換策略 30
2.3.4 直接映射高速緩存的總結 31
2.4 雙路組相聯高速緩存 31
2.5 n路組相聯高速緩存 33
2.6 全相聯高速緩存 33
2.7 n路組相聯高速緩存的總結 33
2.8 高速緩存衝洗 34
2.9 無緩存的操作 35
2.10 獨立的指令高速緩存和數據高速緩存 35
2.11 高速緩存的性能 37
2.12 各種高速緩存體係的差異 38
2.13 習題 38
2.14 進一步的讀物 41
第3章 虛擬高速緩存 45
3.1 虛擬高速緩存的操作 45
3.2 虛擬高速緩存的問題 47
3.2.1 歧義 47
3.2.2 彆名 48
3.3 管理虛擬高速緩存 50
3.3.1 上下文切換 51
3.3.2 fork 51
3.3.3 exec 54
3.3.4 exit 54
3.3.5 brk和sbrk 54
3.3.6 共享內存和映射文件 55
3.3.7 I/O 55
3.3.8 用戶-內核數據的歧義 58
3.4 小結 59
3.5 習題 59
3.6 進一步的讀物 61
第4章 帶有鍵的虛擬高速緩存 63
4.1 帶有鍵的虛擬高速緩存的操作 63
4.2 管理帶有鍵的虛擬高速緩存 64
4.2.1 上下文切換 64
4.2.2 fork 65
4.2.3 exec 67
4.2.4 exit 68
4.2.5 brk和sbrk 68
4.2.6 共享內存和映射文件 68
4.2.7 I/O 70
4.2.8 用戶-內核數據的歧義 71
4.3 在MMU中使用虛擬高速緩存 71
4.4 小結 72
4.5 習題 72
4.6 進一步的讀物 74
第5章 帶有物理地址標記的虛擬高速緩存 75
5.1 帶有物理標記的虛擬高速緩存的組成 75
5.2 管理帶有物理標記的虛擬高速緩存 78
5.2.1 上下文切換 78
5.2.2 fork 78
5.2.3 exec 79
5.2.4 exit 79
5.2.5 brk和sbrk 79
5.2.6 共享內存和映射文件 80
5.2.7 I/O 80
5.2.8 用戶-內核數據的歧義 80
5.3 小結 81
5.4 習題 81
5.5 進一步的讀物 82
第6章 物理高速緩存 83
6.1 物理高速緩存的組成 83
6.2 管理物理高速緩存 85
6.2.1 上下文切換 85
6.2.2 fork 85
6.2.3 exec、exit、brk和sbrk 85
6.2.4 共享內存和映射文件 86
6.2.5 用戶-內核數據的歧義 86
6.2.6 I/O和總綫監視 86
6.3 多級高速緩存 91
6.3.1 帶有次級物理高速緩存的主虛擬高速緩存 91
6.3.2 帶有物理標記的主虛擬高速緩存和次級物理高速緩存 93
6.4 小結 94
6.5 習題 95
6.6 進一步的讀物 96
第7章 高效的高速緩存管理技術 97
7.1 引言 97
7.2 地址空間布局 97
7.2.1 虛擬索引的高速緩存 97
7.2.2 動態地址綁定 100
7.2.3 物理索引的高速緩存 101
7.3 受限於高速緩存大小的衝洗操作 102
7.4 滯後的高速緩存無效操作 103
7.4.1 帶有鍵的虛擬高速緩存 104
7.4.2 沒有總綫監視機製的物理標記高速緩存 104
7.5 緩存對齊的數據結構 105
7.6 小結 107
7.7 習題 107
7.8 進一步的讀物 108
第二部分 多處理器係統
第8章 多處理器係統概述 111
8.1 引言 111
8.2 緊密耦閤、共享存儲的對稱多處理器 113
8.3 MP存儲器模型 114
8.3.1 順序存儲模型 115
8.3.2 原子讀和原子寫 115
8.3.3 原子讀-改-寫操作 117
8.4 互斥 119
8.5 迴顧單處理器UNIX係統上的互斥 120
8.5.1 短期互斥 121
8.5.2 帶有中斷處理器的互斥 121
8.5.3 長期互斥 122
8.6 在MP上使用UP互斥策略的問題 124
8.7 小結 125
8.8 習題 125
8.9 進一步的讀物 127
第9章 主從內核 129
9.1 引言 129
9.2 自鏇鎖 130
9.3 死鎖 131
9.4 主從內核的實現 133
9.4.1 運行隊列的實現 133
9.4.2 從處理器的進程選擇 136
9.4.3 主處理器的進程選擇 137
9.4.4 時鍾中斷處理 137
9.5 性能考慮 137
9.6 小結 139
9.7 習題 140
9.8 進一步的讀物 142
第10章 采用自鏇鎖的內核 145
10.1 引言 145
10.2 巨型上鎖 145
10.3 不需要上鎖的多綫程情況 147
10.4 粗粒度上鎖 148
10.5 細粒度上鎖 150
10.5.1 短期互斥 150
10.5.2 長期互斥 151
10.5.3 帶有中斷處理器的互斥 152
10.5.4 鎖的粒度 153
10.5.5 性能 154
10.5.6 內核搶占 154
10.6 休眠和喚醒對多處理器的影響 155
10.7 小結 156
10.8 習題 156
10.9 進一步的讀物 159
第11章 采用信號量的內核 161
11.1 引言 161
11.1.1 采用信號量的互斥 162
11.1.2 采用信號量的同步 162
11.1.3 采用信號量分配資源 163
11.2 死鎖 163
11.3 實現信號量 164
11.4 粗粒度信號量的實現 167
11.5 采用信號量的多綫程 168
11.5.1 長期互斥 168
11.5.2 短期互斥 169
11.5.3 同步 169
11.6 性能考慮 170
11.6.1 測量鎖爭用 170
11.6.2 結對 171
11.6.3 多讀鎖 173
11.7 小結 177
11.8 習題 177
11.9 進一步的讀物 178
第12章 其他MP原語 181
12.1 引言 181
12.2 管程 181
12.3 事件計數和定序器 183
12.4 SVR4.2 MP的MP原語 185
12.4.1 自鏇鎖 185
12.4.2 休眠鎖 187
12.4.3 同步變量 188
12.4.4 多讀鎖 190
12.5 比較MP同步原語 191
12.6 小結 193
12.7 習題 193
12.8 進一步的讀物 194
第13章 其他存儲模型 197
13.1 引言 197
13.2 Dekker算法 198
13.3 其他存儲模型 199
13.4 完全存儲定序 201
13.5 部分存儲定序 204
13.6 作為存儲層次結構一部分的保存緩衝區 206
13.7 小結 207
13.8 習題 207
13.9 進一步的讀物 208
第三部分 帶有高速緩存的多處理器係統
第14章 MP高速緩存一緻性概述 213
14.1 引言 213
14.2 高速緩存一緻性問題 214
14.3 軟件高速緩存一緻性 217
14.3.1 共享數據不被緩存 218
14.3.2 選擇性的高速緩存衝洗 219
14.3.3 處理其他存儲模型 222
14.4 小結 223
14.5 習題 223
14.6 進一步的讀物 224
第15章 硬件高速緩存一緻性 229
15.1 引言 229
15.2 寫-使無效協議 231
15.2.1 寫直通-使無效協議 231
15.2.2 寫一次協議 231
15.2.3 MESI協議 234
15.3 寫-更新協議 235
15.3.1 Firefly協議 235
15.3.2 MIPS R4000 更新協議 236
15.4 讀-改-寫操作的一緻性 236
15.5 多級高速緩存的硬件一緻性 237
15.6 其他主要的
· · · · · · (
收起)
評分
☆☆☆☆☆
从单核的cache设计 引申出 多核smp架构的cache设计,并对单核和多核smp的cache一致性的实现,以及在内核设计时面临的同步和互斥的实现,提供了解决方案。 本书前半部分介绍cache, 后半部分介绍同步和互斥等内核原语的实现方式。 对想了解cache原理和内核原语实现方式的同学有...
評分
☆☆☆☆☆
如果你读过pongba的C++多线程内存模型的博文(http://blog.csdn.net/pongba/article/details/1659952),对里面的一些内容抱有疑惑,并且你想从本质上逐步去解决这些疑惑。这本书可以帮你解答影响内存模型在SMP体系上,以及受Cache影响的所有问题。这本书的内容并不单纯面向内...
評分
☆☆☆☆☆
从单核的cache设计 引申出 多核smp架构的cache设计,并对单核和多核smp的cache一致性的实现,以及在内核设计时面临的同步和互斥的实现,提供了解决方案。 本书前半部分介绍cache, 后半部分介绍同步和互斥等内核原语的实现方式。 对想了解cache原理和内核原语实现方式的同学有...
評分
☆☆☆☆☆
从单核的cache设计 引申出 多核smp架构的cache设计,并对单核和多核smp的cache一致性的实现,以及在内核设计时面临的同步和互斥的实现,提供了解决方案。 本书前半部分介绍cache, 后半部分介绍同步和互斥等内核原语的实现方式。 对想了解cache原理和内核原语实现方式的同学有...
評分
☆☆☆☆☆
如果你读过pongba的C++多线程内存模型的博文(http://blog.csdn.net/pongba/article/details/1659952),对里面的一些内容抱有疑惑,并且你想从本质上逐步去解决这些疑惑。这本书可以帮你解答影响内存模型在SMP体系上,以及受Cache影响的所有问题。这本书的内容并不单纯面向内...