linux內存分配堆棧數據段代碼段,linux – LD_PRELOAD堆棧和數據段內存分配

你好,

我正在編寫一個Linux模塊(基于名為“Ccontrol”的GitHub項目)來創建緩存分區(a.k.a頁面著色),以減輕定時側通道攻擊(用于防止Prime Probe等攻擊).

我已經使用LD_PRELOAD系統env變量來覆蓋所有malloc(),calloc()和free()調用,并用顏色感知調用替換它們.

現在我正在尋找顏色堆棧和數據段的顏色.

用于為新生進程分配內存的系統調用/庫是什么?

有沒有辦法使用LD_PRELOAD或任何其他方法覆蓋此調用(不重新編譯內核)?

謝謝大家,

加爾

解決方法:

有兩個內存分配系統調用:sbrk,它擴展(連續)堆段和mmap,用于將單獨的匿名內存段映射到調用進程的地址空間.

但是,您將無法使用LD_PRELOAD來覆蓋這些.

如果您覆蓋的代碼通過DSO導出的libc包裝器進行這些調用,您將只能執行此操作,這意味著您將無法通過未導出的包裝器覆蓋直接系統調用和系統調用(DSO-internal( __attribute __((visibility(“hidden”)))),大多數libc實現都使用了很多.你也無法覆蓋動態鏈接器所做的系統調用.

如果您需要一種強大的覆蓋調用方式,則需要轉向ptrace或修改內核.

標簽:linux,linux-kernel,linux-device-driver

來源: https://codeday.me/bug/20190705/1391242.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/372560.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/372560.shtml
英文地址,請注明出處:http://en.pswp.cn/news/372560.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【騰訊Bugly干貨分享】Android內存優化總結實踐

本文來自于騰訊Bugly公眾號(weixinBugly),未經作者同意,請勿轉載,原文地址:https://mp.weixin.qq.com/s/2MsEAR9pQfMr1Sfs7cPdWQ 導語 智能手機發展到今天已經有十幾個年頭,手機的軟硬件都已經發…

以編程方式向OpenJPA注冊實體類型

我剛剛開始為Isis開發 OpenJPA對象庫 。 在一般情況下,可以在persistence.xml文件中注冊實體類型。 但是,Isis是一個框架,可以構建自己的元模型,并且可以自行確定哪些類構成實體。 因此,我不想強??迫開發人員重復自己…

linux redis客戶端,Redisson 3.4.0和2.9.0發布,Redis客戶端

Redisson 3.4.0和2.9.0發布,Redis客戶端發布時間:2017-04-27 09:12:16來源:紅聯作者:baihuoRedisson于2017年4月26日發布了3.4.0和2.9.0版本Redisson是架設在Redis基礎上的一個Java駐內存數據網格(In-Memory Data Grid)。充分的利用了Redis鍵值數據庫提供的一系列優…

LeetCode 349 Intersection of Two Arrays

Given two arrays, write a function to compute their intersection. Example: Given nums1 [1, 2, 2, 1], nums2 [2, 2], return [2]. 思路: 利用ArrayList的contains(Object o)方法進行交集的查詢。 解法: 1 import java.util.ArrayList;2 3 publi…

shell腳本1——變量 $、read、``

與Shell變量相關的幾個命令: 變量只在當前Shell中生效. source 這個命令讓腳本影響他們父Shell的環境(. 可以代替source命令) export 這個命令可以讓腳本影響其子Shell的環境 () unset 從環境中刪除變量 其他幾個與變量有關的命令&#xff1…

令人印象深刻的第一個Apache Camel版本

為了準備下周的CamelOne會議,我花了一些時間回顧一下Apache Camel項目的歷史。 因此,除其他外,我了解了Apache Camel的第一個正式1.0版本 。 Apache Camel 1.0 – 5年前 我看的越多,這個版本的事實給我留下了深刻的印象。 現在您…

Linux禁用user01賬戶,Linux?管理用戶?useradd

創建用戶、設置密碼、修改用戶、刪除用戶:useradd testuser 創建用戶testuseruseradd [選項]useradd 命令選項-u uid:指定新用戶的uid,默認用當前最大uid加1-g group:指定新用戶所在的組(私有組),該組必須存在-G group:指定新用戶的附加組-d dir:指定新用戶的自家目…

css小細節

1. 文字居中顯示 水平居中: text-align: center; 垂直居中: line-height: (height); 2.子元素相對于父元素的絕對布局。 父元素一定要 position: relative/absolute/fixed; 默認position 是static 轉載于:https://www.cnblogs.com/zcancandice/p/5…

為什么在2012/2013年我將在新的Enterprise Java項目中繼續使用Spring *和* Java EE

自從我擔任技術決策職務以來已經過去了一年多,很高興看到我仍然與之保持著完美的和諧。 幾個月前,我在KaiWhner的一個不錯的博客中寫了一個有關JEE與Spring的答案。 如果觀點沒有不同,那么討論的附加值在哪里? 我確實同意Kai的許多…

linux ubuntu 五筆輸入法,ubuntu下安裝fcitx五筆輸入法

安裝fcitx輸入法sudo add-apt-repository ppa:fcitx-team/stable #添加安裝源,apt-get 添加,nightly源也可以sudo apt-get update #更新源,否則無法安裝fcit…

淺談Windows下SVN在Android Studio中的配置、基本使用及解除關聯

看到網上很多關于svn環境配置和關聯Android-Studio的很多博文,發現很零散,想集大家所長整理一下: 在AndroidStudio中開發版本控制中,除了Git就是SVN,和Eclipse不同Android Studio沒有提供單獨的插件,只能和…

四. 基于環視Camera的BEV感知算法-BEVDepth

目錄 前言0. 簡述1. 算法動機&開創性思路2. 主體結構3. 損失函數4. 性能對比總結下載鏈接參考 前言 自動駕駛之心推出的《國內首個BVE感知全棧系列學習教程》,鏈接。記錄下個人學習筆記,僅供自己參考 本次課程我們來學習下課程第四章——基于環視Cam…

【騰訊Bugly干貨分享】Android Patch 方案與持續交付

本文來自于騰訊bugly開發者社區,非經作者同意,請勿轉載,原文地址:http://dev.qq.com/topic/57a31921ac3a1fb613dd40f3 Android 不僅系統版本眾多,機型眾多,而且各個市場都各有各的政策和審核速度&#xff0…

App Engine中的Google Services身份驗證,第1部分

這篇文章將說明如何構建一個簡單的Google App Engine(GAE)Java應用程序,該應用程序可針對Google進行身份驗證,并利用Google的OAuth授權訪問Google的API服務(例如Google Docs)。 此外,在Google已…

c語言中空格的作用是什么,C語言中空格和\0的區別

\0 為字符串結束符,比如說:abcd (空格)cdefg;存入數組時,空格作為一個字符占有一個字節的空間,我們可以把它看著一個字符去處理。而“\0 ” 則是這個字符串的結束標識符,也占有一個字節的空間,表…

C++11 新特性:Lambda 表達式

參考文章:https://blogs.oracle.com/pcarlini/entry/c_1x_tidbits_lambda_expressions 或許,Lambda 表達式算得上是 C 11 新增特性中最激動人心的一個。這個全新的特性聽起來很深奧,但卻是很多其他語言早已提供(比如 C#&#xff0…

山東自考c語言程序設計停考了嗎,2018山東自考停考專業有哪些

自考每年都會停考一批的專業以適應社會的發展,今年山東自考的停考專業有哪些?本文由學梯網小編整理發布,僅供參考。2018年山東自考停考專業有什么根據山東省教育考試院發布的《關于山東自學考試停考國際貿易(專科)等19個專業的通知》知悉&…

公開調用私有Java方法?

我們是Java開發人員,在Java中已知4種訪問修飾符:私有,受保護,公共和包。 好吧,除了私有外,最后三個可以通過繼承,相同的包或實例從類外部調用。 現在,常見的問題是,可以公…

Java 異常處理 try catch finally throws throw 的使用和解讀(一)

最近的一個內部表決系統開發過程中,發現對異常處理還存在一些模棱兩可的地方,所以想著整理一下主要涉及到:1.try catch finally throws throw 的使用和解讀2.自定義異常的使用3.常見的運行異常 /** * Java 異常處理 * try catch finally thr…

C語言字符像素,返回字符串寬度 (以像素為單位)

[c]代碼庫#include #include #include #include int main(void){/* request auto detection */int gdriver DETECT, gmode, errorcode;int x 0, y 0;int i;char msg[80];/* initialize graphics and local variables */initgraph(&gdriver, &gmode, "");/…