Linux Kernel Fonksiyonlarını 'Hook'lamak

0
anonim
Linux çekirdeğindeki bir fonksiyonun işleyişini ona zarar vermeden değiştirmek istediğimizi düşünelim. Kaynak kodları değiştirir tekrar derleriz ancak bu yazıda daha farklı bir yöntem izleyecegiz ve hafızadaki kernel'a tamamen geçici bir yama yapacağız.

Bunu, 90ların başlarında MS-DOS virüslerinin çok sevdiği bir tekniği Linux'a uyarlayarak gerçekleştireceğiz.

Hooklamak istediğimiz fonksiyonun başına jmp hook instruction'ını yazdığımızı düşünelim. Gelen her çağrı bize yönlendirilecektir fakat üzerine yazdığımız bölgeyi kullanılamaz hale getirmiş oluruz. Üzerine yazdığımız bölüm kadar yeri yedekleyelebiliriz.

Linux çekirdeğinde 'kernel export'ları nasıl 'hook'lanacağı üzerine olan bu yazıyı ve ilgili kaynak kodları http://blog.int6.net/media/kit.tar.gz adresinden edinebilirsiniz.

Görüşler

0
auselen
Ben de strace'in reklamını yapayım.

Daha önce kullanmayanlar için kısa açıklama; linux'ta sistem çağrılarını gözlemlemenizi sağlayan bir program.

Örneğin komut satırında "strace ls" derseniz, ls komutun hangi sistem komutlarını çağırdığını görürsünüz.

Bundan da güzeli, sistemin bu uygulamayı çalıştırmadan önce neler yaptığını, mesela hangi sistem kitaplıklarını açtığını görürsünüz.

Sistemde çalışmayan bir uygulama olduğunda oldukça yararlı olduğunu söyleyebilirim.

http://en.wikipedia.org/wiki/Strace
http://sourceforge.net/projects/strace
0
Tarık
reklama ne hacet, tepe tepe kullanıyoruz. bende bir bağlantı atayım da tam olsun :) ayrıca aynı yerden şunu da yiyebilmekteyiz.
0
Tarık
ayrıca hdd ye indirilip yazıcı çıktısı alınası...
0
FZ
Bu tür yazıların devamını bekliyoruz ;-)
0
realist
Tüm FM yazıları böyle olsun, beni aşsın, afallatsın. Nasıl yapıldığını anlamam için cilt cilt okumam gereksin.
0
FZ
Ve sonra FM sadece tek bir konu üzerinde 100 cilt kitap okuyup 15 yıldır çalışan birkaç uzmanın uğrak noktası olsun diğer herkes seyirci kalsın ve bir süre sonra onlar da sıkılıp, pek bir şey anlamayıp gitsinler :-p
0
mos
ben de bu bakış aşısından yanayım :)
0
anonim
Ben anladım sanırsam.

önce o büyük düğmeye basıyoduk deilmi?...
Görüş belirtmek için giriş yapın...

İlgili Yazılar

Mono + Knoppix = Monoppix !

demolish

Monoppix, Knoppix tabanlı bir çalışan cd dağıtımı. Adından da anlaşılacağı üzere Mono teknolojisini tanıtmak ve yaymak için oluşturulmuş. Mono, .Net teknolojisinin sadece framework kısmının özgür alternatifi ve daha fazlası. Cd içerisinde:
Mono runtime environment,complier and class libraries.
Mono enabled IDE.
ASP.NET web server.
MySQL DB.
ve Mono ile ilgili dokümanlar mevcut.

Yeni bir Linux Projesi için Yardım Çağrısı

anonim

Yeni başlayan (henüz hiçbir sürümü yok) bir Linux dağıtımı na teknik olmayan bazı konularda yardım ediyorum.

Proje henüz çok yeni olduğu için ve teknik olarak çok yoğun ziyaretleri web sitenin (şimdilik) kaldırması zor olduğu için proje başkanı benden şimdilik sadece gerçekten yardım edeceğine inandığım kişileri siteye yönlendirmemi rica etti. Bu yüzden projenin ismini malesef şimdilik veremiyorum. Ancak kısaca anlatmam gerekirse bu proje tamamen açık yazılım temeline oturacak ve herhangi bir ticari amacı olmayacak (Debian modeli). RH tabanlı bir işletim sistemi olacak ve kullanıcılarının projeye katkı sağlaması için tasarlanacak.

SUSE Novell tarafından satın alındı!

sundance

Dünyanın önde gelen IT firmalarından Novell, Ağustos ayında Ximian'ı satın almasının ardından bugün SUSE ile anlaşmaya vardığını açıkladı.

Böylelikle ilk defa milyar dolar seviyesinde sermayeye sahip bir firma kendi Linux dağıtımını geliştirip yaymaya başlayacak. Anlaşmanın bedeli olan 210 milyon doların mali yılın ilk çeyreği içinde SUSE'ye verilmesi bekleniyor.

Xbox üzerinde Linux

tongucyumruk

Bu Linux'çular gerçekten gıcık insanlar... Şimdide Bill'in sinirini bozmak için MS'in gülü Xbox üzerinde Linux kullanmaya çalışıyorlar. Yavaş yavaş ilerleme kaydeden arkadaşların ana Hedefi temel Linux uygulamalarını, kerneli ve X, Gnome KDE gibi sistemleri Xbox üzerine port edebilmek... Bu sayede Xbox makinaları kullanarak clustering yapmaktan bahsediyorlar ki bir Xbox'ın fiyatına oranla sunduğu işlem gücü düşünüldüğünde kulağa oldukça mantıklı geliyor. Ayrıca Linux yükleyip birde TV çıkışını VGA'ya çeviren adaptör kullanarak Xbox'ı bildik PC donanımlarıyla (klavye mouse vs...) kullanabilmek'te yapılabilecekler arasında... Şu an itibariyle önlerindeki en önemli problem Xbox yazılımlarının dijital imza mecburiyeti gibi gözüküyor... Eğer bu tip bir kontrol donanım tabanlı olarak yapılıyorsa işleri oldukça zor demektir.

Vector 3.0 çıktı

anonim

DistroWatch'un haberine göre Vector Linux 3.0 versiyonu cikti. Bu versiyonda önemli yenilikler var. Tamamen Slackware tabanlı hale getirilen dağıtımda ayrıca Slackware'in paket araçları pkgtools da bulunuyor. Bu sayede Slackware için olan her paketi (ve update'leri) yükleyebilirsiniz. Ayrica LSB uyumlu ve versiyon 2.5'a göre sadece 20MB daha büyük !