<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/rss2enclosuresfull.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.feedburner.com/~d/styles/itemcontent.css"?><rss xmlns:media="http://search.yahoo.com/mrss/" xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd" version="2.0"><channel><title>Kernel Turk</title><link>http://kernelturk.blogspot.com/</link><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/rss+xml" href="http://feeds.feedburner.com/KernelWorks" /><description></description><language>en</language><managingEditor>noreply@blogger.com (Ibrahim Akgul)</managingEditor><lastBuildDate>Sat, 24 Dec 2011 12:05:18 PST</lastBuildDate><generator>Blogger http://www.blogger.com</generator><openSearch:totalResults xmlns:openSearch="http://a9.com/-/spec/opensearch/1.1/">28</openSearch:totalResults><openSearch:startIndex xmlns:openSearch="http://a9.com/-/spec/opensearch/1.1/">1</openSearch:startIndex><openSearch:itemsPerPage xmlns:openSearch="http://a9.com/-/spec/opensearch/1.1/">25</openSearch:itemsPerPage><feedburner:info xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" uri="kernelworks" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><media:category scheme="http://www.itunes.com/dtds/podcast-1.0.dtd">Technology/Gadgets</media:category><itunes:owner><itunes:email>noreply@blogger.com</itunes:email></itunes:owner><itunes:explicit>no</itunes:explicit><itunes:subtitle></itunes:subtitle><itunes:category text="Technology"><itunes:category text="Gadgets" /></itunes:category><item><title>Kernel Mode Driver Nedir? Nasıl Yazılır?</title><link>http://kernelturk.blogspot.com/2011/07/kernel-mode-driver-nedir-nasl-yazlr.html</link><category>windows arthitecture</category><category>Device Driver</category><category>masm32</category><category>kernel mode driver</category><category>kernel mode</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Wed, 27 Jul 2011 05:51:39 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-4170223212587363665</guid><description>&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;&lt;br /&gt;
&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Tekrar merhabalar, seneler önce merakla Windows Nt tabanlı sistemler üzerinde Kernel Mode Driver &amp;nbsp;yazımı için kaynak aradığım zamanlardan rastladığım ve beğenerek takip ettiğim F-Four serisinden öğrenmiş olduğum bilgilerin ilk bölümünü arşivlerimden sizlerin huzuruna sunuyorum:&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Bu makale de güncel olarak kullanılan Microsoft Windows 2003, XP, 2000, NT4.0 gibi Windows NT tabanlı işletim sistemleri üzerinde 32-Bit Assembly dili kullanılarak Kernel-Mode Aygıt sürücülerinin (device drivers) nasıl yazılacağı anlatılacaktır. Windows 95/98/ME versiyonları için VxD sürücüleri geliştirmek ise bu makalenin alanı dışındadır. Muhtemelen size aktardığım bilgilerde bazı konsept farklılıkları ve kişisel hatalar yapabilirim. &lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoListParagraph" style="line-height: normal; mso-add-space: auto; mso-list: l5 level1 lfo6; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 2; text-indent: -18.0pt;"&gt;&lt;span style="color: black; font-family: Symbol; font-size: 18pt;"&gt;·&lt;span style="font: normal normal normal 7pt/normal 'Times New Roman';"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/span&gt;&lt;/span&gt;&lt;b&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;Mimariyi Tanıyalım&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d1"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 18pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 3;"&gt;&lt;b&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;Ana Sistem Bileşenleri&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d1d1"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Windows NT'nin&amp;nbsp;mimarisi&amp;nbsp;dahili olarak code denetimi (code permissions) ve adres boşluğu (address space) olarak iki kısma ayrılmıştır. Bu ayırım işlemi ile daha güvenli ve daha esnek bir işletim sistemi oluşturulması amaçlanmıştır. Ayrıca programcılar içinde yeni nesil işlemcilerin tüm yeteneklerinin kullanılması amaçlanmıştır. İşletim sistemi üzerinde&amp;nbsp;çalışacak her programın çalışması için bir hafıza alanına ihtiyacı vardır. Bu alanlar&amp;nbsp;işletim sistemi tarafından adres boşluklarının organize bir şekilde yönetilmesi&amp;nbsp;ile uygulamalara paylaştırılır.&amp;nbsp;Adres boşluğunun paylaşımı ise sanıldığının aksine basit bir mantığa dayanmaktadır. 32-Bit işlemci mimarisinde Adreslenebilir 4GB hafıza iki eşit parçaya ayrılır (tabi burada Fiziksel Adres açılımı olan PAE desteğini yok sayıyoruz)&amp;nbsp; ve bu iki parçadan kullanıcı modun'da (user-mode) olana bu boşluğun en düşük alanı olan 00000000 - 7FFFFFFFh adresleri arasındaki 2GB'lık alan verilir. Yani User-Mode dediğimiz user process'leri bu hafıza alanında çalışır ve bu onlar için bir sınır değerdir. Diğer kalan üst limit 80000000 - 0FFFFFFFFh 'lik doğrusal hafıza alan adresi oranı ise aygıt sürücüleri (device drivers) , sistem hafıza havuzu (system memory pools) ve sistem data yapıları (system data structures) gibi sistem bileşenlerine verilir. Bu adres oranlarına adreslenebilir hafıza alanları diyoruz. Bu hafıza alanları arasındaki ayrım ve yönetim işlemlerini ise hangi bileşenlerin kontrol ettiğini makalenin ilerleyen kısımlarında ayrıntılı bir şekilde işleyeceğiz.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;User-mode'da çalışan temel işlemleri aşağıdaki şekilde tanımlayabiliriz:&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l4 level1 lfo1; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Sistem Destek İşlemleri (System Support      Processes)&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;örneğin,&amp;nbsp;Logon      process'i&amp;nbsp;(\%SystemRoot%\System32\Winlogon.exe&amp;nbsp;dizininde yer alır);&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l4 level1 lfo1; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Hizmet İşlemleri (Service Processes)&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;örneğin,&amp;nbsp;Yazıcılar      için&amp;nbsp;Spooler&amp;nbsp;servisi&amp;nbsp;(\%SystemRoot%\System32\spoolsv.exe'da      yer alır);&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l4 level1 lfo1; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Kullanıcı uygulamaları (User Applications)&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;beş çeşittir: Win32, Windows 3.1, MS-DOS,      POSIX&amp;nbsp;ve&amp;nbsp;OS/2;&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l4 level1 lfo1; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Ortam AltSistemleri (Environment Subsystems)&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;Windowsta üç çeşit ortama ait processleri      çalıştırabilirsiniz: Win32 (\%SystemRoot%\System32\Csrss.exe&amp;nbsp;yer      alır); POSIX (\%SystemRoot%\System32\Psxss.exe'yer alır); OS/2      (\%SystemRoot%\System32\Os2ss.exe&amp;nbsp;yer alır).&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Windows XP ile birlikte artık&amp;nbsp;OS/2 alt sistemi kaldırılmıştır.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Kernel-Mode bileşenleri ise aşağıdaki gibi tanımlanabilir:&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l0 level1 lfo2; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Yönetim (Executive)&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;hafıza yönetimi,      process&amp;nbsp;ve&amp;nbsp;thread&amp;nbsp;yönetimi, security, etc.;&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l0 level1 lfo2; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Kernel&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-      thread'ların&amp;nbsp;planlanması,&amp;nbsp;kesme isteği(interrupt) ve istisna      işleme (exception dispatching), etc. (Executive&amp;nbsp;ve&amp;nbsp;Kernel      \%SystemRoot%\System32\Ntoskrnl.exe&amp;nbsp;tarafından icra edilir);&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l0 level1 lfo2; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Aygıt Sürücler (Device Drivers)&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;Donanım aygıt sürücüleri (hardware device      drivers),&amp;nbsp;dosya sistemi sürücüleri (file system) ve ağ sürücüleri      (&amp;nbsp;network drivers);&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l0 level1 lfo2; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Donanımdan soyutlandırma katmanı (Hardware      Abstraction Layer)&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;, HAL -      Kernel'den aygıt sürücülerden yönetim biriminden ve platforma özel donanım      farklılıklarından yalıtılmış bir birimdir.&amp;nbsp;(      \%SystemRoot%\System32\Hal.dll'de yer alır);&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l0 level1 lfo2; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Pencere ve Grafik sistemi (Windowing And Graphics      System)&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;Pencerelerle çalışmak, kullanıcı      arayüz kontrolleri ve çizim (drawing) işlemleri ile uğraşmak için      grafiksel kullanıcı arayüzü (Graphical user interface [GUI]) fonksiyonları      sağlar.&amp;nbsp;( \%SystemRoot%\System32\Win32k.sys'de yer alır).&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 3;"&gt;&lt;b&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;1.1.2 Kernel Mode vs. User Mode&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d1d2"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Aslında Intel x86 işlemcileri 4 adet imtiyaz seviyesi (privilege levels) sağlar (ring olarakta anılırlar) , ancak Windows bunlardan sadece 2 sini kullanır. Bunlar Kernel-Mode için privilege levels 0 (veya ring0) , user-mode için ise privilege levels 3 (veya ring3) seviyesidir.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Her user-mode processi kendine ait özel bir hafıza boşluğuna sahiptir. Processler en düşük imtiyaz seviyesinde (user-mode veya ring 3 diyebilirsiniz) çalıştıklarından, özel cpu komutlarını&amp;nbsp;icra edemez,&amp;nbsp;sistem data'ları ve sistem adres boşluğuna erişim sağlayamaz ve donanıma doğrudan erişim yapamazlar. Örneğin user-mode'da çalışan bir process adres boşluğunun kernel-mode tarafına ait bir orandaki hafıza adresine (8000000-0FFFFFFFFh) ulaşmaya çalışırsa, sistem o işlemi hemen sonlandıracaktır. User-Mode processleri sistem servislerini çağırarak kernel-mode'a geçiş yapabilirler ancak bu durum o hizmete yaptırılan işlemlerle sınırlıdır ve&amp;nbsp; process user-mode'a döner dönmez tüm kontrolü tekrar kaybedecektir.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;User-Mode processleri sistem stabilizesini bozabileceklerinden potansiyel tehlike olarak görünürler. Bu yüzden sahip olduğu imtiyazlar sert çizgilerle belirlenmiştir ve yetkisizce yapmaya çalıştığı her işlem anında sonlandırılır.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Kernel-Mode bileşenleri ise kernel-mode hafıza alanını ortak bir şekilde paylaşırlar, en üst imtiyazlarla (ring0) çalışabilir ve istedikleri CPU komutunu çalıştırabilirler. Kısacası erişimleri sınırsızdır.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Sistemin adres boşluğunda çalışan kodlar tümüyle güvenilir olarak düşünülür. Bir sürücünün yüklenmesi esnasında sistem o sürücü kodlarını kendi bölümüymüş gibi varsayar. Driver'lar kernel'in kendi güvenilir bileşenleri listesinde yer aldığından istediği her erişimi sınırsızca yapabilir.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Tam olarak ifade edersek user-mode uygulamaları işletim sistemi tarafından bütünüyle soyutlanmıştır. Aslında bu işletim sisteminin bütünlüğü açısından iyidir, fakat , debugging araçları gibi bazı yardımcı araçların için tam bir baş ağrısıdır. User-Mode uygulamaları ile sistemle bütünleşik bir yazılım gerçekleştirmek&amp;nbsp;çoğu zaman imkansızdır. İşletim sisteminin dahili fonksiyonları ve data yapıları'na user-mode'dan asla ulaşamazsınız bunun için yapmanız gereken sistem adres boşluğunun içerisine girmektir buda&amp;nbsp; kernel-mode&amp;nbsp;düşerek olur.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 2;"&gt;&lt;b&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Windows NT Device Drivers&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d2"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 18pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 3;"&gt;&lt;b&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;1.2.1&amp;nbsp;Aygıt Sürücülerinin Tipleri&lt;/span&gt;&lt;/b&gt;&lt;b&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Windows NT geniş bir yelpazede aygıt sürücü tiplerini destekler, bunları aşağıdaki gibi listeleyebiliriz:&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l2 level1 lfo3; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;User-Mode Drivers&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;:&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;ul type="circle"&gt;&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l2 level2 lfo3; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 72.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Virtual Device Drivers&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;(VDD) -&amp;nbsp;16-bit MS-DOS uygulamalarını emule edebilmek için       kullanılan bir user-mode bileşenidir. Karıştırmayasınız diye yazıyorum       Win 9x zamanı VxD'lerle benzer bir yanları yoktur.&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l2 level2 lfo3; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 72.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Printer Drivers&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;Aygıttan bağımsız baskı isteklerini yazıcıya özel       komutlara çevirirler.&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l2 level1 lfo3; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Kernel-Mode Drivers&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;:&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;ul type="circle"&gt;&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l2 level2 lfo3; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 72.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;File System Drivers&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;Standart dosya sistem işlemlerini yerine getirirler.&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l2 level2 lfo3; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 72.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Legacy Drivers&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;Windows 2000/XP/2003 üzerinde değişmemiş ama önceki       Windows NT versiyonları için yazılmış farklı sürücülerden yardım       almaksızın bir donanım aygıtını kontrol etmeye yarayan sürücü çeşididir.&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l2 level2 lfo3; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 72.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Video Drivers&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;görsel data işleme;&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l2 level2 lfo3; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 72.0pt;"&gt;&lt;b&gt;&lt;i&gt;&lt;span style="color: #636363; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Streaming Drivers&lt;/span&gt;&lt;/i&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;-&amp;nbsp;ses ve tv kartı gibi multimedia aygıtları içindirler;&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: black; line-height: normal; mso-list: l2 level2 lfo3; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 72.0pt;"&gt;&lt;b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;WDM-Drivers -&amp;nbsp;&lt;/span&gt;&lt;/b&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Windows       Driver Model konseptine bağlıdırlar. WDM; Windows NT'nin güç yönetim       desteğini ve tak çalıştır desteğini destekler. WDM'ler işletim sistemleri       arasında binary uyumlulukları sayesinde kaynak-uyumu sağlarlar. Örneğin       Windows 2000 için yazılmış bir WDM driver Windows Me ve 98 üzerinde       çalışabilir.&lt;/span&gt;&lt;span style="font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Bunlardan farklı modellerde vardır ancak şimdilik bu konsepti tanımanız açısından yeterlidir.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Adlarında da gayet net anlaşılacağı gibi aygıt sürücüler bir aygıtı kontrol etmek için kullanılırlar. Ancak iyi bir tarafları vardır ki bu aygıt illa ki fiziksel bir aygıt olmak zorunda değildir. Dilerseniz sanal bir aygıt oluşturup onu programlayabilirsiniz.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Yapısal olarak aslında aygıt sürücüleri bir PE-format (Exe) dosyasından başka bir şey değildir. Aygıt sürücüler (Device Drivers) yüklenebilir kernel-mode modülleridirler. Genel olarak .sys uzantılarına sahiptirler. Aygıt sürücüler yükleme ve yönetim açısından bütünüyle farklı yollara sahiptirler. Gerçekte kernel-mode dll'leri user-mode tarafında çözülemeyecek görevleri yerine getirilmesi için tasarlanırlar. Bir de şu var ki biz user-mode processlerimiz ile aygıt sürücülerimizin ne kod ne de data alanlarına ulaşamayız. Bizim sürücülerimizle irtibat kuracağımız tek yol&amp;nbsp;&lt;b&gt;&lt;i&gt;I/O Yöneticisi&lt;/i&gt;&lt;/b&gt;&amp;nbsp;(&lt;b&gt;&lt;i&gt;I/O Manager&lt;/i&gt;&lt;/b&gt;)'dir.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Kernel-mode aygıt sürücüsü geliştirme aşamasında kendinizi bütünüyle çaylak hissedecek ve aslında önceden öğrendiğiniz onca programlama ve Win32API bilgisinin şimdi nasıl olup ta size yardımcı olamadığına şahit olacaksınız. Belki bundan önce hatırı sayılır user-mode uygulamaya imza atmış olabilirsiniz ancak kernel-mode mimarisinin komutları ve yapıları bütünüyle farklıdır.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoListParagraph" style="line-height: normal; mso-add-space: auto; mso-list: l5 level1 lfo6; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 3; text-align: justify; text-indent: -18.0pt;"&gt;&lt;span style="color: black; font-family: Symbol; font-size: 13.5pt;"&gt;·&lt;span style="font: normal normal normal 7pt/normal 'Times New Roman';"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/span&gt;&lt;/span&gt;&lt;b&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;Katmanlı ve Monolithic&amp;nbsp;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d2d2"&gt;&lt;/a&gt;(Tek-Katmanlı) Aygıt Sürücüleri&lt;/span&gt;&lt;/b&gt;&lt;b&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm; text-align: justify;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Katmanlı sürücülerin çoğu fiziksel aygıtları kontrol etmek için yazılırlar. Adlarından gayet net anlaşıldığı gibi katmanlı sürücüler drivers stack olarak ta anılan bir konseptle en alt katmandaki sürücülere en üst katmandan aldıkları istekleri işleyerek veya bunun tam tersini yaparak çalışırlar. Bu mimaride I/O isteklerinin işlenmesi (handling request) görevi farklı sürücüler arasında dağıtılmıştır. Örneğin sabit disk üzerindeki bir dosyayı okumak isteyen uygulama’nın i/o istekleri önce dosya sistem sürücüsüne geçirilecek, oradan da disk sürücüsüne yönlenecek ve disk üzerinde veriyi okuyacaktır. Driver geldiği katmansal yolun tam tersini işleyerek veriyi uygulamaya ulaştıracaktır. Dilerseniz sizde bu katmansal mimarinin herhangi bir yerinde araya girerek filter-driver yazabilir , gelen ve giden veriyi encrypt/decrypt gibi şifreleme işlemlerine tabi tutabilirsiniz.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Monolithic driver ‘lar ise aygıt sürücülerin en basit tipleridirler. Yine adlarından anlaşılacağı gibi katmansız bir mimarileri vardır ve layered modeldeki gibi diğer driver’lar ile i/o işleme konusunda herhangi bir paylaşım yapmazlar. Sık olarak doğrudan user-mode uygulamalarına tek başlarına arayüz olarak destek vermeleri gerektiklerinde yazılırlar. Geliştirme ve debugging hizmetleri ise tanımlanabilir en basit görevleridir. Zaten makalenin ilerleyen kısımlarında böyle bir driver yazacağız ve ne anlatmak istediğimi daha iyi anlayacaksınız. Diğer aygıt sürücüsü kategorileri ise şimdilik yazımızın kapsamı dışındadır.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;div class="MsoListParagraph" style="line-height: normal; mso-add-space: auto; mso-list: l5 level1 lfo6; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 2; text-align: justify; text-indent: -18.0pt;"&gt;&lt;span style="color: black; font-family: Symbol; font-size: 18pt;"&gt;·&lt;span style="font: normal normal normal 7pt/normal 'Times New Roman';"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/span&gt;&lt;/span&gt;&lt;b&gt;&lt;span style="color: black; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;Thread context&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d3"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 18pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm; text-align: justify;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Çoğu durumda yalnızca tek bir işlemciye sahip olduğumuz için, sistemin uygulamaları icra ediş şekli bizi hep bu işlemlerin aynı anda oluyormuşcasına izlenimine sokar. Çalışan tüm uygulamalar için işletim sistemi cpu zamanını herbir processin thread’ları için ayrı ayrı dilimlere ayırır. Cpu tek bir kaynaktır ve bu kaynağı işlemlerin sırası ile kullanabilmesi için Round-Robin denen algoritma kullanılır. Bu teknik sayesinde cpu ile olan işi kendine verilen quantum sürelik zamanı aşmasına rağmen bitmeyen bir thread’ın o anki tüm çalışma bilgileri bir yapıya geçirilip (CONTEXT) makine durum registerleri (msr)’lere saklanır ve sonraki thread’a geçilir.&amp;nbsp;&amp;nbsp;Tabi bu teknik aslında çok daha kompleks işlerde yapar ama şimdilik bunlar bizim için yeterlidir. Birde fiziksel olarak işlemcilerin 1’den fazla olduğu durumlar vardır ki o zaman thread scheduling işlemi daha da karmaşık bir hal alır. Böyle bir yapıda thread’lar çekirdekler arası yük paylaşımına sokulur ve işletim sistemi çok daha gelişmiş kompleks algoritmalar kullanarak yönetim yapar. Thread’lar arası geçişte eğer bir sonraki çalışma sırası gelen thread aynı uygulamaya ait bir thread ise , işlemci tarafında sadece yukarıda tanımlamasını yaptığım basit bir thread context gerçekleşir. Lakin geçiş yapılan thread farklı bir process’e ait bir thread ise , işte o zaman hem bir “thread context switch” hemde işlemcinin CR3 register’inin içerisine o processe ait page table yüklenir.&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm; text-align: justify;"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm; text-align: justify;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Her kullanıcı işlemi (user process) kendine ait özel bir adres alanına sahiptir. Bu da şu demektir ki : her user process’i sayfa tablolarını (page tables) farklı sayfa dizinlerinde (page directory) tutar. Sayfa tabloları (page tables) sanal (virtual) adresleri fiziksel adreslere çevirmek için işlemcinin kullandığı tablolardır. Bu tabloları hazırlamak işlemcinin sorumluluğundadır ve her process’te mutlaka olmalıdır. İşlemci context’ine girdiği thread’in cr3 register’inada bakarak kullanacağı hafıza alanını tespit eder ve hafıza alanından faydalanmasını sağlar. Aslında kernel-mode’da driver yazarken bu işlemlerle bizim doğrudan bir etkileşimimiz yoktur. Fakat her context switch cpu israfına neden olduğundan driverlar genellikle kendileri thread olusturmazlar . Bu yüzden context switch’ler esnasında CPU zamanından tasarruf edebilmek için kernel-mode’da çalışan driver’lar üç çeşit context’ten birini kullanır:&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm; text-align: justify;"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm; margin-left: 36.0pt; margin-right: 0cm; margin-top: 0cm; text-align: justify; text-indent: -18.0pt;"&gt;&lt;span style="color: #333333; font-family: Symbol; font-size: 10pt;"&gt;·&lt;/span&gt;&lt;span style="color: #333333; font-family: 'Times New Roman', serif; font-size: 7pt;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/span&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Kullanıcı thread’inin context’in de bir I/O işlemi ile birlikte ;&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm; margin-left: 36.0pt; margin-right: 0cm; margin-top: 0cm; text-align: justify; text-indent: -18.0pt;"&gt;&lt;span style="color: #333333; font-family: Symbol; font-size: 10pt;"&gt;·&lt;/span&gt;&lt;span style="color: #333333; font-family: 'Times New Roman', serif; font-size: 7pt;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/span&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Kernel-mode sistemi bağlamındaki threadlar olarak;&lt;/span&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Veya bir interrupt vasıtası ile&amp;nbsp;&amp;nbsp;.&lt;/span&gt;&lt;/i&gt;&lt;span style="color: black; font-family: 'Times New Roman', serif; font-size: 13.5pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-bottom: .0001pt; margin-bottom: 0cm;"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;div class="MsoListParagraph" style="line-height: normal; mso-add-space: auto; mso-list: l5 level1 lfo6; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 2; text-indent: -18.0pt;"&gt;&lt;span style="color: #333333; font-family: Symbol; font-size: 18pt;"&gt;·&lt;span style="font: normal normal normal 7pt/normal 'Times New Roman';"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/span&gt;&lt;/span&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;Kesme isteği seviyeleri&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d4"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 18pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Kesmeler (interrupts) her işletim sisteminin de bulunan en önemli kısımlardandır. Her kesme oluştuğunda işlenmesi gerekir ve bu yüzden işlemci bir kesme oluştuğunda o anki normal akışını durdurur ve kesme'yi ilgilendiren koda dallanır. Yazılımsal ve Donanımsal olarak iki tip kesme vardır. Kesme'lere önceliklerine göre hizmet edilir. Düşük önceliğe sahip bir kesme akışına devam ederken, sonradan gelen yüksek öncelikli bir kesme bu akışı durdurup akışı ele geçirebilir.&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Windows kesmelerin öncelik şemasını&amp;nbsp;&lt;b&gt;&lt;i&gt;kesme isteği seviyeleri&lt;/i&gt;&lt;/b&gt;&amp;nbsp;(&lt;b&gt;&lt;i&gt;interrupt request levels&lt;/i&gt;&lt;/b&gt;[IRQL]) olarak bilinen bir sistemle yönetir. Kernel IRQL'leri 0 dan 31'e kadar olan bir öncelik sırasına göre sıralar. Bu seviyelerden en yüksek duruma sahip olan en imtiyazlı interrupt olarak bilinir. Unutmadan belirtmeliyim ki IRQL imtiyaz seviyeleri ile işleç-programlama (thread-scheduling) arasında farklılıklar vardır. Bu yüzden birbirleri ile karıştırmayın.&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Yukarıda ki tanımlamalarımıza göre&amp;nbsp;IRQL=0&amp;nbsp;'a sahip bir kesme aslında bir kesme olayı başlatıp bir kodun akışını kesmez. Yani açıkçası aslında zaten o bir kesme değildir. User-Mode'da çalışan her thread passive level'de yürütülür. Bizim yazacağımız kodlarda bu IRQL seviyesinde olacaklardır. Böylelikle yazdığımız kodlar, başka akışların yarıda kesilmesine sebebiyet doğurmayacak. Tabi bu demek değildir ki her driver passive level de çalışacak. Bu sadece bizim örneklerimiz için geçerlidir.&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Son olarak şunları belirtmekte fayda var:&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Birincisi: Sürücü kodlarını icra ederken daha yüksek IRQL'le sahip bir işlem tarafından her zaman için akışı kesilebilir. Sürücü içersinde kod işleme aşamasında güncel IRQL seviyenizi öğrenebilir ve işleminizin yarıda kesilmemesi gereken kod bloklarında IRQL seviyenizi arttırabilir ve azaltabilirsiniz.&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;İkinci olarak:&amp;nbsp;Passive IRQL seviyesindeyken bile her kernel fonksiyonunu çağırabilirsiniz. (Ayrıca DDK her fonksiyon için istenen IRQL seviyesini belirtmiştir). Ayrıca sayfalı(paged) ve sayfasız(nonpaged) adresleme yapabilirsiniz. Hafıza Yöneticisi sayfa hatası (page fault) hizmetleri açısından yetersiz kaldığından yüksek bir IRQL'de (DISPATCH_LEVEL veya daha yüksek (15-31 arası mesala)) paged bir hafıza alanına erişmeyi denerseniz sistemin çökmesine sebep olursunuz.&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoListParagraph" style="line-height: normal; mso-add-space: auto; mso-list: l5 level1 lfo6; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 2; text-indent: -18.0pt;"&gt;&lt;span style="color: #333333; font-family: Symbol; font-size: 18pt;"&gt;·&lt;span style="font: normal normal normal 7pt/normal 'Times New Roman';"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/span&gt;&lt;/span&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;Sistem Çökmeleri&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d5"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 18pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Daha önce hiç rastlamadım demeniz mümkün değil! Neden mi bahsediyorum? Tabi ki Meşhur Mavi Ekrandan (BSOD[Blue Screen of Death]). Muhtemelen hepte hiç beklemediğimiz bir anda ansızın karşımıza çıkmıştır. Ama onu uzun süredir göremiyorsanız üzülmeyin, çünkü kernel-mode'da driver yazarken kendisi ile bol bol haşır neşir olucaz :)&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Windows kermel-mode 'da çalışan sürücüler tarafından kullanılan özel sistem hafızasını korumak için herhangi bir koruma işlemi yapmaz. Driver kernel-mode'a bir kere kancayı attımı artık tüm işletim sistemi dataları ve sistem hafıza alanı onun için serbest bölgedir. Bu yüzden driver'imizi kodlarken önceden planlı bir yapılanma izleyip sistem stabilitesini tehlikeye atmamamız şart.&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Artık yukarıda anlatılanları iyice kavramanız şart. Şayet sizde kernel-mode'da bir driver'da benim olsun diyenlerdenseniz thread context, interrupt request levels, kernel-mode ve user-mode etc... gibi kavramlara mutlaka aşina olmak zorundasınız.&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoListParagraph" style="line-height: normal; mso-add-space: auto; mso-list: l5 level1 lfo6; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 2; text-indent: -18.0pt;"&gt;&lt;span style="color: #333333; font-family: Symbol; font-size: 18pt;"&gt;·&lt;span style="font: normal normal normal 7pt/normal 'Times New Roman';"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/span&gt;&lt;/span&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;Driver Development Kit&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d6"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 18pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Windows DDK ile aygıt sürücü geliştirme aşamasında ihtiyacımız olan tüm dahili sistem rutinleri ve data yapılarına erişebiliriz. Windows DDK, MSDN Profesyonel üyeliliğinin bir parçasıdır. Dilerseniz&amp;nbsp;&lt;/span&gt;&lt;a href="http://web.archive.org/web/20080626074533/http:/msdn.microsoft.comdan/" target="_blank"&gt;&lt;span style="color: #666666; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;http://msdn.microsoft.com 'dan&lt;/span&gt;&lt;/a&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;online olarak dokümantasyonlara erişebilir ve eğer Türkiye'de iseniz sembolik ( kızmayın :p ) bir ücret ödeyerek kargo ile microsoftun size gerekli kütüphane ve örneklerle komple kiti&amp;nbsp; göndermesini sağlayabilirsiniz.&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoListParagraph" style="line-height: normal; mso-add-space: auto; mso-list: l5 level1 lfo6; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 2; text-indent: -18.0pt;"&gt;&lt;span style="color: #333333; font-family: Symbol; font-size: 18pt;"&gt;·&lt;span style="font: normal normal normal 7pt/normal 'Times New Roman';"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/span&gt;&lt;/span&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;MASM programcıları için&amp;nbsp;Kernel-Mode Driver Kit&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d7"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 18pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;KmdKit sizin assembly dilinin gücünü ve Masm32 compiler'inin yeteneklerini birleştirerek aygıt sürücüleri yazabilmenizi sağlayacak alt yapıyı oluşturur. İndirmek için lütfen tıklayın :&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;http://www.freewebs.com/four-f/KmdKit/KmdKit.zip&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoListParagraph" style="line-height: normal; mso-add-space: auto; mso-list: l5 level1 lfo6; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 2; text-indent: -18.0pt;"&gt;&lt;span style="color: #333333; font-family: Symbol; font-size: 18pt;"&gt;·&lt;span style="font: normal normal normal 7pt/normal 'Times New Roman';"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/span&gt;&lt;/span&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;Driver Debugging&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d8"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 18pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Yazdığımız kernel-mode sürücülerini yine kernel-mode'da çalışacak debugger'lar vasıtası ile analiz edebiliriz. Bunun için en ideal araç ve tercihim Compuware firmasının Driver Studio ürünüdür. İçerisinde barındırdığı güçlü debugging yetenekleri ve sembol dosyası desteği ile daha boot aşamasından itibaren kernel'i ve yükleme aşamasından itibarende driver'larımı ayrıntılı olarak debug etme fırsatımız oluyor. Ayrıca birde microsoftun ücretsiz WinDbg ürünü var. Şayet iki pc'niz var ise diğer pc'nin kernelini adım adım yükleyebilir ve tüm sistemi tam anlamı ile kontrol edebilirsiniz. Birde ünlü SysInternals ekibinden Mark Russionovich'in yazdığı tool'u kullanarak windbg ile ikinci bir pc'ye ihtiyaç duymadan live debuging yapabilirsiniz.&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; mso-outline-level: 2;"&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 12pt;"&gt;Faydalı kaynaklar&lt;/span&gt;&lt;/b&gt;&lt;a href="http://www.blogger.com/post-edit.g?blogID=1664781491659878902&amp;amp;postID=4170223212587363665" name="k1d9"&gt;&lt;/a&gt;&lt;b&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 18pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/b&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: #333333; line-height: normal; mso-list: l3 level1 lfo4; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;David Solomon, Mark Russinovich, "Inside Microsoft Windows 2000.      Third Edition", Microsoft Press, 2000&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-left: 36.0pt; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Aygıt sürücü yazarları ve adayları için bir numaralı kaynak. Bu kitabı okuyarak benim iğrenc makalemi okumak zorunda kalmayabilirsiniz :}&lt;/span&gt;&lt;/i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: #333333; line-height: normal; mso-list: l3 level1 lfo4; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Sven B. Schreiber, "Undocumented Windows 2000 Secrets. A      Programming Cookbook", Addison-Wesley&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-left: 36.0pt; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Bu da baş ucu eseri olma niteliğinde Win2000 neredeyse tüm gizliliklerini ifşa etmiş bir eser.&lt;/span&gt;&lt;/i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: #333333; line-height: normal; mso-list: l3 level1 lfo4; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Walter Oney, "Programming the Microsoft Driver Model",      Microsoft Press, 1999&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;i&gt;Walter'in anlatımı çok ağır ve zaten karmaşık olan bir konuyu iyice zorlaştırmış ama yinede okunması gerekir&lt;/i&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: #333333; line-height: normal; mso-list: l1 level1 lfo5; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Walter Oney, "Programming the Microsoft Windows Driver Model. 2nd      edition", Microsoft Press, 2003&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-left: 36.0pt; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;İşte bu diğerine 5 basar.&amp;nbsp;hem anlatım sadeleşmiş hemde plug-in-play hiç bu kadar kolay anlatılmamıştı..&lt;/span&gt;&lt;/i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: #333333; line-height: normal; mso-list: l1 level1 lfo5; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Art Baker č Jerry Lozano, "The Windows 2000 Device Driver Book, A      Guide for Programmers, Second Edition", Prentice Hall, 2000&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-left: 36.0pt; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Bunu okumadım ama referansı iyiye benziyor ve konumuzla tamamen alakalı olduğundan buraya yazdım&lt;/span&gt;&lt;/i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: #333333; line-height: normal; mso-list: l1 level1 lfo5; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Rajeev Nagar, "Windows NT File System Internals. A Developer's      Guide", O'Reilly&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-left: 36.0pt; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Bu kitap varken bu makaleyi yazmamalıydım :)&lt;/span&gt;&lt;/i&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: #333333; line-height: normal; mso-list: l1 level1 lfo5; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Prasad Dabak, Sandeep Phadke, and Milind Borate, "Undocumented      Windows NT", M&amp;amp;T Books, 1999&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; margin-left: 36.0pt; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;ul type="disc"&gt;&lt;li class="MsoNormal" style="color: #333333; line-height: normal; mso-list: l1 level1 lfo5; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Gary Nebbett, " Windows NT-2000 Native API Reference",      MacMillan Technical Publishing, 2000&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;li class="MsoNormal" style="color: #333333; line-height: normal; mso-list: l1 level1 lfo5; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto; tab-stops: list 36.0pt;"&gt;&lt;span style="font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Jeffrey Richter, "Programming Applications for Microsoft Windows.      Fourth Edition", Microsoft Press, 1999&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;&lt;div class="MsoNormal" style="line-height: normal; mso-margin-bottom-alt: auto; mso-margin-top-alt: auto;"&gt;&lt;span style="color: #333333; font-family: Verdana, sans-serif; font-size: 10pt;"&gt;Serinin ikincisinde görüşmek üzere...&lt;o:p&gt;&lt;/o:p&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="MsoNormal"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-4170223212587363665?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2011-07-27T15:51:39.073+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Stuxnet hakkında herşey</title><link>http://kernelturk.blogspot.com/2011/06/stuxnet-hakknda-hersey.html</link><category>stuxnet</category><category>sysinternals</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Wed, 29 Jun 2011 10:01:44 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-1760616972097348710</guid><description>Blogu bu aralar ziyaret edenlerin çoğu stuxnet cümlesini kullanmışlar. Bende ziyaretçilerin elini boş göndermemek için bir derleme yaptım. Aşağıda ki doküman ve videolar bu konudaki tüm soru işaretlerini silecektir diye umuyorum.&lt;br /&gt;
&lt;br /&gt;
&lt;a href="http://blogs.technet.com/b/markrussinovich/archive/2011/03/30/3416253.aspx"&gt;Analyzing a Stuxnet Infection with the Sysinternals Tools, Part 1&lt;/a&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;a href="http://blogs.technet.com/b/markrussinovich/archive/2011/04/20/3422035.aspx"&gt;Analyzing a Stuxnet Infection with the Sysinternals Tools, Part 2&lt;/a&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;a href="http://rdist.root.org/2011/01/17/stuxnet-is-embarrassing-not-amazing/"&gt;Stuxnet is embarrassing, not amazing&lt;/a&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;object width="446" height="326"&gt;&lt;param name="movie" value="http://video.ted.com/assets/player/swf/EmbedPlayer.swf"&gt;&lt;/param&gt;&lt;param name="allowFullScreen" value="true" /&gt;&lt;param name="allowScriptAccess" value="always"/&gt;&lt;param name="wmode" value="transparent"&gt;&lt;/param&gt;&lt;param name="bgColor" value="#ffffff"&gt;&lt;/param&gt;&lt;param name="flashvars" value="vu=http://video.ted.com/talks/dynamic/RalphLangner_2011-medium.flv&amp;su=http://images.ted.com/images/ted/tedindex/embed-posters/RalphLangner-2011.embed_thumbnail.jpg&amp;vw=432&amp;vh=240&amp;ap=0&amp;ti=1107&amp;lang=eng&amp;introDuration=15330&amp;adDuration=4000&amp;postAdDuration=830&amp;adKeys=talk=ralph_langner_cracking_stuxnet_a_21st_century_cyberweap;year=2011;theme=what_s_next_in_tech;theme=war_and_peace;theme=bold_predictions_stern_warnings;theme=a_taste_of_ted2011;theme=numbers_at_play;event=TED2011;tag=Iran;tag=Science;tag=Technology;tag=computers;tag=government;tag=nuclear+energy;tag=politics;tag=war;&amp;preAdTag=tconf.ted/embed;tile=1;sz=512x288;" /&gt;&lt;embed src="http://video.ted.com/assets/player/swf/EmbedPlayer.swf" pluginspace="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash" wmode="transparent" bgColor="#ffffff" width="446" height="326" allowFullScreen="true" allowScriptAccess="always" flashvars="vu=http://video.ted.com/talks/dynamic/RalphLangner_2011-medium.flv&amp;su=http://images.ted.com/images/ted/tedindex/embed-posters/RalphLangner-2011.embed_thumbnail.jpg&amp;vw=432&amp;vh=240&amp;ap=0&amp;ti=1107&amp;lang=eng&amp;introDuration=15330&amp;adDuration=4000&amp;postAdDuration=830&amp;adKeys=talk=ralph_langner_cracking_stuxnet_a_21st_century_cyberweap;year=2011;theme=what_s_next_in_tech;theme=war_and_peace;theme=bold_predictions_stern_warnings;theme=a_taste_of_ted2011;theme=numbers_at_play;event=TED2011;tag=Iran;tag=Science;tag=Technology;tag=computers;tag=government;tag=nuclear+energy;tag=politics;tag=war;"&gt;&lt;/embed&gt;&lt;/object&gt;&lt;br /&gt;
&lt;br /&gt;
Stuxnet hakkında yapılmış belgesel tadında bir video:&lt;br /&gt;
&lt;br /&gt;
&lt;iframe src="http://player.vimeo.com/video/25118844?title=0&amp;amp;byline=0&amp;amp;portrait=0" width="400" height="225" frameborder="0"&gt;&lt;/iframe&gt;&lt;p&gt;&lt;a href="http://vimeo.com/25118844"&gt;Stuxnet: Anatomy of a Computer Virus&lt;/a&gt; from &lt;a href="http://vimeo.com/patrickclair"&gt;Patrick Clair&lt;/a&gt; on &lt;a href="http://vimeo.com"&gt;Vimeo&lt;/a&gt;.&lt;/p&gt;&lt;br /&gt;
Stuxnet, kısacası; ileri reverse engineering ve çalıştığı mimariye ait derinlemesine assembly bilgisi olanlar için yapılabilirilitesi gayet mümkün olan bir iş.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-1760616972097348710?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-29T20:01:44.766+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total><enclosure url="http://video.ted.com/assets/player/swf/EmbedPlayer.swf" length="504795" type="application/x-shockwave-flash" /><media:content url="http://video.ted.com/assets/player/swf/EmbedPlayer.swf" fileSize="504795" type="application/x-shockwave-flash" /><itunes:explicit>no</itunes:explicit><itunes:subtitle>Blogu bu aralar ziyaret edenlerin çoğu stuxnet cümlesini kullanmışlar. Bende ziyaretçilerin elini boş göndermemek için bir derleme yaptım. Aşağıda ki doküman ve videolar bu konudaki tüm soru işaretlerini silecektir diye umuyorum. Analyzing a Stuxnet Infec</itunes:subtitle><itunes:author>noreply@blogger.com (Ibrahim Akgul)</itunes:author><itunes:summary>Blogu bu aralar ziyaret edenlerin çoğu stuxnet cümlesini kullanmışlar. Bende ziyaretçilerin elini boş göndermemek için bir derleme yaptım. Aşağıda ki doküman ve videolar bu konudaki tüm soru işaretlerini silecektir diye umuyorum. Analyzing a Stuxnet Infection with the Sysinternals Tools, Part 1 Analyzing a Stuxnet Infection with the Sysinternals Tools, Part 2 Stuxnet is embarrassing, not amazing Stuxnet hakkında yapılmış belgesel tadında bir video: Stuxnet: Anatomy of a Computer Virus from Patrick Clair on Vimeo. Stuxnet, kısacası; ileri reverse engineering ve çalıştığı mimariye ait derinlemesine assembly bilgisi olanlar için yapılabilirilitesi gayet mümkün olan bir iş.</itunes:summary><itunes:keywords>stuxnet, sysinternals</itunes:keywords></item><item><title>Windows'un Evrimi (Video)</title><link>http://kernelturk.blogspot.com/2011/03/windowsun-evrimi-video.html</link><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Mon, 07 Mar 2011 11:00:56 PST</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-3396169165746252840</guid><description>Windows işletim sisteminin Dos 5.0'dan Windows 7'ye kadar çıkmış tüm sürümlerinin hızlıca ve sade bir dille anlatıldığı çok hoş bir çalışmayı paylaşmak istedim.&lt;br /&gt;
&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;object width="320" height="266" class="BLOGGER-youtube-video" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0" data-thumbnail-src="http://2.gvt0.com/vi/vPnehDhGa14/0.jpg"&gt;&lt;param name="movie" value="http://www.youtube.com/v/vPnehDhGa14&amp;fs=1&amp;source=uds" /&gt;&lt;param name="bgcolor" value="#FFFFFF" /&gt;&lt;embed width="320" height="266" src="http://www.youtube.com/v/vPnehDhGa14&amp;fs=1&amp;source=uds" type="application/x-shockwave-flash"&gt;&lt;/embed&gt;&lt;/object&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-3396169165746252840?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2011-03-07T21:00:56.480+02:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">1</thr:total><enclosure url="http://www.youtube.com/v/vPnehDhGa14&amp;fs=1&amp;source=uds" length="1091" type="application/x-shockwave-flash" /><media:content url="http://www.youtube.com/v/vPnehDhGa14&amp;fs=1&amp;source=uds" fileSize="1091" type="application/x-shockwave-flash" /><itunes:explicit>no</itunes:explicit><itunes:subtitle>Windows işletim sisteminin Dos 5.0'dan Windows 7'ye kadar çıkmış tüm sürümlerinin hızlıca ve sade bir dille anlatıldığı çok hoş bir çalışmayı paylaşmak istedim. </itunes:subtitle><itunes:author>noreply@blogger.com (Ibrahim Akgul)</itunes:author><itunes:summary>Windows işletim sisteminin Dos 5.0'dan Windows 7'ye kadar çıkmış tüm sürümlerinin hızlıca ve sade bir dille anlatıldığı çok hoş bir çalışmayı paylaşmak istedim. </itunes:summary></item><item><title>Microsoft: Command Prompt vulnerabilty</title><link>http://kernelturk.blogspot.com/2011/01/microsoft-degisiklik-yok-yola-devam.html</link><category>cmd hack</category><category>command prompt hack</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Sat, 22 Jan 2011 11:36:36 PST</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-2299229223036334119</guid><description>2006 yılında Windows 2003 Server ve Windows Xp client'larında keşfettiğim ve ne yazık ki Windows 2008 R2 Server ve Windows 7 x64 sistemlerde aynen devam eden Command Prompt(Cmd.exe) zayıflığı halen varlığını sürdürmekte. Bir hexeditor veya Excel makro çalıştırma hakkınız var ise Cmd.exe'yi yazma yetkiniz olan bir alana kopyalayıp içerisindeki DisableCMD satırından sadece tek bir karakteri değiştirmeniz command prompt kısıtlaması policy'sini etkisiz hale getirmenize yetecektir.&lt;br /&gt;
&lt;br /&gt;
Bu açıklığı PoC ile gösteren bir macroyu da o seneler ilk acemi deneyimim olan camtasia screen record ile zabıt altına almıştım . İzleyip gülmeyelim lütfen :&lt;br /&gt;
&lt;br /&gt;
&lt;object width="425" height="344"&gt;&lt;param name="movie" value="http://www.youtube.com/v/t7ZSdbXwSMI?hl=en&amp;fs=1"&gt;&lt;/param&gt;&lt;param name="allowFullScreen" value="true"&gt;&lt;/param&gt;&lt;param name="allowscriptaccess" value="always"&gt;&lt;/param&gt;&lt;embed src="http://www.youtube.com/v/t7ZSdbXwSMI?hl=en&amp;fs=1" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="425" height="344"&gt;&lt;/embed&gt;&lt;/object&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-2299229223036334119?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2011-01-22T21:36:36.461+02:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total><enclosure url="http://www.youtube.com/v/t7ZSdbXwSMI?hl=en&amp;fs=1" length="1044" type="application/x-shockwave-flash" /><media:content url="http://www.youtube.com/v/t7ZSdbXwSMI?hl=en&amp;fs=1" fileSize="1044" type="application/x-shockwave-flash" /><itunes:explicit>no</itunes:explicit><itunes:subtitle>2006 yılında Windows 2003 Server ve Windows Xp client'larında keşfettiğim ve ne yazık ki Windows 2008 R2 Server ve Windows 7 x64 sistemlerde aynen devam eden Command Prompt(Cmd.exe) zayıflığı halen varlığını sürdürmekte. Bir hexeditor veya Excel makro çal</itunes:subtitle><itunes:author>noreply@blogger.com (Ibrahim Akgul)</itunes:author><itunes:summary>2006 yılında Windows 2003 Server ve Windows Xp client'larında keşfettiğim ve ne yazık ki Windows 2008 R2 Server ve Windows 7 x64 sistemlerde aynen devam eden Command Prompt(Cmd.exe) zayıflığı halen varlığını sürdürmekte. Bir hexeditor veya Excel makro çalıştırma hakkınız var ise Cmd.exe'yi yazma yetkiniz olan bir alana kopyalayıp içerisindeki DisableCMD satırından sadece tek bir karakteri değiştirmeniz command prompt kısıtlaması policy'sini etkisiz hale getirmenize yetecektir. Bu açıklığı PoC ile gösteren bir macroyu da o seneler ilk acemi deneyimim olan camtasia screen record ile zabıt altına almıştım . İzleyip gülmeyelim lütfen : </itunes:summary><itunes:keywords>cmd hack, command prompt hack</itunes:keywords></item><item><title>Yeni eğlencemiz: Binary Planting</title><link>http://kernelturk.blogspot.com/2010/09/yeni-eglencemiz-binary-planting.html</link><category>win32 vulnerability</category><category>Binary Planting</category><category>search path algorithm</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Mon, 13 Sep 2010 22:32:28 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-656341296099283310</guid><description>Bu aralar vulnerability keşiflerinde gözle görülür bir artış var ve sebebi menba-ı da yine malum windows mimarisi. Mailime her gün dll injection vuln reportları geliyor ve tümünün origin'i de &lt;span style="font-weight:bold;"&gt;Binary Planting&lt;/span&gt;. Win32 Sistem programcılığı yapmış olanlar iyi bilirler ki uygulamanızda export edip nimetlerinden faydalandığımız bir dll'i (ör: dwmapi.dll, secacc.dll ...) LoadLibrary api si ile kullanmak istediğimizde işletim sistemiz bu kullanılmak istenen dll dosyasını safe search list algoritmasına göre şu şekilde arar:&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
LoadLibrary library arama öncelikleri :&lt;br /&gt;
&lt;br /&gt;
1 - Uygulamanın çalıştırıldığı dizin&lt;br /&gt;
2 - 32-bit Sistem dizini  (Windows\System32)&lt;br /&gt;
3 - 16-bit Sistem dizini (Windows\System)&lt;br /&gt;
4 - Windowsun kurulu olduğu dizin (Windows)&lt;br /&gt;
5 - Çalışma dizini&lt;br /&gt;
6 - Ortam değişkenlerinde PATH ile belirtilmiş olan dizinler&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
Sanırım her şey gayet net ve açık. Eğer bir uygulamanın bu şekilde zaafiyetini kullanmak istiyorsanız rolünü almak istediğiniz dll dosyasının fonksiyonlarını memory inject etmek yerine o dll'in manipüle ettiğiniz halini zehirlemek istediğiniz uygulamanın kurulu olduğu dizine kopyalamanız kafi gelicektir. Kısacası yine bir microsoft mimari hatası. Ki olay sadece LoadLibrary ile bitmiyor ve ne yazık ki CreateProcess, LoadModule, WinExec, ShellExecute gibi api'ler için aynı senaryo geçerli. &lt;br /&gt;
&lt;br /&gt;
Zaafiyetin tüm güncellemeleri almış bir sistemde nasıl işlediği ile alakalı bir görseli aşağıdaki linkten izleyebilirsiniz:&lt;br /&gt;
&lt;br /&gt;
&lt;a href="http://core.yehg.net/lab/pr0js/advisories/dll_hijacking/flash_player/poc/movie/flash_player_ie_10.x_dll_hijacking_vuln.mp4"&gt;http://core.yehg.net/lab/pr0js/advisories/dll_hijacking/flash_player/poc/movie/flash_player_ie_10.x_dll_hijacking_vuln.mp4&lt;/a&gt;&lt;br /&gt;
&lt;br /&gt;
Daha ayrıntılı zaafiyet açıklaması ve microsoftun çabaları için aşağıda ki linkleri ziyaret edebilirsiniz:&lt;br /&gt;
&lt;br /&gt;
&lt;a href="http://blog.acrossecurity.com/2010/09/binary-planting-goes-exe.html"&gt;http://blog.acrossecurity.com/2010/09/binary-planting-goes-exe.html&lt;br /&gt;
&lt;/a&gt;&lt;br /&gt;
&lt;a href="http://support.microsoft.com/kb/2264107"&gt;http://support.microsoft.com/kb/2264107&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-656341296099283310?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2010-09-14T08:32:28.684+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total><enclosure url="http://core.yehg.net/lab/pr0js/advisories/dll_hijacking/flash_player/poc/movie/flash_player_ie_10.x_dll_hijacking_vuln.mp4" length="1822763" type="video/mp4" /><media:content url="http://core.yehg.net/lab/pr0js/advisories/dll_hijacking/flash_player/poc/movie/flash_player_ie_10.x_dll_hijacking_vuln.mp4" fileSize="1822763" type="video/mp4" /><itunes:explicit>no</itunes:explicit><itunes:subtitle>Bu aralar vulnerability keşiflerinde gözle görülür bir artış var ve sebebi menba-ı da yine malum windows mimarisi. Mailime her gün dll injection vuln reportları geliyor ve tümünün origin'i de Binary Planting. Win32 Sistem programcılığı yapmış olanlar iyi </itunes:subtitle><itunes:author>noreply@blogger.com (Ibrahim Akgul)</itunes:author><itunes:summary>Bu aralar vulnerability keşiflerinde gözle görülür bir artış var ve sebebi menba-ı da yine malum windows mimarisi. Mailime her gün dll injection vuln reportları geliyor ve tümünün origin'i de Binary Planting. Win32 Sistem programcılığı yapmış olanlar iyi bilirler ki uygulamanızda export edip nimetlerinden faydalandığımız bir dll'i (ör: dwmapi.dll, secacc.dll ...) LoadLibrary api si ile kullanmak istediğimizde işletim sistemiz bu kullanılmak istenen dll dosyasını safe search list algoritmasına göre şu şekilde arar: LoadLibrary library arama öncelikleri : 1 - Uygulamanın çalıştırıldığı dizin 2 - 32-bit Sistem dizini (Windows\System32) 3 - 16-bit Sistem dizini (Windows\System) 4 - Windowsun kurulu olduğu dizin (Windows) 5 - Çalışma dizini 6 - Ortam değişkenlerinde PATH ile belirtilmiş olan dizinler Sanırım her şey gayet net ve açık. Eğer bir uygulamanın bu şekilde zaafiyetini kullanmak istiyorsanız rolünü almak istediğiniz dll dosyasının fonksiyonlarını memory inject etmek yerine o dll'in manipüle ettiğiniz halini zehirlemek istediğiniz uygulamanın kurulu olduğu dizine kopyalamanız kafi gelicektir. Kısacası yine bir microsoft mimari hatası. Ki olay sadece LoadLibrary ile bitmiyor ve ne yazık ki CreateProcess, LoadModule, WinExec, ShellExecute gibi api'ler için aynı senaryo geçerli. Zaafiyetin tüm güncellemeleri almış bir sistemde nasıl işlediği ile alakalı bir görseli aşağıdaki linkten izleyebilirsiniz: http://core.yehg.net/lab/pr0js/advisories/dll_hijacking/flash_player/poc/movie/flash_player_ie_10.x_dll_hijacking_vuln.mp4 Daha ayrıntılı zaafiyet açıklaması ve microsoftun çabaları için aşağıda ki linkleri ziyaret edebilirsiniz: http://blog.acrossecurity.com/2010/09/binary-planting-goes-exe.html http://support.microsoft.com/kb/2264107</itunes:summary><itunes:keywords>win32 vulnerability, Binary Planting, search path algorithm</itunes:keywords></item><item><title>Biraz nostalji: Masm32 ile ilk çırpınışlar</title><link>http://kernelturk.blogspot.com/2010/09/biraz-nostalji-masm32-ile-ilk-crpnslar.html</link><category>win32</category><category>masm32</category><category>assembly</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Wed, 08 Sep 2010 13:43:56 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-1208190021886471285</guid><description>Sene 2002, çalıştığım şirkette gece vardiyalarında bol boş vakit den kaynaklanan zaman aralıklarını faydalı bir şeylerle değerlendireyim derken tanıştım masm32 ile. Icezelion'un müthiş win32 serisini bir çırpıda okuyup yaklaşık 24 step'lik tuts larınıda example'ları ile yuttuktan sonra ilk denememi yapayım demiş ve aşağıdaki acaip şey ortaya çıkmıştı :) Arşivimden bir mp3 cutter ararken rast geldim ve paylaşayım istedim:&lt;br /&gt;&lt;br /&gt;&lt;blockquote&gt;&lt;br /&gt;;Writed by StreAmeR    10.10.2002  bilgislem@hotmail.com&lt;br /&gt;.386&lt;br /&gt;.model flat,stdcall&lt;br /&gt;option casemap:none&lt;br /&gt;&lt;br /&gt;WinMain proto :DWORD,:DWORD,:DWORD,:DWORD&lt;br /&gt;&lt;br /&gt;include \masm32\include\windows.inc&lt;br /&gt;include \masm32\include\kernel32.inc&lt;br /&gt;include \masm32\include\user32.inc&lt;br /&gt;includelib \masm32\lib\kernel32.lib&lt;br /&gt;includelib \masm32\lib\user32.lib&lt;br /&gt;&lt;br /&gt; @UzunlukAl MACRO&lt;br /&gt; push edi&lt;br /&gt; mov edi,esi&lt;br /&gt; xor al,al&lt;br /&gt; xor ecx,ecx&lt;br /&gt; scasb&lt;br /&gt; pushf&lt;br /&gt; inc ecx&lt;br /&gt; popf&lt;br /&gt; jnz $-6&lt;br /&gt; mov konum,edi&lt;br /&gt; pop edi&lt;br /&gt; ENDM&lt;br /&gt;&lt;br /&gt; @SatirAtla MACRO&lt;br /&gt; dec edi&lt;br /&gt; mov al,0ah&lt;br /&gt; stosb&lt;br /&gt; mov al,0dh&lt;br /&gt; stosb&lt;br /&gt; ENDM&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;asd  proto :DWORD&lt;br /&gt;&lt;br /&gt;.data&lt;br /&gt;baslik db "GetEnvironmentStrings&amp;Assembly Example",0&lt;br /&gt;hata db "Hata",0&lt;br /&gt;konum dd 0&lt;br /&gt;&lt;br /&gt;.data?&lt;br /&gt;hHandle HWND ?&lt;br /&gt;buf db 512 dup(?)&lt;br /&gt;&lt;br /&gt;.code&lt;br /&gt;start:&lt;br /&gt; invoke GetEnvironmentStrings    ; Programın işletim                                   sistemi tarafından otomatik olarak tanımlanan ortam değişken tablosuna pointer al&lt;br /&gt; &lt;br /&gt;        mov hHandle,eax     ; Pointer'i sakla&lt;br /&gt; mov edi,hHandle     ; Pointer üzerinde işlem yapabilmeniz için bir kopyasını edi'ye çekiyoruz&lt;br /&gt;&lt;br /&gt; ; Ortam bilgisinin hafızada yer alan bilgisinin tümünü tarayıp bitis noktasini aliyoruz&lt;br /&gt;&lt;br /&gt; ; ------------ Pointerin sonu Bir sonlandırıcı 00 ve iki bitiş 00 00 ile bitiyor. Biz bu değişken tablosunun sonunu bulmalıyız &lt;br /&gt; push edi      ; Pointer'in base adresini stacke atıyoruz&lt;br /&gt; xor ax,ax      ; &lt;br /&gt; scasw&lt;br /&gt; jnz $-2&lt;br /&gt; dec edi&lt;br /&gt; mov edx,edi ;Yapının son adresini edx'e alıyoruz&lt;br /&gt;&lt;br /&gt; ;İlk bilgi yapısını alıyor ve geçersiz olduğundan dolayı tamponumuza almıyıp bize gecerli olan adresi isaretlemesini sağlıyoruz&lt;br /&gt; pop edi &lt;br /&gt; xor al,al&lt;br /&gt; xor ecx,ecx&lt;br /&gt; scasb &lt;br /&gt; pushf&lt;br /&gt; inc ecx&lt;br /&gt; popf&lt;br /&gt; jnz $-6&lt;br /&gt; &lt;br /&gt; lea edi,buf&lt;br /&gt; push edi&lt;br /&gt; mov esi,hHandle&lt;br /&gt; xor al,al&lt;br /&gt; rep movsb&lt;br /&gt; pop edi&lt;br /&gt; push edi  &lt;br /&gt; mov ecx,20&lt;br /&gt; xor al,al&lt;br /&gt; rep stosb&lt;br /&gt;&lt;br /&gt; @UzunlukAl&lt;br /&gt;&lt;br /&gt; &lt;br /&gt; lea edi,buf  ;tampon&lt;br /&gt; rep movsb&lt;br /&gt; @SatirAtla&lt;br /&gt; &lt;br /&gt; @UzunlukAl&lt;br /&gt; rep movsb&lt;br /&gt; @SatirAtla&lt;br /&gt; &lt;br /&gt; mov konum,edi &lt;br /&gt; .while konum!=edx&lt;br /&gt; @UzunlukAl&lt;br /&gt; rep movsb&lt;br /&gt; @SatirAtla&lt;br /&gt; .endw&lt;br /&gt;&lt;br /&gt; invoke MessageBox,NULL,ADDR buf,addr baslik,MB_OK&lt;br /&gt;&lt;br /&gt; invoke FreeEnvironmentStrings,hHandle &lt;br /&gt; invoke  ExitProcess,NULL&lt;br /&gt; ret&lt;br /&gt;&lt;br /&gt;end start&lt;br /&gt;&lt;br /&gt;&lt;/blockquote&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-1208190021886471285?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2010-09-08T23:43:56.786+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Sadece 1K ile neler yapılabilir</title><link>http://kernelturk.blogspot.com/2010/09/sadece-1k-ile-neler-yaplabilir.html</link><category>javascript</category><category>JS1K</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Tue, 07 Sep 2010 06:29:24 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-202524677293888860</guid><description>Çoğunuz duymuşsunuzdur JS1K.com adlı site geliştiricilerden 1K sınırını aşmaksızın javascript ile etkileşimli projeler geliştirmesi için bir yarışma başlattı. Bir şeyler karalayıp gönderdim ama oradaki diğer parlak fikirleri görünce geri çekilesim geldi :) Örnek: &lt;a href="http://js1k.com/pleaseDontHotlinkMe/680"&gt;pleaseDontHotlinkMe&lt;/a&gt; 
&lt;br /&gt;
&lt;br /&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-202524677293888860?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2010-09-07T16:29:24.299+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Windows 7 x64 için Rootkitler MBR ile geri mi dönüyor?</title><link>http://kernelturk.blogspot.com/2010/09/windows-7-x64-rootkit-mbrla-gerimi.html</link><category>windows 7</category><category>x64</category><category>kpp</category><category>ssdt hook</category><category>mbr</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Thu, 30 Jun 2011 02:01:48 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-8874854964832605672</guid><description>Windows'un ne yapsa bir türlü kurtulamadığı Kernel taraflı açıklarına karşı geliştirdiği yeni nesil koruma sistemlerine uzun zamandır pratik bir çözüm bulunamamıştı! Ramazan ayının da verdiği rehavet ile internet'te boş boş dolaşırken &lt;a href="http://www.prevx.com/blog.asp"&gt;http://www.prevx.com/blog.asp&lt;/a&gt; adlı bloga rastladım. Arkadaşlar gayet akılcı ve ince bir yol ile Windows 7 x64 sistemleri üzerinde KMCS(Code Singing) ve KPP (patch protection) korumalarını atlatmayı başarmışlar. Mantık kısaca MBR üzerinden windows'un başlangıç paramtrelerini manipüle ederek bu korumaları devre dışı bırakmaktan geçiyor. Seneler önce sistemde kalıcı olarak bulunabilmek/zarar verebilmek için virüsler tarafından kullanılan mbr alanı x64 mimarisi ile yeniden gündemde. Umarım ortalığın hareketlenmesine biraz olsun yardımcı olur. &lt;br /&gt;
&lt;br /&gt;
Sağlıcakla.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-8874854964832605672?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-30T12:01:48.204+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>McAfee VirusScan Enterprise 8.7.0i sonlandırma açığı</title><link>http://kernelturk.blogspot.com/2010/09/mcafee-virusscan-enterprise-870i.html</link><category>mcafee vulnerable</category><category>mcafee virusscan enterprise</category><category>vulnerability</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Wed, 01 Sep 2010 04:32:36 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-8281702439748584675</guid><description>Her ne kadar Windows taraflı güvenlik yazılımları sektörüne zorunlu bir Unix-Linux macerası yaşıyor olmam sebebi ile ara vermiş olsam da, kötü güvenlik politikaları coder'i deneyim sahibi yapar sözüne istinaden yine bir açıkla karşınızdayım. &lt;br /&gt;&lt;br /&gt;Şirketimiz için bir Network Analyze uygulaması yazmış ve deploy edilmesi için Visual Studio'nun publisher'ini kullanmıştım ancak her kurulum denememde inatla herhangi bir uygulamaya özel hata almadan sadece autorun.inf dosyasının execute olmasını engelleyen bir windows hatası ile karşılaşıyordum ve kısa bir bakıştan sonra buna neden olanın yeni satın almış olduğumuz McAfee VirusScan Enterprise olduğunu öğrendim. Hemen ilk aklıma geleni yani uygulamayı disable etmeyi denedim ancak şifre soran bir ekran ile karşı karşıya kalmıştım. Antivirüsün deployunu başka bir arkadaşım yaptığından parolayı da bilen oydu ve ne yazık ki o sırada ona ulaşmıyordum. Sırası ile service'i stop etmeyi ve terminate attack'larla sonlandırmayı denedim ama mcafee bunlara hali ile önlem almıştı. İşin benim için eğlendirici tarafı da o sırada başlamıştı.&lt;br /&gt;&lt;br /&gt;Her nasıl olduysa genelde en son denediğim şeylerden birini, heap memory'ye müdahale etmeyi hemen denedim ve kernel taraflı ana processin kullandığı kendine ait en yüksek boyuta ait private alana ntdll.dll dosyasından export edilen virtualmemory fonskiyonları ile müdahele ettim ve sonuç mcafee ye ait ana sistem koruma bileşeni sonlanarak host sistemi savunmasız hale getirdi. Böylece bende uygulamamı rahatlıkla kurabildim :) &lt;br /&gt;&lt;br /&gt;Açığı geçtiğimiz hafta McAfee yetkililerine bir PoC ile bildirdim. Halen bir feedback alamadığımı da ayrıca belirtmek isterim. İlgisizliklerine göre bir zaman aralığında kodu sizlerle paylaşmayı düşünüyor iyi günler diliyorum.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-8281702439748584675?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2010-09-01T14:32:36.791+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Kendime Not: Outlook 2010 crash problemi</title><link>http://kernelturk.blogspot.com/2010/08/kendime-not-outlook-2010-crash-problemi.html</link><category>Outlook 2010</category><category>Office 2010</category><category>Personel Folder problem</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Tue, 17 Aug 2010 06:55:28 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-8929749399472632029</guid><description>Outlook 2010 kullanan ve kişisel klasörünü(personel folder yada pst) varsayılan teslim kutusu olarak seçen kullanıcılarda Outlook'u her açış denemesinde uygulama dump olup sonlanıyor. Microsoft halen açılan caselere çözüm arıyo dursun ben bulduğum çareyi sizlerle paylaşayım:&lt;br /&gt;&lt;br /&gt;Sorun kişisel klasör dosyasınızda bulunan junk mail klasörüne güvenli gönderici listesi(safe sender list) kullanıldığı durumlarda vuku buluyor. Ida ile baktığımda &lt;br /&gt;her defasında bu fonksiyonda hata veriyordu. Kullandığı registry yolu ise şöyle: &lt;br /&gt;&lt;blockquote&gt;HKCU\Software\Policies\Microsoft\Office\14.0\outlook\options\mail&lt;/blockquote&gt;&lt;br /&gt;Bu yoldaki "JunkMailImportLists" anahtarının değerini "0" yaparak outlook'u problemsiz bir şekilde çalıştırabiliyoruz.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-8929749399472632029?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2010-08-17T16:55:28.394+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Kendime Not: Ntlmv2 ile mount işlemi</title><link>http://kernelturk.blogspot.com/2010/06/kendime-not-ntlmv2-ile-mount-islemi.html</link><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Tue, 29 Jun 2010 02:10:07 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-6518240563645654683</guid><description>Kısa bir zaman önce ldap güvenliğinde ntlmv2 şifreleme yöntemine geçtik ve bu yüzden eski basit mount işlemlerimiz işlev görmez hale geldi. Aşağıdaki komut ile başarı ile paylaşımlarınıza bağlanabilirsiniz:&lt;br /&gt;&lt;br /&gt;&lt;blockquote&gt;[root@localhost /]# mount -t cifs //serveradi/paylasimadi /mnt/dizinadi --verbose -o sec=ntlmv2,user=domainuseradi,pass=parolasi,domain=DOMAINADI&lt;br /&gt;&lt;/blockquote&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-6518240563645654683?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2010-06-29T12:10:07.781+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Kendime Not:Esx Server Root parolasını Resetleme</title><link>http://kernelturk.blogspot.com/2010/06/kendime-notesx-server-root-parolasn.html</link><category>esx server</category><category>virtulization</category><category>linux</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Mon, 21 Mar 2011 04:51:56 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-5463095906205921846</guid><description>Grub ekranındayken editing moda geçiyor ve son satırı single olarak değiştirip multimode'un dışında çalışacağımızı belirtiyoruz ardından düştüğümüz cli'dan passwd ile parolamızı değiştiriyor ve projemize kaldığımız yerden devam ediyoruz. Aşağıda bu adımların görsel temsilleri yer almaktadır.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="https://lh5.googleusercontent.com/-AdQFUovSZ-0/TYc6Z2qm4UI/AAAAAAAAAEk/yrtxM4zHgSM/s1600/Step-1.JPG" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="221" src="https://lh5.googleusercontent.com/-AdQFUovSZ-0/TYc6Z2qm4UI/AAAAAAAAAEk/yrtxM4zHgSM/s400/Step-1.JPG" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;Bu aşamada önünüze gelen 4 adet seçenekten "kernel /vmlinuz...." ile baslayan satırı bulup "e" tuşuna basarak komutu özelleştirme işlemine geçiyoruz ve çıkan ekranda son satırda yer alan "quiet" kelimesini silip "single" yazıyoruz:&lt;br /&gt;
&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="https://lh3.googleusercontent.com/-Iv1ffOLF3l8/TYc6aFznCtI/AAAAAAAAAEo/A3aR5-zmYM0/s1600/Step-2.JPG" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="70" src="https://lh3.googleusercontent.com/-Iv1ffOLF3l8/TYc6aFznCtI/AAAAAAAAAEo/A3aR5-zmYM0/s400/Step-2.JPG" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&amp;nbsp;Bu aşamada Esc ile ana menüye dönüp "b" tuşuna basıp sistemi bu parametre ile boot ediyoruz. Ve işlem bitiminde bizden komut bekleyen shell'e passwd komutunu giriyoruz:&lt;br /&gt;
&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="https://lh3.googleusercontent.com/-zJBTnocwGuM/TYc6aWxa2jI/AAAAAAAAAEs/4ewc7LrjvJk/s1600/Step-3.JPG" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="215" src="https://lh3.googleusercontent.com/-zJBTnocwGuM/TYc6aWxa2jI/AAAAAAAAAEs/4ewc7LrjvJk/s400/Step-3.JPG" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;br /&gt;
&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="https://lh3.googleusercontent.com/-yptNOiCvnUw/TYc6a69QbiI/AAAAAAAAAEw/du4Ti_JsErg/s1600/Step-4.JPG" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="242" src="https://lh3.googleusercontent.com/-yptNOiCvnUw/TYc6a69QbiI/AAAAAAAAAEw/du4Ti_JsErg/s400/Step-4.JPG" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-5463095906205921846?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2011-03-21T13:51:56.464+02:00</app:edited><media:thumbnail url="https://lh5.googleusercontent.com/-AdQFUovSZ-0/TYc6Z2qm4UI/AAAAAAAAAEk/yrtxM4zHgSM/s72-c/Step-1.JPG" height="72" width="72" /><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Kendime Not: Openfire Ldap Server Singing Problemi</title><link>http://kernelturk.blogspot.com/2010/05/kendime-not-openfire-ldap-server.html</link><category>openfire</category><category>active directory</category><category>java</category><category>ldap server sign</category><category>spark</category><category>ldap</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Fri, 28 May 2010 06:54:47 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-7099452080096319038</guid><description>Openfire Server'ini Active Directory Simple LDAP Authentication mekanizması ile problemsiz bir şekilde çalıştıranlar yaptıkları Ldap Server Signing değişikliği ile Spark IM'lerine elvada dediler. Ldap Server Signing özelliğinin zorunlu kıldığı Digest-MD5 authentication mekanizmasını son versiyonunda bile desteklemeyen &lt;a href="http://www.igniterealtime.org/"&gt;Jive Software&lt;/a&gt; destek forumlarında bu problemle çıkan onlarca &lt;a href="http://www.igniterealtime.org/community/message/203358#203358"&gt;soruyuda cevapsız bırakıyor&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;Sorunu yine geçmişte uğraştığım Reverse engineering tekniklerine borçlu olarak çözümlemeyi başarabildim ve iğrenç anlatımımla sizlerle paylaşıyorum:&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;OpenFire ile Windows 2008 Server R2 Ldap Signing Problemi&lt;/strong&gt;&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;Problem:&lt;/strong&gt;  Openfire kurulumu LDAP authentication aşamasını geçemiyor, kurulum tamamlanamıyor.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;Sebep:&lt;/strong&gt;   Openfire’ın son sürümü dahil (Mayıs 2010 itibari ile 3.6.4) digest-md5 ve auth-int mekanizmalarını desteklenmediğinden Ldap Sign özelliğini kullanan Windows Server ailesi işletim sistemleri ile Ldap authentication başarılı bir şekilde sağlanamıyor. &lt;br /&gt;&lt;br /&gt;&lt;strong&gt;Çözüm: &lt;/strong&gt;&lt;br /&gt;1) Openfire’ın  kaynak kod dosyaları http://www.igniterealtime.org/downloads/download-landing.jsp?file=openfire/openfire_src_3_6_4.zip adresinden indirelerek uygun bir dizine açılır.&lt;br /&gt; &lt;br /&gt;2) Kaynak dosyalarla proje bazlı çalışabilmek ve editing yapabilmek için http://www.eclipse.org/downloads/ adresinden Eclipse  IDE’si indirilir&lt;br /&gt; &lt;br /&gt;3) src\java\org\jivesoftware\openfire\ldap dizinde yer alan LdapManager.java ve LdapAuthProvider.java Eclipse altında düzenlemek üzere açılır. &lt;br /&gt; &lt;br /&gt;4) LdapManager.java dosyası içinde yer alan “env.put(Context.SECURITY_AUTHENTICATION, "simple");” satırları “env.put(Context.SECURITY_AUTHENTICATION, "DIGEST-MD5");” olarak değiştirilir ve hemen alt satırına “env.put("javax.security.sasl.qop", "auth-int")”; eklenir.  LdapManager.java altında bu şekilde değiştirilmesi gereken 3 yer vardır.  &lt;br /&gt;&lt;br /&gt;5) Buraya kadar yapılan aşamalarda Ldap Authentication başarılı bir şekilde sağlanır ancak OpenFire’in kullanıcı denetleme mekanizması halen simple methodu ile distinguished query yaparak çalıştığından bunu iptal etmeliyiz.  Bunuda LdapAuthProvider.java dosyasında authenticate() adlı methodun manager.checkAuthentication(string, string)  fonksiyonuna geçilen paramtreyi değiştirerek sağlarız.  &lt;br /&gt;&lt;br /&gt;6) Tüm bu işlemlerden sonra değişiklikleri kaydediyoruz ve derleme adımına geçiyoruz. Derleme yapabilmek için Java Se 1.5 Runtime ve Ant 1.6 veya 1.7 sürümüne ihtiyacımız var.  &lt;br /&gt;&lt;br /&gt;7) Doğru bir derleme yapabilmek için öncelikle JAVA_HOME ve ANT_HOME değişkenlerini işletim sistemimizin Ortam Değişkenleri (Environment Variables) alanına tanımlamamız lazım.  &lt;br /&gt;&lt;br /&gt;8) Derleme işlemine başlayabilmek için openfire’ın kaynak kodlarının yer aldığı klasördeki build adlı dizine command prompt penceresi ile geçmemiz gerekiyor:  &lt;br /&gt;&lt;br /&gt;9) Artık derleme işlemine geçebiliriz. Bunun için build.xml dosyasının bulunduğu dizinde ant komutunu vermemiz yeterlidir. Başarılı bir derleme işleminden sonra almanız gereken sonuç resimdeki gibidir:  &lt;br /&gt;&lt;br /&gt;10) Derleme işleminden sonra %openfire_src%\work\lib dizini altında oluşan openfire.jar dosyasını authentication sağlayamadığımız orjinal OpenFire kurulum dosyasılarını barındıran dizinedeki openfire.jar ile değiştiriyoruz&lt;br /&gt;&lt;br /&gt;Bol dertsiz günler&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-7099452080096319038?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2010-05-28T16:54:47.079+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Bu düzen otururmu?</title><link>http://kernelturk.blogspot.com/2010/05/bu-duzen-otururmu.html</link><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Wed, 12 May 2010 13:11:46 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-2267868185213285795</guid><description>5 ay'ı aşkın süredir aktif sanal iletişim hayatım sekteye uğramış durumda. En büyük sebebi iş yerimdeki yeni pozisyonum ve getirdiği aşırı iş yükü. Göreve gelmemle birlikte daha ortama alışma ve yapıyı tanıma fırsatım olmadan büyük bir projenin yükü sırtıma bindi. Havacılık sektörü gibi 7/24 hizmet etme mecburiyeti bulunan bir organizasyonun IT yapısını yenilemek ve canlı tutmak gerçekten zor ve yorucu bir iş. Ekip arkadaşlarımla birlikte yeri geldiğinde geceleri yatağımızdan kaldırılarak problem çözmek de artık alışkanlık haline geldi. &lt;br /&gt;&lt;br /&gt;Tabi bu kadar iş yükü bir çok yeni ve taze bilgiye de sahip olmama neden oldu. Özellikle en son 7 sene önce kullanıcısı olduğum Linux platformunun şimdilerde Enterprise yönetimi seviyesindeki çözümleri ve problemlerine iyice aşina oldum. Hobi olarak uğraştığım bir çok bilgi koluda (reversing, kernel debugging, code analyzing..) işimin bir parçası ve sorunların çözümlerinde yardımcı araçlar oldu. İnsanın bu kadar bilgiyi boşuna öğrenmemiş olduğu hissi gerçekten hoşuna gidiyor. &lt;br /&gt;&lt;br /&gt;Fırsat ve zaman buldukça yaşanan gerçek problemler ve iş geliştirmelerinin süreçleri hakkında canlı senaryolar üzerinden bilgilerimi aktarmaya çalışacağım. Şimdilik sağlıcakla.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-2267868185213285795?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2010-05-12T23:11:46.165+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">1</thr:total></item><item><title>Milw0rm artık yok mu?</title><link>http://kernelturk.blogspot.com/2009/12/milw0rm-artk-yok-mu.html</link><category>Milw0rm</category><category>exploit</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Mon, 14 Dec 2009 04:40:45 PST</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-1402214861146163548</guid><description>Bugün tekrar aktif hayata dönme çabalarım içerisinde güncel haberleri okuma atraksiyonumu ifa ederken üzücü bir haberle karşılaştım. Str0ke nickli ünlü Milw0rm sitesinin owner'i geçirdiği kalp yetmezliği nedeni ile vefat etmiş. Haberin kaynağı her ne kadar beni pek ikna edememiş olsa da doğruluk payı ihtimalini göz ardı edemiyoruz. Malum milw0rm uzun süredir güncellenmiyordu. Umarım haber hoax çıkar ve Str0ke sevenlerini yalnız bırakmaz.&lt;br /&gt;&lt;br /&gt;Haberin kaynağı: &lt;a href="http://bl4cksecurity.blogspot.com/2009/11/str0ke-milworms-funeral-is-this-friday.html"&gt;Milw0rm is gone&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;Düzeltme: Evet tahminlerim beni yanıltmadı = &lt;a href="http://www.offensive-security.com/blog/offsec/offensive-security-exploit-archive/"&gt;Milw0rm is Alive&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;Sanal alemde ki haberlere hemen zıplamayın'a güzel bir örnek :)&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-1402214861146163548?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2009-12-14T14:40:45.652+02:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Warning: Your body is infected by  A(H1N1) virus</title><link>http://kernelturk.blogspot.com/2009/11/warning-your-body-is-infected-by-ah1n1.html</link><category>A (H1N1)</category><category>grip</category><category>H1N1</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Tue, 10 Nov 2009 03:42:26 PST</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-4701679771922658403</guid><description>Söylenenler sahiden doğruymuş; bu grip denen melet hemde h1n1'li si ilaçlı 7 gün ilaçsız 1 haftada geçiyor. Önceki hafta Cuma günü beni yatağa mıhlayıp bugün itibari ile doğrulmama izin verdiği için saygıdeğer virüsümüze sonsuz şükranlarımı iletiyorum. Doğrusunu söylemek gerekirse diğer grip sendromlarının çok üstünde bir efor harcattı bünyeme. Doktor tarafından verilen ilaçlardan tutunda annemin bitkisel ilaç karışımlarına kadar onlarca şey denemem sadece bol bol uyumama neden oldu ve hala beynimdeki ve ellerimde ki uyuşukluk geçmiş değil bu yüzden imla hataları ve saçmalamalar yüzünden peşinen özür diliyorum :)&lt;br /&gt;&lt;br /&gt;Hastalık sürecinde canımı en çok sıkan ama alışkanlıktan olsa gerek pek umursatmayan ülkemiz insanlarının ve onları bu denli bir paranoyaya sokan devlet organları ve medyanın tutumu oldu. 2 gün üst üste , gece yarıları dahil farklı saat dilimlerinde 7 kez 5 farklı hastaneye (2'si devlet 3'ü özel) girme girişimim derbi maç öncesi stat önünden farksız olan kalabalık yüzünden başarısızlıkla sonuçlandı. İnsanlar çıldırmış gibi hastahanelere akın etmişler. Bir kez hapşıran da gelmiş , gözü sulanan da. Benim gibi 41 derece ateşliler ise ya o hengamede beklemeyi tercih edecek ya da evine gidip makus kaderine razı olup yorganı üstüne çekecek. &lt;br /&gt;&lt;br /&gt;Soranlar olabilir ! Nereden biliyorsun o virüsü taşıdığını ? diye. Tabi ki bilmiyorum ama karşılaşma fırsatı bulduğum ve 1dk lık bir görüşme şansı yakaladığım acil dokturu ile aramda geçen diyalog: &lt;br /&gt;&lt;br /&gt;Dr House - "hımm " dereceye bakıyor "40 derece .... kaç gündür hastasın"&lt;br /&gt;Ben - "bugün 4.gün ve ateşim 38.5 ile 41 arasında"&lt;br /&gt;Dr House - "bulantı, ishal filan oldumu?"&lt;br /&gt;Ben - "evet sanırım 18 kez istiğfra ettim ve karın kaslarım işlemez halde"&lt;br /&gt;Dr House - "delikanlı işte sende kapmışsın domuzun gribini ama neyse varmı evde ilacın?"&lt;br /&gt;Ben - "Evde??? İlaç ???"&lt;br /&gt;DR House - "tmm " bişiler karalıyor "bunları al istrahat et"&lt;br /&gt;&lt;br /&gt;Bende bu gribin birilerinin cebini doldurabilmek için türetilmiş bir varyant olduğunu düşünenlerdenim ve onların asla kazanmasını istemem ancak hayatınızdan vereceğiniz bir 5 gününüz yoksa gidip Sam amcanın iğnesini vurulmakta bir şık olarak önünüze çıkıyor. &lt;br /&gt;&lt;br /&gt;Hepinize sağlıklı ve mutlu günler.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-4701679771922658403?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2009-11-10T13:42:26.474+02:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">5</thr:total></item><item><title>Günlükten Çıkanlar - 2</title><link>http://kernelturk.blogspot.com/2009/11/gunlukten-ckanlar-2.html</link><category>Device Driver</category><category>Windows Internals</category><category>kernel mode</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Tue, 03 Nov 2009 06:09:40 PST</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-249130078896639174</guid><description>2005 Yılının ajandasınıda buldum , sadece 8 sayfa not karalamışım ve birbirinden kopuk bilgilerden oluşuyor lakin meraklıları için güzel nimet :&lt;br /&gt; &lt;br /&gt;- Device Driver'lar SYSTEM olark anılan özel bir context'te çalışırlar. Bunu taskmanager'da görünen SYSTEM kullanıcısı olarakta görebiliriz.&lt;br /&gt;&lt;br /&gt;- Her Aygıt  sürücüsü (Device Driver) bir Device Name tag'ı ile tanımlanır. Her sürücü kullanacağı aygıt için bir isim oluşturmalıdır.&lt;br /&gt;&lt;br /&gt;- Sürücüler DriverEntry rutininde aygıt için DeviceObject adı verilen aygıtı tanımlayısı sistem taraflı bir nesne ve SymbolicLink adı da verilen ve aygıt adının usermode tarafında da görülebilmesini sağlyan ortak nesne yaratır. Ayrıca bazı driver'a ve aygıta özel başlangıç işlemleride yapar.&lt;br /&gt;&lt;br /&gt;- Driver'lar fiziksel bir aygıtı kontrol etmek zorunda değildirler. Bunun yerine sadece sürücü kodu içerisinde verilen görevleride yapabilirler. Ancak unutulmaması gereken en önemli husus bu kodların ring0 denilen en imtiyazlı seviyede çalıştıklarıdır. &lt;br /&gt;&lt;br /&gt;- Driver'lara yapılan tüm istekler birer I/O Request Packet (IRP) biçiminde yollanır. Driver, tüm sürücü istekleri için önceden DriverEntry rutininde tanımlanmış olan fonskiyon pointer'larını SYSTEM context'inde bekler.&lt;br /&gt;&lt;br /&gt;- Tüm işlemlerin virtual address (sanal adresleri) aynı olabilir ancak fiziksel sayfaları farklı adresleri işaret eder.&lt;br /&gt;&lt;br /&gt;- Farklı process'lerin her iki modda aynı hafıza alanını kullanabilmesi için named memory mapped file oluşturması gerekmektedir.&lt;br /&gt;&lt;br /&gt;- ObReferenceObjectByHandle komutu belirtilen handle'in istenen erişim izinlerine uygun olup olmadığına bakar. Eğer handle'a istenilen kriterlerde erişim izni verilirse programcıya STATUS__SUCCESS durumu döner.&lt;br /&gt;&lt;br /&gt;- 32bit işlemciler bir hafıza adresine erişirken 16bit'lik bir Segment Selector ve 32bit'lik segmentle birlikte kullanılacak offset değeri kullanır. &lt;br /&gt;&lt;br /&gt;- Segmentlere erişim ile alakalı gerekli blgiler işlemciye segment table yoluyla aktarılır.Segment Selector, segment table içindeki bir index'tir. &lt;br /&gt;&lt;br /&gt;- Herhangi bir anda yalnızca 2 adet segment tablosu aktif olabilir. Bunlar GDT v LDT'dir.&lt;br /&gt;&lt;br /&gt;- Segment Selector'de ki bir bit kullanılarak CPU hangi Segment tablosunu kullanacağına karar verir.&lt;br /&gt;&lt;br /&gt;- Segment Descriptor'lar, hafızanın bir bölgesini işaret eden bilgiyi ve o bölgeye erişebilmek için gereken erişim haklarına ait bilgiyi tutar. Segment Descriptorlar , Segment Tablosunun içerisinde array şeklinde yer alırlar. Bir Segment Descriptor kısaca bir segmentin başlangıç adresi ile boyutunu tutar ve imtiyaz seviyesini belirten DPL olarakta bilinen 2 bit'i kullanır.&lt;br /&gt;&lt;br /&gt;- İşlemci bir segment'e erişim izni vermeden önce DPL ve RPL'i karşılaştırır. RPL selector'de yer alan 2 bitlik bir imtiyaz belirteçidir. &lt;br /&gt;&lt;br /&gt;- Address Translation işlemindeki ilk adım, segmetin taban adresi ile offset'in toplanmasıdır. Bu işlemin sonucunda eğer paging mekanizması aktif değil ise doğrudan çıkan sonuç fiziksel adresi gösterir. Paging aktif ise bu adrese logical veya lineer adres adı verilir ve fiziksel adresi bulabilmek için eldeki veri tekrar Paging Address Translation adı verilen bir başka mekanizmaya devr edilir.&lt;br /&gt;&lt;br /&gt;- Memory Management şeması Paging olarak anılır. Çünkü Hafıza, Pages olarak bilinen sabit boyutlu birimler halinde tanımlanır. Intel işlemciler üzerinde bir sayfa 4kb olarak varsayılır.&lt;br /&gt;&lt;br /&gt;- 32bit Adresleme ile fiziksel hafıza ancak 4GB adreslenebilir. Bunun anlamı 1 milyon sayfayı adresleyebilirsiniz demektir. &lt;br /&gt;&lt;br /&gt;- Bir PageDirectoryEntry'si eğer LSB(Least Significant bit) bit'i 1 ise geçerli olarak değerlendirilir. &lt;br /&gt;&lt;br /&gt;- WindowsNT her process için ayrı bir PageTable tutar ve bunun sanal adres aralığıda 0xC0000000 dan 0xC03fffff'dir.&lt;br /&gt;&lt;br /&gt;- Page Table Directory (1024)1K adet Page Table'in adresini tutar. PDT Lineer adresin son 10bit'inde (22-32 bitleri) yer alır ve bu tabloda ki bir girişe işaret eder.&lt;br /&gt;&lt;br /&gt;- Page Table , adresleri PDT'de bulunan ve kendi tablolarında 1024 adet PageTableEntry(PTE) tutan PageTableFrame(PTF)'ye işaret eden tablolardır. Lineer adresin 12 ve 22 bit'leri arasında yer alır.&lt;br /&gt;&lt;br /&gt;- Address space olarak bilinen kavram PageDirectory'den başka bişi değildir. Page Directory'nin gösterdiği table'lar üst yarısı bütün process'ler için aynıdır. &lt;br /&gt;&lt;br /&gt;- MMCreateProcessAddressSpace fonksiyonu hafızanın 3 aşağıdaki işler için ayırır:&lt;br /&gt;Birinci sayfayı PageDirectory için, ikinci sayfayı HyperSpace Page table girişlerini tutmak için ve 3.Sayfayıda Process ilk defa oluşturulduğunda working set olarak anılan , processin .code , .data , stack gibi nesnelerini tutmaya yarayan hafıza öbeğinin adresini tutar.&lt;br /&gt;&lt;br /&gt;- Memory-Mapped, dosyaları, NT section nesneleri ile çalışabilmek için kullanır.&lt;br /&gt;&lt;br /&gt;- Bir Process'in çalışma anında fiziksel hafızaya alınamayan kısımları işaretlenir. Process ne zaman hafızada bulunmayan bir datasına ulaşmaya çalışırsa , önceden işaretlenmiş alanlar ikincil depolama aygıtından (senaryomuzda bu hdd'dir) ana hafızaya getirilir. &lt;br /&gt;&lt;br /&gt;- Eğer İşletim sistemi fiziksel hafızayı(RAM) tüketirse kendine yer açailmek için bazı dataları atmak durumunda kalır. Ancak bu boşaltım işlemi geri dönüşümsüz bir silinme şeklinde değil swapping yapılarak tekrar hdd'ye atılır ve dilendiği zaman oradan geri alınabilir. Bu dataların atılma işlemine karar verme mekanizması "Replacement Policy" olarak bilinir. Bu mekaizmada WindowsNT FIFO(İlk giren ilk çıkar) yönetimini kullanarak yerine getirir. Bu policy'ye göre bir yer sıkıntısı olduğunda bellekte ki en eski veri atılmış olacaktır.&lt;br /&gt;&lt;br /&gt;- Eğer bir Page fiziksel Ram'in üzerinde map edilmemişse WindowsNT bu sayfayı "invalid" olarak işaretler. Bu sayfaya herhangi bir erişim gerçekleşirse bir "page fault" gerçekleşir ve bu hatayı yakalayan "page fault handler" hdd'den ilgili datayı az önce yukarıdaki bahsettiğimiz şekilde getirir.&lt;br /&gt;&lt;br /&gt;- Eğer Page bir dll veya executable code içeriyor ise saygfa da o ilgili dll veya exe dosyadan alınır. Şayet sayfa bir data içeriyor ise sayfayı swap dosyasından alacaktır. Yani kod içeren bölgeler datalardan önceliklidir. Eğer sayfa Memory-Mapped paylaşımlı dosya alanından alınacak ise sayfa uygun dosyadan alınır.&lt;br /&gt;&lt;br /&gt;- Windows NT fiziksel hafızadaki boş alanı sürekli tahrip eder, böylece bir page fault meydana geldiğinde hdd'den çıkarılacak sayfa için yer ayırabilecektir. Bu takip bilgileri, Page Frame Database (PFD) olarak anılan Kernel data yapısında tutulur.&lt;br /&gt;&lt;br /&gt;- PFD hafızadaki sayfaları FIFO tabanlı bir listede tutar ve yer sıkıntısı olduğu durumlarda atılacak sayfaya karar verir. Ancak bir sayfayı atmadan önce WindowsNT bu sayfanın "dirty" kirli olmadığından emin olmalıdır. Dirty biti sayfanın yazılmış olduğunu ve hafızadan atılmak icap eden durumlarda bu sayfanın ilgili swapping işlemine uygun olduğunu gösterir. Ayrıca PFD paylaşılan sayfalar içine bir referans sayacı tutar ve yalnız bu sayaç ilgili sayfa için sıfır olduğunda atılır. Genelde PFD her fiziksel sayfanın durumuna bakar. PFD her fiziksel sayfa için 24byte 'lık bir array'dir. PFD arrayinin boyutu bir kernel değişkeninde depolanan fiziksel sayfanın sayısına eşittir. Bu değeri tutan değişken "MmNumberOfPhysicalPages"'dir. PFD'nin adresini yine bir kernel değişkeni olan MmPfnDatabase tutar. Bir fiziksel sayfa farklı durumlarda olabilir. Örneğin in-use, free ,free ama dirty gibi. PFD girişi bir doubly linkd list'e ve fiziksel sayfanın durumuna bağlıdır. Örneğin boş sayfaları tanımlayacak PFD girişleri free page listesine bağlıdır.&lt;br /&gt;&lt;br /&gt;- Virtual Address Descriptor: Windows NT her boş fiziksel sayfanın listesi ile birlikte ayrıca her Process için ayrılmış olan virtual address boşluğunuda izlemeye ihtiyaç duyar. Bir Process ,bir hafıza bloğu ayırmak istediği zaman ki bu işlem örneğin bir dll i hafızaya almakta olabilir bu esnada WindowsNT Virtual Address boşluğundaki boş bloklar için bir kontrol yapar ve ondan sonra gereken yeri ayırır, ve Virtual Address map'i bu doğrultuda günceller ve hali ile bu işlem bilgilerini alabileceği en doğru yer Page Table'dir. &lt;br /&gt;&lt;br /&gt;- IO Manager , gerekli şartlar oluşup bir IRP oluşturulduğunda IRP yapısının AssociatedIRP.SystemBuffer alanına usermode'da yer alan buffer'indaki bilgiyi geçer.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-249130078896639174?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2009-11-03T16:09:40.850+02:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><item><title>Biraz sinerji katalım</title><link>http://kernelturk.blogspot.com/2009/11/biraz-sinerji-katalm.html</link><category>kernel tricks</category><category>driver development</category><category>kernel mode</category><category>IRP</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Mon, 02 Nov 2009 06:40:02 PST</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-251960271375732222</guid><description>Takip edenler bilir, yaklaşık bir aydır eski nostaljim olan kernelmode dünyasına geri döndüm. Kendisi ile 2 sene önce hazin bir ayrılık yaşamış ve highlvl yollarını aşındırır olmuştum. Sağolsun  &lt;a href="http://zararliyazilim.wordpress.com"&gt;Emre Tınaztepe&lt;/a&gt; ve &lt;a href="http://kutalmis.wordpress.com"&gt;Kutalmis&lt;/a&gt; dostlarım sayesinde tekrar gerçeten severek uğraştığım işe geri döndüm. Bu sebeple yıllar önce şirketteki a4 ve toner kapasitesinin tükenmesine neden olduğum kernelmode dökümanlarımı tekrar gün yüzüne çıkardım ve hararetle okumaya başladım. &lt;br /&gt;&lt;br /&gt;Dökümanları karıştırıken günlük gibi tuttuğum ve iyice sararmaya yüz tutmuş olan not defterime denk geldim. Okudukça iyiki yazmışım bunları dedim ve sizlerle paylaşmak için hemen bloguma giriş yaptım. Umarım sizlerinde işine yarar:&lt;br /&gt;&lt;br /&gt;== 2004 ==&lt;br /&gt;- User-Mode kodları Objectlere handle'ları kullanarak erişir ancak Kernel-Mode kodları Object'lere doğrudan erişirken pointer'ları kullanır. &lt;br /&gt;&lt;br /&gt;- Object'lerde bulunan ReferenceCount hem user-mode dan handle lar vasıtası ile yapılan erişimlerde hem de kernel-mode'dan yapılan erişimlerde 1 artar.&lt;br /&gt;&lt;br /&gt;- Bir process zaten çok küçük zaman aralıklarında çalıştığından (quantum slice) hafıza bölgelerinede bitişik olsalar dahi çok küçük erişim boyutlarında erişir. &lt;br /&gt;&lt;br /&gt;- İşletim Sistemi, bir processin sadece o an hafızada çalıştığı kümelerini (bknz:working set) saklamaya ihtiyaç duyar&lt;br /&gt;&lt;br /&gt;- Her device controller local bir buffer'a sahiptir. CPU bu local bufferdan, ana hafızaya veya ana hafızdan local buffera data taşır &lt;br /&gt;&lt;br /&gt;- I/O: Aygıttın kendi device controllerinde bulunan local buffer'a yapılan işlemdir.&lt;br /&gt;Device controller daha sonra bu i/o işleminin bittiğini Cpu'ya interrupt kullanarak bildirir.&lt;br /&gt;&lt;br /&gt;- Trap bir kullanıcı hatası veya başka bir problemden dolayı meydana gelen yazılımsal bir interrupt'tır&lt;br /&gt;&lt;br /&gt;- I/O Manager, bir IRP oluşturduğunda _IRP yapısının AssociatedIrp.SystemBuffer buffer alanına kullanıcı taraflı buffer alanındaki bilgiyi geçer. &lt;br /&gt;&lt;br /&gt;- IofCompleteRequest çağrısı ile bir irp için gerekli işlemlerin tümünün yapıldığı varsayılır. Bu komut sonrasında I/O Manager driver taraflı buffer alanını user taraflı buffer alanına kopyalar.&lt;br /&gt;&lt;br /&gt;- IRQL Notları&lt;br /&gt; &lt;br /&gt;1.Bir fonksiyona girdiğinizde mutlaka IRQL'ni kontrol edin&lt;br /&gt;2.Her hangi bir fonksiyonu çağırmadan önce IRQL'ı için DDK'ya göz atın&lt;br /&gt;3.Eğer bir thread en düşük IRQL seviyesinde çalışıyorsa onu daha fazla alt seviyeye indiremezsiniz, ancak yükseltebilirsiniz.&lt;br /&gt;4.DISPATCH_LEVEL da PAGE_FAULT yaşamazsınız&lt;br /&gt;5.Paging I/O APC level'da yapılır&lt;br /&gt;6.Kullanıcı her zaman PASSIVE_LEVEL da çalışır &lt;br /&gt;7.Kernel'de PASSIVE_LEVEL da çalışabilir. &lt;br /&gt;8.PASSIVE_LEVEL da iş yükü dağıtımına izin verilir&lt;br /&gt;9.DPC'ler DISPATCH_LEVEL da çalışırlar ve preempt edilemez(etkisizleştirilemez) (ama interrupt edilebilirler tabiki) ve dispatcher olduklarından DISPATCH_LEVEL'da çalışırlar.&lt;br /&gt;10.IRQL'ları manipüle etmek için KeLowerIrql() ve KeRaiseIrql fonksiyonları kullanılır.&lt;br /&gt;&lt;br /&gt;- IRP  Notları &lt;br /&gt;&lt;br /&gt;1.IRP'ler bir uygulamanın veya driver'in davranışları üzerinden IoManager tarafından üretilirler. IRP'in üst kısmı (header) sabit bilgilerden oluşur, alt kısım ise stack location adı verilen bilgi yığınından oluşur.&lt;br /&gt;2.Uygulama driver'a yalnızca kontrolü IRP'lar vasıtası ile devredebilir, ve bilgiler paylaşılan bir hafıza tarafından değiş tokuş edilir.&lt;br /&gt;3.IoManager driver'lar için bir IRP kuyruğu tutmaz, sadece ne zaman alınacaklarını ve gönderileceklerine bakar. IRP'leri kuyruklamaktan driver kendisi sorumludur.&lt;br /&gt;4.IRP sürücü IoCompleteRequest isteği çağrıldığında işlemini sonlandırır.&lt;br /&gt;5.Irp-&gt;IoStatus.Information transfer edilen data boyutunu içerir ve bu bilgi usermode tarafındaki DeviceIOController'in en son paramtresi olan bytesreturned'e aktarilir.&lt;br /&gt;6.IoManager geri donen bilgiyi  SystemBuffer'dan OutputBuffer'a kopyalar.&lt;br /&gt;7.IoCompleteRequest fonksiyonu IoManager'a bildirilen en son IRP çağrısıdır ve bu IRP'in artık işinin sona erdiğini bildirir. Bu çağrı bir kez yapıldıktan sonra artık o IRP'e erişilemez.&lt;br /&gt;8. Driver'dan Driver'a IRP'ler vasıtası ile haberleşilebilir. Driver'lar aynı adres boşluğunda çalıştıklarından her biri bir diğeri ile paylaşımlı hafıza alanları sayesinde iletişim kurabilir.&lt;br /&gt;9.IRP, sürücü katmanları arasında dolaşabilir. Bu IRP'in bilgilerine IoGetCurrentIrpStackLocation çağrısı ile ulaşılabilir.&lt;br /&gt;&lt;br /&gt;İşe yarar temelinizi oluşturacak şeyler buldukça paylaşmaya devam edeceğim... ,&lt;br /&gt;&lt;br /&gt;Şimdilik sağlıcakla.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-251960271375732222?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2009-11-02T16:40:02.748+02:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">1</thr:total></item><item><title>Programcı Kütüphanesi</title><link>http://kernelturk.blogspot.com/2009/10/programc-kutuphanesi.html</link><category>Windows Internals</category><category>Win32 Tricks</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Tue, 03 Nov 2009 04:40:31 PST</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-1111282892992701292</guid><description>Buldukça ekliyeceğim bazı eski yazılarım ve sanal ortamlarda yaptigimiz münazarlara ait linkleri sizinle paylaşmak isterim. Şimdilik bunlar çıktı :&lt;br /&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Konu:&lt;/span&gt;Bir ara gaza gelip komple çevirisini yapmaya niyetlendiğim Win32 Api'nin Windows'lara ait çevirisi. &lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;a href="http://www.snakeforce.com/forum/forum_posts.asp?TID=41&amp;PN=1"&gt;Win32: Pencereler&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Konu:&lt;/span&gt;Sene 2003 Masm32 ile yeni tanışmışım bi yandan okuyorum bi yandan kodluyorum. Baktım kavraması zor her satırı ileride anlıyayım diye commentlemişim. Buyrun aynı çileyi çekmeyin:&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;a href="http://www.snakeforce.com/forum/forum_posts.asp?TID=53&amp;KW="&gt;Masm32 Iskelet&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Konu:&lt;/span&gt;Masm32 yi çözdük ama bu seferde ddk ya merak saldık ve aynı "anla+kodla ve çevir" sistemini bunada uyguladım. Sağolsun rus dostlardan F-Four sağlam bi makale serisi hazırlamış bizede çevirip derlemesi düştü:&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;a href="http://www.snakeforce.com/forum/forum_topics.asp?FID=33"&gt;Sistem Programcılığı Serisi&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Konu:&lt;/span&gt;Win32 Pipe mantığı ve bir örnek&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;a href="http://www.snakeforce.com/forum/forum_posts.asp?TID=67&amp;PN=1&amp;RN=3"&gt;Pipe'ler&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Konu:&lt;/span&gt;Exe'ler nasıl çalışır . Ben baktım güldüm açın sizde gülün :)&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;a href="http://www.spymastersnake.org/forum/thread.php?threadid=2817"&gt;Exe'ler nasıl çalışır&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Konu:&lt;/span&gt;Kripto ve Sıkıştırma hk. Bi aralar güzel münazaralar oluyordu hey gidi günler...&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;a href="http://www.spymastersnake.org/forum/thread.php?threadid=2286"&gt;Sıkıştırma ve Kriptografi&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Konu:&lt;/span&gt;O zamanlar popüler olan Pe header yapısı hakkında münazara ediyorduk &lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;a href="http://www.spymastersnake.org/forum/thread.php?postid=13615#post13615"&gt;Import Section olmaksızın executable derleme&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Konu:&lt;/span&gt;İşe girdim ve ilk defa kısıtlı bir domain kullanıcısı ile tanıştım. Nereye el atsam erişim engellendi hatası. Ben ve Erişim Engellendi hatası aaa hiç olurmu :) Kabul ediyorum acaip amatörce keşifler.&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;a href="http://www.olympos.org/belgeler/gp/microsoft-ve-gpo-aciklari-19225.html"&gt;Microsoft ve Group Policy Açıkları&lt;/a&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;a href="http://sistemdoktoru.com/forums/thread/27153.aspx"&gt;Gpo ile Kısıtlanan Çalıştır (Run) menüsünü geri getirme&lt;/a&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;Link:&lt;/span&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-1111282892992701292?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2009-11-03T14:40:31.706+02:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">4</thr:total></item><item><title>Masm32 ve Win32Api Voltran Voltran Voltran</title><link>http://kernelturk.blogspot.com/2009/10/masm32-ve-win32api-voltran-voltran.html</link><category>win32</category><category>ia32</category><category>masm32</category><category>assembly</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Tue, 05 Jul 2011 11:32:54 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-4973359813647551121</guid><description>Şimdiden uyarayım, okuyacağınız makaleyi 6 sene önce yazdım, kalkıp ta "hala bu adam niye bunları anlatıyor!" demeyin :) Baktım ki dostlar makaleleri ardı ardına diziyorlar, kıskandım bende cem yılmaz misali: "zaten burada yazılmışı var" değip ekledim bloğuma. Hadi size iyi okumalar ve kavramalar.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;span style="font-weight: bold;"&gt;Win32&amp;amp;Masm32 &lt;/span&gt;&lt;br /&gt;
&lt;br /&gt;
Bu dökümanı ayrıntılı olarak yazmamın en büyük sebebi Türkiye'de ki yanlış anlaşılan ve uygulanan sistem programcılığı müessesini bir nevi olsa da gerçek manasıyla anlaşılabilirliğini sağlamaktır. Dil olarak assembly'i seçmemin manası ise, sistemin işleyişini akıllarda soru işareti bırakmayacak bir şekilde yalın olmasını sağlamaktır. Zaten öncelikle bu dokümanın okuyucuları için assembly temelden inceleyen bir giriş yapılacaktır.&lt;br /&gt;
&lt;br /&gt;
Assembly öğrenmek demek, &lt;br /&gt;
&lt;br /&gt;
· Çalıştığınız mimariyi çok iyi tanımak,&lt;br /&gt;
· Hatasız kodlar üretebilmeyi sağlamak,&lt;br /&gt;
· Yazılım eksikliklerini keşfedebilmek,&lt;br /&gt;
· Hızlı ve eksiksiz programlama süreçleri oluşturabilmek,&lt;br /&gt;
&lt;br /&gt;
gibi yetenekler kazandıracaktır. Assembly de en azından orta seviye bir programcı olabilmek için; hardware yapıları, işlemci mimarisi, hafıza yönetimi, os mimarisi, process davranışları ve eğer ilgileniyorsanız network alt yapısının, katmanlarının ve iletişim mimarisinin nasıl çalıştığı hakkında bilgilere sahip olmak zorundasınızdır. Korktunuz mu! Yapmayın hani sistem uzmanı olmak istiyordunuz?&lt;br /&gt;
&lt;br /&gt;
Ben şöyle düşünüyorum. Sonuç olarak derlenmiş kodlar makine koduna dönüyor ve tüm işleri yapan işlemcimiz de en iyi ondan anlıyor, öyleyse önce onu öğrenmeliyim ki sonra üst katman dilleri  geçtiğimde daha hatasız kodlar derleyeyim. Tabi birde karşılaşacağım opcode seviyesi hataların da yorumlayıp hata tespiti yapabileyim. Ayrıca işin birde tilki tarafı var ancak bahsetmeyeyim şimdilik. :)&lt;br /&gt;
&lt;br /&gt;
Dokümana başlamadan önce şunu da belirtmek isterim ki, bu dokümanın hedef kitlesi herhangi bir programlama dilinde en azından orta seviyede bilgili ancak kendini sistem programcılığı konusunda da yetiştirmek isteyen arkadaşlar olacaktır. Dokümanı elimden geldiğince basitleştirip, arada bir iğrenç espirilerimden sıkıştırıp eğlenceli hale getirmeye çalışacağım. &lt;br /&gt;
&lt;br /&gt;
Kısa bir giriş İşlemci&lt;br /&gt;
&lt;br /&gt;
Burada işlemcinin ne olduğunu ve hayat hikayesini anlatacak değilim . Sadece bizi ilgilendiren yerlerini bilmemiz şu anlık yeterli olacaktır.&lt;br /&gt;
&lt;br /&gt;
Nasıl ki diğer programlama dillerinde değişkenler kullanarak bazı değerleri onların içlerinde saklayıp işlemler yapıyorsak assembly içinde işlemcide bulunan registerlar o anlamı ifade eder. Register kavramı eskiden üretici firmalar arasında farklılıklar gösterse de günümüzde bu protokol artık yerleşmiştir.&lt;br /&gt;
&lt;br /&gt;
Registerlar ile değişkenler arasında bir benzetme yapacak olursak.&lt;br /&gt;
&lt;br /&gt;
Delphi için:&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
var&lt;br /&gt;
sayi1,sayi2,sonuc :integer;&lt;br /&gt;
begin&lt;br /&gt;
sayi1:=10&lt;br /&gt;
sayi2:=20&lt;br /&gt;
sonuc=sayi1+sayi2&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
ise&lt;br /&gt;
&lt;br /&gt;
assembly de bu&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
mov ax,10     ;ax artık 10 sayısını saklıyor&lt;br /&gt;
mov bx,20     ;bx artık 20 sayısını saklıyor&lt;br /&gt;
add  ax,bx    ;topladık ve ax artık 30 &lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Bu register'lar dan işlemci de genel amaçlı olanlarından 8 adet bulunur. Bunlar:&lt;br /&gt;
&lt;br /&gt;
EAX,EBX,ECX ve EDX tir. Bunlar 32 bit'lik bilgileri saklarlar ve kendi içlerinde voltran :) oluşturduklarından ayrıca bölünebilirler. Şöyle ki:&lt;br /&gt;
&lt;br /&gt;
*EAX -&amp;gt; AX -&amp;gt; AH,AL&lt;br /&gt;
32b 16b 8b, 8b&lt;br /&gt;
&lt;br /&gt;
*E demek Extended demek ilk işlemcilerde bu yoktu ve 16 bittiler registerlar&lt;br /&gt;
bu örnek yukarıdaki dörtlü için aynıdır. EBX -&amp;gt; BX -&amp;gt; BH,BL gibi&lt;br /&gt;
&lt;br /&gt;
Şu ana kadar yazdıklarımdan bir şey anlamadıysanız baştan tekrar okuyun veya google da daha basit olan ingilizce dökümanları bulun fakat bu anlatılanlar sizi zaten bildiğiniz şeyleri tekrar okutup sıkıyorsa bir sonraki serileri doğrudan ilerleyen konulardan devam etmeniz daha iyi olacaktır.&lt;br /&gt;
&lt;br /&gt;
Bu yukarıdaki dört register cpu tarafından kunta kinte şeklinde yönetilirler ve her şey için kullanılabilir. Bazı işletim sistemleri bu register'ları kendi isteklerine göre gruplandırmıştır. Örneğin Microsoft kendi API sistemin de işletilen fonksiyon geri dönüşlerini sürekli eax'a gönderir. Birde bunların haricinde EDI ve ESI vardır Intel bunları programcılara bir nevi kıyak olsun programcılar uğraşmasınlar diziler ile, koysunlar kopyalanması istenilen diziyi ESI'ye versinler hedef olarak EDI'yi atsınlar bi dongu komutu hepsi EDI'de Yani bi nevi kopyala yapıştır için iyi bir halta yarar bu iki kardeş register . İlerleyen zamanlarda movs, cmps gibi yardımcı komutlarından çıkması ile işlevsellikleri kanıtlanmıştır index registerlarının.&lt;br /&gt;
&lt;br /&gt;
Unutmadan birde ESP var. Amacı ve işleme mantığı şöyledir Esp'yi bir bidon olarak düşünürsek hatta turşu bidonu olarak düşününki :P olay daha da basitleşsin. Turşu bidonumuza zerzevatı ben şu şekilde yerleştirirsem: &lt;br /&gt;
&lt;br /&gt;
| domates | &lt;br /&gt;
| kavun |&lt;br /&gt;
| hıyar |&lt;br /&gt;
| zerdali |&lt;br /&gt;
| floppy :)|&lt;br /&gt;
\________/&lt;br /&gt;
&lt;br /&gt;
bunları alırken hangi sırayla alırım . Intel işlemcileri bunu FILO işlemiyle alır yani First In Last Out - Türkçesi: İlk giren Son çıkar dileyen LIFO yani Last In,First Out'da diğebilir aynı şey J. Kısaca bu istiften yada Intel'in deyimi ile stack'ten ilk çıkan domates olur. Onun peşinden kavun ve en son floppy olur. Halbuki domates en son yığına giren nesnemizdi dimi ama? ESP genelde iki asm komutuyla yönetilir bunlar Push ve Pop tur. Örnekten devam edecek olursak Push komutu kovaya(stack) bi yeşillik atar ve kovanın içindekilerin in sayısını ve yerini tutan bir kayıttaki değeri(ESP) küçültür Pop ise tam tersini yapar kovadan en son atılan malzemeyi alır. Intel işlemcilerinde stackten veri alıp veri koyma işlemleri yaparken register değeri ya 4byte(32bit) artar yada 4byte azalır.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
örnek&lt;br /&gt;
push 20 ; Stacke(kovaya) bi 20'lik attık &lt;br /&gt;
push 10 ; Peşinden onunda üstüne bi 10'luk&lt;br /&gt;
pop ax ; pop komutunu vererek stackin en üstündeki veriyi ax'e aldık ax=10&lt;br /&gt;
pop bx ; bx artık 20&lt;br /&gt;
add ax,bx ;ax=30&lt;br /&gt;
&lt;br /&gt;
kolaymış değilmi? &lt;br /&gt;
&lt;br /&gt;
Tabi bu stackten veriyi illaki en üstündeki alacağız diye bir kaide yok, dilersek stackteki en alttaki veriyi bile elde edebiliriz ama bunu yapan kodlar konumunuz hasebiyle şimdilik size uygun değil.&lt;br /&gt;
&lt;br /&gt;
Şimdi sırada EIP registeri var&lt;br /&gt;
Bu yazmaç yazdığınız programların kodlarını bir sıraya sokar ve adım adım işler. Basit bir benzetme olması açısından Qbasic'i bilenler varsa hatırlarlar:&lt;br /&gt;
&lt;br /&gt;
1 CLS&lt;br /&gt;
2 print "muck muck"&lt;br /&gt;
goto 2&lt;br /&gt;
&lt;br /&gt;
deyip her komutu etiketliyorduk ya işte onun daha gelişmişi eip'tir. Bu register'a dışarıdan komutlarla müdahale şansı doğrudan yoktur. Onu derleyici bir kere ayarlar işletim sistemi de işlemciye yollar işlemcide bu sıraya göre teker teker gider. Ollydbg adlı debugger'ı kullanarak EIP yazmacının mantığını anlamanız daha kolay.&lt;br /&gt;
&lt;br /&gt;
Segmentler:&lt;br /&gt;
CS: SS: DD: ES: FS: GS&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
CS DS ve SS : Programınızı yazıp derlediğiniz zaman, programınız sizin onu kodladığınız halinden milyon kez değişik bir halde çalıştırılabilir dosya haline gelir. Yani sizin anladığınız programlama yapısı ile işlemcinin anladığı yapı çok farklıdır. Siz kodunuzun kodlarının nerede,tanımlamaların nerede,sabitlerin nerede olduğunu bilirsiniz. Ama işlemci bunu ancak programınızı derleyen derleyicinin programınızın çalıştırılabilir kod haline getirdiği zaman içerisine eklediği bazı ipuçlarından faydalanarak bulabilir. İşte programınızın kodlarının nerede mahfuz tutulduğunu işaret eden olaya Code Segment(CS), verilerinizi işaret eden bölüme Data Segment(DS), değişkenleriniz,fonksiyon geri dönüşleriniz ve işlemci taraflı kod dallanmaları gibi göstergeyede Stack Segment(SS) denir. İşlemci programınızı çalıştırmak için hazırlık yaparken CS segmentine bakarak kodların yerini DS segmentine bakarak tanımlamaların yerini SS'ye bakar ise Stack'in yerinin bulur.&lt;br /&gt;
&lt;br /&gt;
Peki işlemci kodların yerini buldu diyelim ancak bu kadar kodun içerisinden nereden başlayacağını nasıl bilecek. Yukarıda yazmıştık değil mi? EIP yazmacından. Siz programınızı derlediğinizde programlama dilinize ait compileriniz bu işlemi sizin için ve cpu için yapar. Programlama dili konseptlerin de şu vardır ki her yazılan kod için bir Entry Point vardır. Siz programınızı derler ve çalıştırırsınız ancak compiler önce sizin yazdığınız kodu icra etmek yerine, yazdığınız program için çalışacak ortamı hazırlamak için öncü bazı hazırlıklar yapacaktır. Her program için işletim sistemi o programa ait giriş noktasını gösteren CS:EIP çiftini hazırlar. İşlemci'de o CS:EIP ikilisine ait ,bazı çevrimler yaparak kodu icra etmeye başlar. &lt;br /&gt;
&lt;br /&gt;
Şimdi hızlı bir giriş yaparak assembly programlamaya başlayabiliriz.&lt;br /&gt;
&lt;br /&gt;
www.masm32.com Bu yazdığımız programları işe yarar hale getirmek için gerekli. Çektiğiniz zaman zipi sürücülerinizi kök dizinlerine açın ör: C: D: E: Ğ: :)&lt;br /&gt;
&lt;br /&gt;
OllyDbg Buda derlediğimiz programlarımızı irdeleyebilmemiz için gerekecek.&lt;br /&gt;
&lt;br /&gt;
Evet gerekenler bunlar ve hepsi içerisindeki örneklerden oluşan kabarıklığı saymazsak 1.5 mb kadar alan kaplıyor . &lt;br /&gt;
&lt;br /&gt;
Masm32 Win ortamlarda assembly kodları ile çalışmak için geliştirilmiş bir derleyicidir. Yazdığınız *.asm uzantılı kodlarınızı size *.exe *.dll olarak sunar. Kabul ettiği ve anladığı tek şey assembly komutlarıdır.&lt;br /&gt;
&lt;br /&gt;
Basit bir giriş yaparak aşağıdaki gibi bir örnek verecek olursak:&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.386&lt;br /&gt;
.model flat, stdcall&lt;br /&gt;
option casemap:none&lt;br /&gt;
include \masm32\include\windows.inc&lt;br /&gt;
include \masm32\include\kernel32.inc&lt;br /&gt;
include \masm32\include\user32.inc&lt;br /&gt;
includelib \masm32\lib\user32.lib&lt;br /&gt;
includelib \masm32\lib\kernel32.lib&lt;br /&gt;
&lt;br /&gt;
.data&lt;br /&gt;
Baslik      db "Ben bir başlığım",0&lt;br /&gt;
Mesaj      db "Selamün Aleyküm Dünya!",0&lt;br /&gt;
&lt;br /&gt;
.code&lt;br /&gt;
start:&lt;br /&gt;
invoke MessageBox, NULL,addr Baslik, addr Mesaj, MB_OK&lt;br /&gt;
invoke ExitProcess,NULL&lt;br /&gt;
&lt;br /&gt;
end start&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Evet yapısı itibari ile biraz karışık olduğu konusunda haklısınız ancak bu kanınızın ileride değişeceğine eminim. Şimdi yukarıda ki kod örneğimiz üzerinde ayrıntılı bir inceleme yapalım.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.386&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Bu komut masm32 derleyecisine(compiler)'e kısaca şöyle der: "Dostum bu programı yazan herifin yazdığı kodlar eski 386 işlemcilerin anladığı opcode'lardan oluşuyor derleme yaparken ona göre yap" der.Ancak bu seçeneği seçerseniz yeni nesil .686 işlemciler için çıkmış son nesil kodlardan yararlanamazsınız. Bu seçeneği isterseniz .686 da yapar yeni nesil komutlarla çalışabilirsiniz. Ayrıca bir diğer önemli hususta adresleme modlarıdır. Yani bu komut eğer .386 altı bir değer ise ör: .286 ve daha aşağısı gibi adresleme modları daha yeni nesil adresleme modlarını örmeğin(80386 Scaled Indexed Addressing Modes) [çok iyi bir indeks bulma yöntemidir zatî alîler-i]desteklemez. O yüzden en iyisi siz .386 ve yukarısını işlemci aileleri ile çalışmayı seçin sonra kafanız ağrımasın.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.model flat,stdcall&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Bu komut ise programınızı kodlarken bir hafıza işlemi yaptığınızda ve yahut bir komut çağırdığınızda işe yarar. Şöyle ki: Eğer 32.bit için program yazıyorsanız genelde flat hafıza yöntemi kullanırsınız çünkü flat komutu hafızayı 4GB sanal bellek olarak varsayar.&lt;br /&gt;
&lt;br /&gt;
Ne demek 4Gb sanal bellek kullanmak? Eski işlemcilerle hafıza sadece 640kb olarak adreslenebiliyordu, sonraları bu sınır segmentasyonda yapılan bazı değişikliklerle 1MB sınırına ulaştı. Ancak işlemci teknoloji gelişmiş ve 32'bitlik bir mimari kazanmıştı. Buda artık hafızaya 32 bitlik erişimler yapılabileceği anlamına geliyordu. Kısaca 32Bit erişimlerle 4GB hafıza adreslenebiliyor. (Bunu windowsunuzun hesap makinesinde 32 adet 1'lik biti yan yana getirip daha sonra decimale çevirdiğinizde görebilirsiniz. ) Peki sisteminizde 32 Mb Ram 512mb hdd varken(küçümsemeyin benim hala böyle çalışan bir sistemim var J) nasıl oluyor da her program 4GB hafıza kullanabiliyor. Bu aslında işlemci üreticilerinin geliştirdiği basit ama bir o kadar da harikulade bir numara. Olay şöyle cereyan ediyor. Her program için işletim sisteminiz sadece programınızı ilgilendiren bir tablo tutar. Bu tabloda programınıza ait hafıza adreslerini gösteren adına linear address dediğimiz konumlandırıcılar için fiziksel hafızada nereye denk geldiklerini gösteren girdiler vardır. Daha da basitleştirirsek: olayı 2 sütunlu excel tablosu gibi düşünebiliriz. A sütunu Doğrusal adresleri(linear) b sutunu ise Fiziksel adresleri belirtiyor olsun. Fiziksel adresten kastımız Ram'imizdir. Bu sütunlarda programınıza ait bazı en çok kullanılan doğrusal adreslere denk düşen fiziksel sayfa numaraları bulunur. Tabi o sütunların hepsinde her doğrusal adrese bir fiziksel adres denk geliyor diye bir kaide yok. Dedik ya sadece çok sık kullanılanlar o tabloda yer alıyor. Eğer işlemci programınızdan o tablonun fiziksel sütununda bulunmayan bir doğrusal adresini çağırırsa, işletim sistemi cpu için hdd'ye giderek o programın o doğrusal adresine denk düşen veriyi alır ve o fiziksel sayfa sütununa koyar. İşlemci de "'her şey ne kadar güzel 1.76 gb'da bile verilere erişebiliyorum "' der J. Biraz daha anlatmaya devam edersem Hafıza modelleme konusuna geçiş yapmak zorunda kalacağım en iyisi burada kesmek. &lt;br /&gt;
&lt;br /&gt;
Şimdi stdcall'e geçelim. Bu komut compilere(compiler masm32 de ml.exe'dir) prosedür çağrılarının stack'e hangi sırayla atılacağını ve alınacağını belirtir. Üç çeşitli vardır : &lt;br /&gt;
&lt;br /&gt;
1-C 2-Pascal 3'te - Stdcall &lt;br /&gt;
&lt;br /&gt;
Biz hep StdCall'i kullanırız . Niyemi? &lt;br /&gt;
Ne demiştik her programlama dili eninde sonunda kodlarını assembly'de anlaşılacak bir hale getirecektir. Ama bu çevrim işleminde bazı yerler vardır ki o programlama dilini yazan firmanın tercihidir karışamayız. Mesela C çağrım şartı için:&lt;br /&gt;
&lt;br /&gt;
goster(int par1,int par2, int par3) gibi bir prosedür çağrısında işlemci bunu&lt;br /&gt;
&lt;br /&gt;
push [par3]&lt;br /&gt;
push [par2]&lt;br /&gt;
push [par1]&lt;br /&gt;
call goster&lt;br /&gt;
add sp,12&lt;br /&gt;
&lt;br /&gt;
şeklinde işleyecektir.&lt;br /&gt;
&lt;br /&gt;
Yukarıdaki kod stacke par3'ten başlayarak değerleri koyar ve goster prosedürünün altındaki komutları icra edip kaldığı yere geri döner ve add sp,12 ise stack'i eski haline geri döndürür. Yani stacki eski haline döndürme işlemi prosedürün işi bittikten sonra yapılır .Ama Pascal çağrım şartında bu tam tersidir. Şöyleki:&lt;br /&gt;
&lt;br /&gt;
topla:= par1+par2+par3 için bu asm'de&lt;br /&gt;
push par1&lt;br /&gt;
push par2&lt;br /&gt;
push par3&lt;br /&gt;
call **pla&lt;br /&gt;
&lt;br /&gt;
dır.&lt;br /&gt;
&lt;br /&gt;
Add sp,12'nerde? Tabiiki **pla prosedürünün içerisinde . Yani stacki derleyip toparlama işi çağrım yapılan fonksiyonun görevidir. &lt;br /&gt;
&lt;br /&gt;
Son olarak STDCALL ise bunların ikisinin karışımıdır. Yine örnekle açıklarsak&lt;br /&gt;
&lt;br /&gt;
**pla(int par1,int par2,int par3) prosedürü asm'de&lt;br /&gt;
&lt;br /&gt;
push [par3]&lt;br /&gt;
push [par2]&lt;br /&gt;
push [par1]&lt;br /&gt;
call **pla&lt;br /&gt;
&lt;br /&gt;
dır.&lt;br /&gt;
&lt;br /&gt;
C çağrım şartı, fonksiyon veya prosedürle verilen operatörlerin en sağından başlayarak stacke koyma işlemini yapar ve fonksiyondan sonra stacki düzenler.Ama Pascal bunun tam tersini yapar ve stacke koyma işlemini soldan sağa yapar ve stacki fonksiyonun içinden çıkmadan düzenler.Stdcall ise C gibi stacke alma işlemini sağdan başlar ama pascal gibide fonksiyon içerisinde stacki düzenler. &lt;br /&gt;
&lt;br /&gt;
Bu anlatılanları bir debuger'la sınarsanız mantığı daha iyi kavrayacağınıza eminim.&lt;br /&gt;
&lt;br /&gt;
Evet bu kısmıda anladıysak devam ediyoruz..&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
option casemap:none&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Bu yönerge programcının isteğine bağlıdır. Şöyleki Bununla compilere dersinizki: "Yazdığım tüm komutlar ve ne kadar şey varsa bunları küçük büyük harf ayrımına tutma. Ben acaip bi insanımdır bazen "push" yazarım bazende "PuSh" sen benim keyfime karışma" der. Bunuda anladıysak kaynak kodumuzdan bir satır daha aşağıya iniyoruz.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
include \masm32\include\windows.inc&lt;br /&gt;
include \masm32\include\kernel32.inc&lt;br /&gt;
include \masm32\include\user32.inc&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
Yukarıdaki komutlar compilere (derleyiciye) bizim hangi yardımcı komutlarla çalışacağımızı söyler. Bu .inc dosyalarının içerisinde bazen komut makroları bazende işletim sistemi fonksiyonlarının komutun kaç paramtre ve hangi tipte boyda veri alacağını belirten tanımlamalar yer alır. İlgili dizindeki dosyaları açarak ne demek istediğimi daha iyi anlayacağınıza inanıyorum.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
includelib \masm32\lib\user32.lib&lt;br /&gt;
includelib \masm32\lib\kernel32.lib&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
includelib komutuda compilere çalıştığımız yardımcı komut kütüphanelerinin hafızadan veya dosyadan çağrılacak offset tanımlamalarını belirtir.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.DATA&lt;br /&gt;
.DATA?&lt;br /&gt;
.CONST&lt;br /&gt;
.CODE&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
Evet EXE'ler nasıl çalışır adlı dokümanımı okumayanlar için bir daha tekrarlayayım . Her çalıştırılabilir dosya ki buna .dll'lerde dahildir, içlerinde programcı tarafından önceden tanımlanmış bilgiler ".data" veya kullanıcıdan veyahut etkileşimli bir komuttan alacağı verileri muhafaza için ".data?" ve program içinden dahi değiştirilemeyecek readonly, gerekli ön tanımlama bilgileri ".const" ve tüm yazılımsal kodları içeren ".code" gibi alanlara sahiptir. &lt;br /&gt;
&lt;br /&gt;
Özetle&lt;br /&gt;
&lt;br /&gt;
.DATA Kullanıcıya iletilecek önceden tanımlanmış veriler veya program içerisinde kullanılacak bazı ön tanımlı değerleri tutar. Buna örnek olarak kaynak kodumuzda belirttiğimiz&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.data&lt;br /&gt;
Baslik      db "Ben bir başlığım",0&lt;br /&gt;
Mesaj      db "Selamün Aleyküm Dünya!",0&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
gibi bir tanımlama verilebilir. &lt;br /&gt;
&lt;br /&gt;
.DATA? ise hafızada yeri ve mekanı belli ama içerisinde hiç bir bilgi olmayan , dışarıdan gelecek her veriye "gel ne olursan ol yine gel" diyen bir alandır Örneğin&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.data?&lt;br /&gt;
buffer db 512 dup(?)&lt;br /&gt;
&lt;br /&gt;
.code&lt;br /&gt;
mov dword ptr[buffer],'X'&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Yukarıdaki gibi bir kodda programı ilk çalıştırdığınızda buffer alanı hafızada ayrılmış ancak hiç bir bilgi içermeyecektir. Ta ki yukarıdaki "'mov"' komutu icra edilene kadar.&lt;br /&gt;
&lt;br /&gt;
.CONST Komutu ise program icra edilirken, ne kendi içerisinde ki bir müdahaleyle ne de dışarıdan alınacak bir girişimle değiştirilemez verileri tanımlar. Mesela bir web server yazdık bunun portunun değiştirilmez bir şekilde 80 olmasını istedik. Bunu :&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.CONST&lt;br /&gt;
webport equ 080h&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
diyerek yapabiliriz.&lt;br /&gt;
&lt;br /&gt;
Her programlama dilinde olduğu gibi assembly'de de data tanımlama belirteçleri vardır. Bunlar:&lt;br /&gt;
&lt;br /&gt;
db = Define Byte (8Bit)&lt;br /&gt;
dw = Define Word (16Bit)&lt;br /&gt;
dd = Define Dword(32Bit)&lt;br /&gt;
..&lt;br /&gt;
dup(?) = Define memory up (miktar)&lt;br /&gt;
&lt;br /&gt;
Yukarıdaki tanımlamalar hafızada belirtilen değerlerde veri girişi sağlar. &lt;br /&gt;
&lt;br /&gt;
Elinize bir kalem kağıt alın yada paint'i açın. Büyük bi dikdörtgen çizin . Bu çizdiğiniz şey sizin programınızın kullanacağı hafıza alanı . Evet windows sizin programınızı böyle bir şey gibi görür. Sizin yapmanız gereken az önce bazılarını yukarıda da anlattığım .data .data? .const .code gibi sınır çizgileri ile bunları bölmek. Yani programınız hafızada artık en basitinden ".data .code ve .stack" gibi görünecektir. &lt;br /&gt;
&lt;br /&gt;
Evet artık size düşen bu alanlarla oynamak. Yukarıdaki kodumuzu inceleyin o hem .data section için hafızada ayrılan boşluğa veri yazar, hemde .code içinde belirtilen kodlar için hafızada kod bloğu oluşturur. Bu data yazma işlemini örneğin&lt;br /&gt;
&lt;br /&gt;
mesaj db "Selam millet",0 &lt;br /&gt;
veya&lt;br /&gt;
sayi dd 0125468984h &lt;br /&gt;
veya&lt;br /&gt;
handle dw 015fah&lt;br /&gt;
&lt;br /&gt;
gibi yazarız . Bunlar ne anlama gelir. &lt;br /&gt;
&lt;br /&gt;
Eğer hafızaya bir string girecekseniz bunu db ile yapmalısınız. Niyemi? hatırlayın her ascii harfinin tekinin boyutu nedir? 1Byte!. Öyle ise ben :&lt;br /&gt;
&lt;br /&gt;
mesaj db "Selam",0 &lt;br /&gt;
&lt;br /&gt;
dediğimde bu hafızaya byte byte yazılacaktır . Şöyleki:&lt;br /&gt;
Hafıza:&lt;br /&gt;
&lt;br /&gt;
00403000 53 65 6C 61 6D 00 00 00 00 00 00 00 00 00 00 00 Selam&lt;br /&gt;
&lt;br /&gt;
gibi olacaktır.&lt;br /&gt;
&lt;br /&gt;
Ama bunu gidip &lt;br /&gt;
mesaj dd "Selam" deseydim hafıza:&lt;br /&gt;
&lt;br /&gt;
00403000 53 00 00 00 65 00 00 00 6c 00 00 00 00 61 00 00 S...T...R &lt;br /&gt;
&lt;br /&gt;
gibi birşey olacaktı ve programınızın ekrana S yazıp bitecekti. Çünki windows stringler için 00'ı terminated data(sonlandırıcı) olarak tanır. &lt;br /&gt;
&lt;br /&gt;
Evet artık .code .stack. data .const compile, verilerin hafızada nasıl yerleştiği, çalışan processin bir debuggerda nasıl gözüktüğü,sectionlar anlamış olmalısınız ve evet artık sizinle güzel örneklere başlayabiliriz. &lt;br /&gt;
&lt;br /&gt;
Burada şöyle bir yöntem kullanacağım . Sizinle birlikte daha kolay anlayasınız diye masm32'nin içinde yer alan icztutes klasörünün içindeki Iczelion'un yazdığı örnekler üzerinde çalışacağız . &lt;br /&gt;
&lt;br /&gt;
Şimdi ilk önceliğimiz size göre tute02 almalıydı ama o zaten yukarıda verdiğim örneklerle birebir aynı ben onu geçip doğrudan TUTE03 klasöründe yer alan WIN.asm uygulamasının üzerinde çalışmayı yeğliyorum. &lt;br /&gt;
&lt;br /&gt;
Win.asm'nin içeriği aşağıdaki gibidir.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.386&lt;br /&gt;
.model flat,stdcall&lt;br /&gt;
option casemap:none&lt;br /&gt;
include \masm32\include\windows.inc&lt;br /&gt;
include \masm32\include\user32.inc&lt;br /&gt;
include \masm32\include\kernel32.inc&lt;br /&gt;
includelib \masm32\lib\user32.lib&lt;br /&gt;
includelib \masm32\lib\kernel32.lib&lt;br /&gt;
&lt;br /&gt;
WinMain proto :DWORD,:DWORD,:DWORD,:DWORD&lt;br /&gt;
&lt;br /&gt;
.data&lt;br /&gt;
ClassName db "SimpleWinClass",0&lt;br /&gt;
AppName  db "Our First Window",0&lt;br /&gt;
&lt;br /&gt;
.data?&lt;br /&gt;
hInstance HINSTANCE ?&lt;br /&gt;
CommandLine LPSTR ?&lt;br /&gt;
.code&lt;br /&gt;
start:&lt;br /&gt;
invoke GetModuleHandle, NULL&lt;br /&gt;
mov    hInstance,eax&lt;br /&gt;
invoke GetCommandLine&lt;br /&gt;
mov    CommandLine,eax&lt;br /&gt;
invoke WinMain, hInstance,NULL,CommandLine, SW_SHOWDEFAULT&lt;br /&gt;
invoke ExitProcess,eax&lt;br /&gt;
&lt;br /&gt;
WinMain proc hInst:HINSTANCE,hPrevInst:HINSTANCE,CmdLine:LPSTR,CmdShow:DWORD&lt;br /&gt;
LOCAL wc:WNDCLASSEX&lt;br /&gt;
LOCAL msg:MSG&lt;br /&gt;
LOCAL hwnd:HWND&lt;br /&gt;
mov   wc.cbSize,SIZEOF WNDCLASSEX&lt;br /&gt;
mov   wc.style, CS_HREDRAW or CS_VREDRAW&lt;br /&gt;
mov   wc.lpfnWndProc, OFFSET WndProc&lt;br /&gt;
mov   wc.cbClsExtra,NULL&lt;br /&gt;
mov   wc.cbWndExtra,NULL&lt;br /&gt;
push  hInstance&lt;br /&gt;
pop   wc.hInstance&lt;br /&gt;
mov   wc.hbrBackground,COLOR_WINDOW+1&lt;br /&gt;
mov   wc.lpszMenuName,NULL&lt;br /&gt;
mov   wc.lpszClassName,OFFSET ClassName&lt;br /&gt;
invoke LoadIcon,NULL,IDI_APPLICATION&lt;br /&gt;
mov   wc.hIcon,eax&lt;br /&gt;
mov   wc.hIconSm,eax&lt;br /&gt;
invoke LoadCursor,NULL,IDC_ARROW&lt;br /&gt;
mov   wc.hCursor,eax&lt;br /&gt;
invoke RegisterClassEx, addr wc&lt;br /&gt;
INVOKE CreateWindowEx,NULL,ADDR ClassName,ADDR AppName,\&lt;br /&gt;
WS_OVERLAPPEDWINDOW,CW_USEDEFAULT,\&lt;br /&gt;
CW_USEDEFAULT,CW_USEDEFAULT,CW_USEDEFAULT,NULL,NULL,\&lt;br /&gt;
hInst,NULL&lt;br /&gt;
mov   hwnd,eax&lt;br /&gt;
invoke ShowWindow, hwnd,SW_SHOWNORMAL&lt;br /&gt;
invoke UpdateWindow, hwnd&lt;br /&gt;
.WHILE TRUE&lt;br /&gt;
invoke GetMessage, ADDR msg,NULL,0,0&lt;br /&gt;
.BREAK .IF (!eax)&lt;br /&gt;
invoke TranslateMessage, ADDR msg&lt;br /&gt;
invoke DispatchMessage, ADDR msg&lt;br /&gt;
.ENDW&lt;br /&gt;
mov     eax,msg.wParam&lt;br /&gt;
ret&lt;br /&gt;
WinMain endp&lt;br /&gt;
&lt;br /&gt;
WndProc proc hWnd:HWND, uMsg:UINT, wParam:WPARAM, lParam:LPARAM&lt;br /&gt;
.IF uMsg==WM_DESTROY&lt;br /&gt;
invoke PostQuitMessage,NULL&lt;br /&gt;
.ELSE&lt;br /&gt;
invoke DefWindowProc,hWnd,uMsg,wParam,lParam  &lt;br /&gt;
ret&lt;br /&gt;
.ENDIF&lt;br /&gt;
xor eax,eax&lt;br /&gt;
ret&lt;br /&gt;
WndProc endp&lt;br /&gt;
end start&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
Program çok basit bir windows penceresidir. içinde hiç bir şey yoktur ve kapat komutundan başka hiç bir komuttan anlamaz. &lt;br /&gt;
&lt;br /&gt;
Windows'ta işler çoğunlukla pencerelerle yürür. Örneğin siz şu anda bu sayfayı Windows işletim sistemi yardımıyla görüntülüyorsanız bu Pencerelerin sayesinde oluyor. Yani şu anda bu okuduğunuz doküman bir pencerenin içinde yer alıyor ve bu pencere genel olarak "açma,kapama,ölçekleme,büyütme ve küçültme, üzerinde yapılan değişiklikleri algılama,fare hareketleri,klavye gönderimleri, başka pencerelerle veri akışı vs.. bir çok yapıyı idare eden bir yapıdadır. Penceremizi yöneten ve onunla çalışmamızı sağlayan GUI'dir, iş akışını idare eden ise Win32 Messaging sistemidir. Yani siz bu pencerenin üzerinde her mouse hareketi yaptığınızda win32 subsystem bu pencereyi kontrol eder ve mouse koordinatlarını yine bu pencereye mesaj olarak iletir ve eğer bu pencereyi yazan programcı bu hareketler için özel tepkiler programladıysa onları pencerenin icra etmesini sağlar. Yukarıdaki örnekteki kodda penceremiz sadece gelen kapat bildirimini almakta ve pencereyi yok etmektedir. Bundan başka gelen her komutu ise DefWindowProc prosedürüne ileterek isteğin Win32 tarafından denetlenmesini ister. GUI kütüphanesi ile pencerelerinizin tasarımını yönetirsiniz. İkonu, şekli, üzerinde yer alacak butonlar,resimler vs.. sizin için hazır olarak bulunan Api'ler ile bunları rahatlıkla yapmanız için GUI tarafından desteklenir.&lt;br /&gt;
&lt;br /&gt;
Her pencere standart olarak bir çerçeveye o çerçeve üzerinde bir başlık çubuğuna, başlık çubuğu üzerinde opsiyonel olarak kapatma,ölçekleme ve simge durumuna alma tuşlarına sahiptir. Bu Windows'un pencere standartıdır. Ama biz gerçekte daha zengin pencerelerle karşılaşabiliyoruz. İşte buda pencerelerin opsiyonelleştirilebilmesi gerçeğini ortaya koyuyor. Evet pencereler aslında her özellikleri ile değiştirilebilecek nesnelerdir. &lt;br /&gt;
&lt;br /&gt;
Windows'da pencere oluşturmak istersek yapmamız gereken bazı zorunlu haller vardır onlar her pencere için bir ana prosedür olan WinMain proceduru ve o pencereye gelecek mesajları irdeleyecek WndProc prosedürü. Bu ikili bir pencerede birlikte olmak zorundadırlar. Biri ki bu WinMain oluyor Pencere ve özelliklerini ayarlayıp pencereyi kullanıcıya sunar ve gelen her isteği dinler, diğer yani Wndproc ise bu gelen mesajlara göre programcının tepkisini yansıtır. Aslında pencere konusunu biraz daha açarsak, bir pencere oluşumu için gerekenler şunlardır.&lt;br /&gt;
&lt;br /&gt;
1. Win32'nin programımıza bağlı pencere ile iletişime geçebilmesi için bir instance handle alınır. Bu handle vasıtası ile penceremizin ana fonksiyonuna ulaşırız.&lt;br /&gt;
2. Penceremiz için bir class name ve de bir class yapısının içini oluşturmalıyız. Bu class, penceremizin temeli niteliğindedir. Penceremiz için gereken görsel ve yapısal ayarların geneli burada yapılmalıdır. Örneğin: Penceremize gelen mesajları hangi prosedürün inceleyeceği, mouse imlecinin şekli,arkaplan rengi gibi çoğunu örnek kodumuzda da göreceğiniz ayarları bu sınıfta tanımlarız. &lt;br /&gt;
3. Oluşturduğumuz Class'ı Register etmeliyiz. Bu RegisterClassEx api'si ile yapılır. Böylece penceremizi oluşturduğumuzda ne tür bir yapı ile çalışacağını windows'a belirtmiş olacağız.&lt;br /&gt;
4. Penceremizi oluştururuz. CreateWindowEx api'si ile bunu yapabiliriz. Bu komut ile birlikte artı penceremiz hafızada yapısal olarak son şeklini almıştır.&lt;br /&gt;
5. Pencere görünür hale getirilir. Hafızada yapısal olarak bitmiş penceremizi ShowWindow komutu ile artık kullanıcılara sunarız.&lt;br /&gt;
6. Bir defaya mahsus Windowsun penceremiz için Refreshing işlemi yapmasını sağlarız. Bu sayede penceremiz artık gerçekten desk**pumuzda aktif işlem olur.&lt;br /&gt;
7. Penceremiz için istekleri dinleriz. Evet artık penceremiz hazır ve aktif olduğuna göre penceremiz için kullanıcı bazlı veya diğer programlardan gelebilecek istekler için sonsuz bir dinleme haline girmeliyiz. Bunu GetMessage ve DispatchMessage api'leri vasıtası ile yaparız. GetMessage api'si penceremize uğrayan her mesajı Windows'un mesaj kuyruğundan alır ve DispatchMessage gönderir. DispatchMessage işe gelen isteği irdeler ve 2. adımda belirttiğimiz Pencere prosedürüne gönderir.&lt;br /&gt;
8. Ve penceremiz ile işimiz bittiğinde onu sonlandırırız. &lt;br /&gt;
&lt;br /&gt;
Şimdi kodu inceleyelim:&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.386&lt;br /&gt;
.model flat,stdcall&lt;br /&gt;
option casemap:none&lt;br /&gt;
include \masm32\include\windows.inc&lt;br /&gt;
include \masm32\include\user32.inc&lt;br /&gt;
include \masm32\include\kernel32.inc&lt;br /&gt;
includelib \masm32\lib\user32.lib&lt;br /&gt;
includelib \masm32\lib\kernel32.lib&lt;br /&gt;
&lt;br /&gt;
WinMain proto :DWORD,:DWORD,:DWORD,:DWORD&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
Buraları anlatmıştım o yüzden es geçiyorum.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.data&lt;br /&gt;
ClassName db "SimpleWinClass",0&lt;br /&gt;
AppName  db "Our First Window",0&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
ClassName pencereler için çok önemlidir. Çünkü her pencere Windows iyi bir kategorilendirme yapabilsin diye ve de mesajlaşma sistemi kullanılabilsin için bu class name ve application name ihtiyaç duymaktadır . Hani bilirsiniz kendi uygulamanızdan başka bir uygulamaya mesajlar gönderirsiniz FindWindow ile bu iş, işte böyle yürür.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.data?&lt;br /&gt;
hInstance HINSTANCE ?&lt;br /&gt;
CommandLine LPSTR ?&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
hInstance daha öncede bahsettiğim gibi Windows'un programımızın varlığını bilsin için ve kendi içinde haberleşmelerde kullanması hasebiyle kullanmak zorunda olduğumuz bir değer. Bu değer Win32 tarafından bize sağlanan 32 bitlik sayısal bir değerdir ve çoğunlukla win32 altında bu değer programımızın hafızadaki doğrusal adresidir. &lt;br /&gt;
&lt;br /&gt;
CommandLine ise tamamen programcının isteğine bağlı tek amacı programınıza dışarıdan gelen komut parametrelerini almak olan bir api'dir. Örneğin programınızın adının spy.exe olduğunu düşünürsek, kullanıcı bu programa doğrudan çalıştırma yoluna gitmeyip parametre ekleyerek(ör:spy.exe  minimize) çalıştırırsa siz bu ilave parametreyi CommandLine sayesinde programınızın içerisinde değerlendirip tepki verebilirsiniz. &lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.code&lt;br /&gt;
start:&lt;br /&gt;
invoke GetModuleHandle, NULL&lt;br /&gt;
mov    hInstance,eax&lt;br /&gt;
invoke GetCommandLine&lt;br /&gt;
mov    CommandLine,eax&lt;br /&gt;
invoke WinMain, hInstance,NULL,CommandLine, SW_SHOWDEFAULT&lt;br /&gt;
invoke ExitProcess,eax&lt;br /&gt;
.....&lt;br /&gt;
end start&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
Evet sonunda bizi gerçekten ilgilendiren yere yani kodumuza girmiş bulunuyoruz. Şu unutulmamalıdır ki masm32 ile programla yaparken icra edilecek kodlarımız .code section'da iki ana etiket arasında bulunmalıdır . Bu programımızın iskeleti niteliğindedir. Ön tanımlı olarak masm32'de bu etiketler start: end start olarak tanımlanmıştır ve bu isimleri rahatlıkla dilediğiniz gibi değiştirebilirsiniz. GetModuleHandle komutumuz yukarıda da belirttiğim gibi bizim için windowstan bir başlık alır. Bu komutun icrasından geri dönen değer "'eax"' yazmacında dır. &lt;br /&gt;
&lt;br /&gt;
Not: Windows kendi tanımlaması olarak fonksiyon dönüşlerini eax'ta alır .Bizde bu mimariye uymak zorundayız.&lt;br /&gt;
&lt;br /&gt;
Eax'te ki değeri "'mov"' komutu ile ileride kullanabilmek için hInstance değişkenimize alıyoruz. Ardından GetCommandLine ile programımıza dışarıdan gelen isteklerin bulunduğu hafıza alanına ait değeri yine "'eax"' vasıtası ile alıp CommanLine değişkenimize gönderiyoruz. Dilersek daha sonra bu alandaki verileri değerlendirip özel işlemler yapabiliriz ancak bu örneğimizde böyle bir şey yok. &lt;br /&gt;
&lt;br /&gt;
WinMain penceremizi oluşturmamız için giriş noktamızdır. WinMain ismi tamamen isteğe bağlıdır yine diğerlerinde olduğu gibi bunu da dilediğiniz gibi değiştirebilirsiniz. WinMain 4 parametre alır. Bunlar sırası ile &lt;br /&gt;
1. Win32'den aldığımız handle'mız, &lt;br /&gt;
2. Win16 günlerinden kalma ama artık kullanılmasının pek esprisi olmadığını düşündüğüm yedek handlemiz, &lt;br /&gt;
3. Komut satırı verilerini barındıran parametrelerimizin yerini gösteren pointerimiz.&lt;br /&gt;
4. Penceremizin başlangıçta hangi biçimde görüneceğini belirten CmdShow belirtecimiz. &lt;br /&gt;
&lt;br /&gt;
ExitProcess ile de programımızı güvenle terk ederiz. &lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
LOCAL wc:WNDCLASSEX&lt;br /&gt;
LOCAL msg:MSG&lt;br /&gt;
LOCAL hwnd:HWND&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
LOCAL komutu biz herhangi bir fonksiyonda yalnızca o fonksiyonun kullanması için değişkenler atadığımızda bizim için stackten hafıza ayırır. Bizi ilgilendiren yer ise penceremiz olduğundan daha öncede bahsettiğim pencere sınıfımız için yapılması gereken bazı tanımlamaların kullanması gereken bir yapının kurulması. Windows bu yapıyı WNDCLASSEX içinde görmek istediğinden onu ve ona point olan "'wc"' değişkenimizi yazdık. Ayrıca mesajlarımız için yine win32 ön tanımlı olarak MSG yapısı ve penceremizi için mesajlaşmalarda kullanacağımız 32 bitlik bir dword olan HWND'yi belirttik. Biz bunları local ile yaptığımızdan bu fonksiyonun dışında başka yerde kullanılmaları söz konusu değildir. &lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
mov   wc.cbSize,SIZEOF WNDCLASSEX&lt;br /&gt;
mov   wc.style, CS_HREDRAW or CS_VREDRAW&lt;br /&gt;
mov   wc.lpfnWndProc, OFFSET WndProc&lt;br /&gt;
mov   wc.cbClsExtra,NULL&lt;br /&gt;
mov   wc.cbWndExtra,NULL&lt;br /&gt;
push  hInstance&lt;br /&gt;
pop   wc.hInstance&lt;br /&gt;
mov   wc.hbrBackground,COLOR_WINDOW+1&lt;br /&gt;
mov   wc.lpszMenuName,NULL&lt;br /&gt;
mov   wc.lpszClassName,OFFSET ClassName&lt;br /&gt;
invoke LoadIcon,NULL,IDI_APPLICATION&lt;br /&gt;
mov   wc.hIcon,eax&lt;br /&gt;
mov   wc.hIconSm,eax&lt;br /&gt;
invoke LoadCursor,NULL,IDC_ARROW&lt;br /&gt;
mov   wc.hCursor,eax&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
Yukarıdaki komut kümesi tamamı ile sık sık kendinden bahsettiğimiz pencere sınıfımızın içeriğini doldurmak ile ilgilidir. WNDCLASSEX gibi bir yapıyı doldurmamızın amacı ileride aynı şablonda birden fazla pencere oluşturacağımız anlarda bunu bir çok hafıza alanı tüketmektense varolan bir hafıza alanında onu point ederek üretmek olacaktır. Ayrıca yine belirtmeliyim ki WNDCLASSEX yapısı gibi Windows'ta hazır olarak ön tanımlı bir çok pencere sınıfı vardır. Örneğin editbox, button bu gibi sınıflardır ve sadece CreateWindowEx api'si ile herhangi bir yapının içini doldurma gereği olmadan oluşturulabilirler. Şimdi herşeyin neden object olduğunu anlamışsınızdır umarım J . WNDCLASSEX yalın halde aşağıdaki gibi bir yapıdır.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
WNDCLASSEX STRUCT DWORD &lt;br /&gt;
cbSize            DWORD      ? &lt;br /&gt;
style             DWORD      ? &lt;br /&gt;
lpfnWndProc       DWORD      ? &lt;br /&gt;
cbClsExtra        DWORD      ? &lt;br /&gt;
cbWndExtra        DWORD      ? &lt;br /&gt;
hInstance         DWORD      ? &lt;br /&gt;
hIcon             DWORD      ? &lt;br /&gt;
hCursor           DWORD      ? &lt;br /&gt;
hbrBackground     DWORD      ? &lt;br /&gt;
lpszMenuName      DWORD      ? &lt;br /&gt;
lpszClassName     DWORD      ? &lt;br /&gt;
hIconSm           DWORD      ? &lt;br /&gt;
WNDCLASSEX ENDS &lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
mov wc.cbSize,SIZEOF WNDCLASSEX ile kullanacağımız yapının boyutunu alırız. Bu bound ayarı ve windows'a register ederken doğru tanımlama yaptığımızı garantilemek açısından önemlidir. &lt;br /&gt;
&lt;br /&gt;
mov wc.style, CS_HREDRAW or CS_VREDRAW, ise pencerelerimizin ölçeklendirme işlemlerinin her taraftan yapılabileceğini belirtir. Dilerseniz farklı bir çok seçenek daha eklenebilir. İlgili opsiyonlar Windows.inc dosyasında yer alırlar. &lt;br /&gt;
&lt;br /&gt;
mov wc.lpfnWndProc, OFFSET WndProc penceremize uğrayacak her türlü mesajın işlenmek için hangi prosedüre yollanacağını belirtir. &lt;br /&gt;
&lt;br /&gt;
mov wc.cbClsExtra,NULL işletim sistemi tarafından boş bırakılır . Extra sınıf tanımlamaları için sonradan kullanılması planlanan veriler buraya point edilir.&lt;br /&gt;
&lt;br /&gt;
mov wc.cbWndExtra,NULL. Eğer class tanımlaması ayrı bir dosyada (*.rc) yapılmış bir dialog kutusu sınıfı ile çalışacaksanız bu alanı doldurmak zorundasınızdır.Tabi bizim ilgi alanımız şimdilik yalın pencereler olduğundan boş bırakıyoruz. &lt;br /&gt;
&lt;br /&gt;
push hInstance&lt;br /&gt;
pop wc.hInstance ile programımıza ait handle'i pencere sınıfımıza atıyoruz.&lt;br /&gt;
&lt;br /&gt;
mov wc.hbrBackground,COLOR_WINDOW+1 penceremizin arka plan renk seçimini yapıyoruz. Daha fazla renk seçeneği için include dosyaları incelenebilir. &lt;br /&gt;
&lt;br /&gt;
mov wc.lpszMenuName,NULL Eğer pencerenizde tıpkı internet explorerda veya office programlarında olduğu gibi Dosya,Düzen,Görünüm,Yardım gibi ilave araçlar içeren bir menü çubuğu istiyorsanız ilgili yapının adresini de buraya belirtmelisiniz.&lt;br /&gt;
&lt;br /&gt;
mov wc.lpszClassName,OFFSET ClassName. Bu pencere sınıfımızı register edebilmek ve ileride program içinden veya dışından penceremizin görsel ayarları ile oynamak istediğimizde kolayca ulaşabilmemizi sağlayan bir belirteçtir. &lt;br /&gt;
&lt;br /&gt;
invoke LoadIcon,NULL,IDI_APPLICATION&lt;br /&gt;
mov wc.hIcon,eax&lt;br /&gt;
mov wc.hIconSm,eax ile penceremizin sol üst köşesinde veyahut ta minimize edilirken ki halinde gözükmesini istediğimiz icon'u belirtiriz. &lt;br /&gt;
&lt;br /&gt;
invoke LoadCursor,NULL,IDC_ARROW&lt;br /&gt;
mov wc.hCursor,eax burada da tıpkı LoadIcon api'sinde olduğu gibi pencere içinde mouse'mizin almasını istediğimiz şeklini çizdirebiliriz. &lt;br /&gt;
&lt;br /&gt;
invoke RegisterClassEx, addr wc ve artık istediğimiz ayarlamaları yaptıktan sonra bu komut ile penceremizi windows'a kayıt ettiriyoruz.&lt;br /&gt;
&lt;br /&gt;
INVOKE CreateWindowEx,NULL,ADDR ClassName,ADDR AppName,\&lt;br /&gt;
WS_OVERLAPPEDWINDOW,CW_USEDEFAULT,\&lt;br /&gt;
CW_USEDEFAULT,CW_USEDEFAULT,CW_USEDEFAULT,NULL,NULL,\&lt;br /&gt;
hInst,NULL&lt;br /&gt;
&lt;br /&gt;
ve artık penceremizi servise sunma zamanı geldi. CreateWindowEx fonksiyonu 12 parametre içerir . Genel yapısı şöyledir.&lt;br /&gt;
&lt;br /&gt;
CreateWindowExA proto dwExStyle:DWORD,\ &lt;br /&gt;
lpClassName:DWORD,\ &lt;br /&gt;
lpWindowName:DWORD,\ &lt;br /&gt;
dwStyle:DWORD,\ &lt;br /&gt;
X:DWORD,\ &lt;br /&gt;
Y:DWORD,\ &lt;br /&gt;
nWidth:DWORD,\ &lt;br /&gt;
nHeight:DWORD,\ &lt;br /&gt;
hWndParent:DWORD ,\ &lt;br /&gt;
hMenu:DWORD,\ &lt;br /&gt;
hInstance:DWORD,\ &lt;br /&gt;
lpParam:DWORD &lt;br /&gt;
&lt;br /&gt;
.dwExStyle: Bu parametreyi biz boş geçtik ama dilerseniz siz pencerenizin sürekli ekranın üstünde görünmesi gibi özel ayarlamalar yapabilirsiniz. &lt;br /&gt;
&lt;br /&gt;
.lpClassName: Bu mutlaka gerekli bir parametredir. Çünkü hangi pencere sınıfının gösterileceğini daha önceden kayıt ettirdiğiniz pencere sınıfı ismini alarak yapmaktadır.&lt;br /&gt;
&lt;br /&gt;
.lpWindowName: Pencerenizin başlık çubuğunda yazmasını istediğiniz string ifadeyi alır. Eğer NULL geçerseniz başlık çubuğunuzda hiçbir şey yazmaz.&lt;br /&gt;
&lt;br /&gt;
.dwStyle: Bu parametreyi doldurmazsak başlık çubuğunda ne kapama nede büyültme ve küçültme tuşları olmazdı. Biz ortak bir tanımlama olan WS_OVERLAPPEDWINDOW ile standart butonların olmasını istedik.&lt;br /&gt;
&lt;br /&gt;
X,Y: Pencerenin sol üst köşesin bulunacağı koordinatı verir. Biz default değeri vererek bu işi windowsun gönlüne bıraktık&lt;br /&gt;
&lt;br /&gt;
.nWidth,nHeight: Kısaca penceremizin eni ve boyu. Biz yine bu işi windowsa bıraktık.&lt;br /&gt;
&lt;br /&gt;
.hWndparent: Eğer aynı özelliklerde ana pencerenize bağlı başka bir alt pencere oluşturmak isterseniz bu değeri ilgili child pencerenin handle ile doldurmalısınız. Bu bir nevi MDI tarzı bir görüntü oluştursa da child pencere hiçbir zaman ana pencerenin boyut sınırları arasında değildir. Yani istediğiniz yere masa üstünde sürükleyebilirsiniz. Ancak bu şekilde üretilen child pencereler ana pencere kapandı anda otomatik olarak kapanacaktır.&lt;br /&gt;
&lt;br /&gt;
.hMenu: Eğer zaten WNDCLASSEX ile pencere sınıfınıza menü eklediyseniz bu parametreyi boş geçebilirsiniz. Menü kullanmak istemediğinizde de boş tur. Ancak menu kullandığınızı ve menu sisteminizi sayısal değerlere sahip id ler ile yönetmek istediğinizi varsayarsak o zaman bu parametre sizin için kullanışlı olabilir.&lt;br /&gt;
&lt;br /&gt;
.hInstance:Bu da yine kalıtımsal olarak hiyerarşik bir şekilde programımızın başında windowstan elde ettiğimiz handle'dir.&lt;br /&gt;
&lt;br /&gt;
.lParam: Kendi tasarladığınız veya ön tanımlı yapıların mesaj olarak pencerenize iletilmesinde kullanacağınız bir parametredir. Örneğin çok pencereli MDI formlarda CLIENTCREATESTRUCT yapısını pencerenize vererek daha sonra client lara GetWindowLong ve SetWindowLong api'leri vasıtası ile değişiklikler yapabilirsiniz.&lt;br /&gt;
&lt;br /&gt;
Evet ayrıntılı bir şekilde de CreateWindowEx api'mizi inceledikten sonra devam ediyoruz.&lt;br /&gt;
CreateWindowEx apiside çalıştıktan sonra yine "'eax"' içinde hafıza oluşmuş penceremizi gösteren pointer'i dönderiyor. Artık penceremizin hafıza belli bir imajı çıktı ve bizim onu görücüye çıkartmamızı bekliyor. Bunu yapmanın yolu ShowWindow api'si. ShowWindow api'si iki paramtre alır bunlardan ilki hafıza yer alan ve bize ait olan pencerenin handle'ı, diğer ise pencerenin kullanıcıya sunum şeklini belirten CmdShow parametresi.&lt;br /&gt;
&lt;br /&gt;
İnvoke ShowWindow,hwnd,CmdShow ; diyerek penceremizin kullanıcıya daha önceden WinMain içinde verdiğimiz CmdShow değişkeninde belirtilen niteliğe göre gösterilmesini sağlarız. &lt;br /&gt;
&lt;br /&gt;
Artık penceremiz gözüküyor ancak bu kaba bir tabirle kuru bir yaprak sayfası gibidir. Bu pencereyi kullanıcıdan mesaj alıp verebilmesi için bir kere tetiklememiz lazım ve bunu &lt;br /&gt;
&lt;br /&gt;
İnvoke UpdateWindow,hwnd; ile yapıyoruz. &lt;br /&gt;
&lt;br /&gt;
Artık program emir almaya hazır ancak bu gelecek olan istekleri ne ile **playacak ve ne ile işleyecek. İşte buraya sıradaki adamlarımız mesaj komutları devreye girer. Kısaca şöyledir.&lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.WHILE TRUE&lt;br /&gt;
invoke GetMessage,Addr msg,NULL,0,0&lt;br /&gt;
.BREAK .IF(!eax)&lt;br /&gt;
invoke TranslateMessage,addr msg&lt;br /&gt;
invoke DispatchMessage,addr msg&lt;br /&gt;
.ENDW&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
Gördüğünüz gibi bu işlemi sonsuz bir döngüde yapmak zorundayız aksi halde dakikada binlerce mesaj akan bu win32 sisteminden bize ait olan mesajları almamız olanaksız olurdu.GetMessage api'si penceremize ait bir mesaj gelene kadar bekler. Yani kod akışı orada durur. Ta ki dışarıdan bir müdahale gelsin ve gereken prosesler başlasın. &lt;br /&gt;
&lt;br /&gt;
İnvoke GetMessage,addr msg,NULL,0,0 Win32'nin mesaj kuyruğundan bir mesaj alır ve eğer mesaj bizim penceremize ait ise msg yapısının için doldurarak bir alt yordama havale eder. GetMessage geriye eğer WM_QUIT gibi bir çıkış mesajı alır ve False döndürürse bu döngüden çıkılması anlamına gelir. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
.invoke TranslateMessage api'si aslında kullanılması zorunlu olmayan bir api'dir. Tek amacı pencerenize klavyeden gelen klavye vuruşlarını ascii kod olarak doğrudan işlemesidir. Dilerseniz kullanmayabilirsiniz. &lt;br /&gt;
&lt;br /&gt;
İnvoke DispatchMessage ise mesajı alır ve Mesajları işlemekle yükümlü fonksiyona gönderir. Bizim örneğimizde bu WndProc'tur.&lt;br /&gt;
&lt;br /&gt;
mov eax,msg.wParam&lt;br /&gt;
ret&lt;br /&gt;
WinMain endp&lt;br /&gt;
&lt;br /&gt;
Mesaj döngüsünden çıkılıp program sonlandırılacağında msg yapısının wParam parametresinde çıkış kodu yer alır. Aslında windows bu değer bir daha kullanmaz ama oyunun kuralı gereği güvenli çıkış adına bunu şart koşmuştur. Keşke her işlerinde bu kadar sağlam olsalar J .&lt;br /&gt;
&lt;br /&gt;
WndProc proc hWnd:HWND, uMsg:UINT, wParam:WPARAM, lParam:LPARAM&lt;br /&gt;
&lt;br /&gt;
Bu bizim pencere işleyicimiz. Bu yapının anlaşılması çok önemlidir. Fonksiyonun aldığı parametreler şunlardır.&lt;br /&gt;
&lt;br /&gt;
HWND: Her fonksiyonda olduğu gibi buradada ilgili handle'mızı kullanıyoruz.&lt;br /&gt;
&lt;br /&gt;
.umsg:UINT: Gördüğünüz gibi bu msg yapısı gibi bir şey değil sadece bir sayısal ifade. Windows'ta binlere mesaj vardır ancak programlarımız sadece kendilerini alakadar eden mesajlarla ilgilenirler. Bu UINT değeri sayesinde sadece istediğimiz ilgili mesajın sayısal ifadesine denk gelen mesajla ilgilenebileceğiz anlamına gelir. Örnekleri ileride görecekseniz.&lt;br /&gt;
&lt;br /&gt;
WParam,LParam: Bazı mesajlarla birlikte bazı ilave bilgiler de gelir. Örneğin pencerenizde yer alan bir butona basıldığında bunun mouse ile mi yoksa klavye ile mi gelen bir mesaj olduğunu wParam ve lParam öğeleri ile birlikte gelen değerlerden anlarız. &lt;br /&gt;
&lt;br /&gt;
&lt;blockquote&gt;&lt;br /&gt;
.IF uMsg==WM_DESTROY&lt;br /&gt;
invoke PostQuitMessage,NULL&lt;br /&gt;
.ELSE&lt;br /&gt;
invoke DefWindowProc,hWnd,uMsg,wParam,lParam  &lt;br /&gt;
ret&lt;br /&gt;
.ENDIF&lt;br /&gt;
xor eax,eax&lt;br /&gt;
ret&lt;br /&gt;
WndProc endp&lt;br /&gt;
end start&lt;/blockquote&gt;&lt;br /&gt;
&lt;br /&gt;
Bu kısım en can alıcı noktayı içeriyor. Burayı iyi anlamınız şart. Ne demiştik! Her pencere devamlı mesajlarla meşgul olur. Bunu bir debugger'la daha iyi anlayabilirsiniz. Siz pencereleriniz üzerinde işlem yapıldığında gelen isteklere gerekli yanıtı verebilmek adına bir filitre belirlemelisiniz. Örneğin siz programınızı her ne kadar da sakin rahat rahat çalışıyo sansanız da, programınız kendisi ile alakalı veya alakasız binlerce mesaj bombardımanına tutulur. Üziernde fare ile gezerken,bir click atarken, bir yerde bir yere taşırken,klavye ile bazı tuşlara basarken, siz programınıza bu isteklere karşı cevap verecek bir modül yazmasanız dahi bu istekler ile programınız meşgul olur. Peki bu kadar mesaj nasıl oluyorda siz bir şey yapmadan işleniyor. Yani pencereyi sürüklüyorsunuz ve istediğiniz yere gidiyor ama bunu siz yazmamıştınız. İşte bunu DefWindowProc halleder. Bu api sizin programınızda belirttikleriniz dışında programınıza gelen mesajları windows'a yönlendirir ve onun muhatap olmasını sağlar sizde böylece sadece kendi belirlediğiniz mesajlar ile rahatça ilgilenebilirsiniz. Tıpkı .IF uMsg==WM_DESTROY da ki gibi. Biz bu komutla uMsg'ya gelen sayısal değeri WM_DESTROY mesajına denk düşen mesajları işleyeceğimizi belirttik ve eğer mesaj gelirse şu işlemi yap dedik. &lt;br /&gt;
&lt;br /&gt;
Evet bu yazınında sonuna geldik. Yazım hataları ve anlam karmaşası olan yerler için özür dilerim. Bir daha ki bölümlerimizde kaldığımız örneklerden devam etmeye çalışacağız inşAllah.&lt;br /&gt;
&lt;br /&gt;
....&lt;br /&gt;
&lt;br /&gt;
Not: Döküman biraz karışık ve birbirinden kopuk ilerliyor farkındayım. Ancak üzülerek söylemeliyim ki bu dökümanı bile iş aralarından fırsat bulup ilerletebiliyorum o yüzden inşAllah döküman bittiğinde baştan aşağı bir tarama yapıp gerekli düzenlemeyi yapıcam. kod: &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Evet uzun süredir dökümanı editliyemiyorum ve sizde haliyle yeni şeyler bekliyorsunuz. Bu kısa ara, benim içinde dökümanda takip etmem gereken yol hakkında inceden inceye düşünmeye itti, ve artık stilde bazı değişiklikler yapmak zorunda hissettim açıkcası kendimi. &lt;br /&gt;
&lt;br /&gt;
Yukarıdaki yazıyı okuyan arkadaşlar artık kısaca assembly ile bir mesaj kutusu nasıl çıkartılıyor biliyor. Bu aşamaya gelene kadar ise hafıza da veriler nasıl ve hangi tanımlayıcılar la tanımlanır, derlenmiş dosyanın hafızadaki şablonu nasıl bir hal alır, Stack nedir,section nedir,veriler hafızada nasıl dizilir,byte,word,dword tanımlamalar arasındaki fark ve bir çok kafa karıştıran konu artık bana göre kafanızdan silinmiş olmalı. Olmalı ki artık verilen örneklerden ve incelediğiniz kodlardan daha çok şey çıkarabileseniz.&lt;br /&gt;
&lt;br /&gt;
Şimdi benim bu yazıda anlatmak istediklerim ise yine konumuzla bağımlı ve öğrenme sürecinizi maximum seviyeye çıkarmaktır. Örneğin bu yazımızda sizlere Win32 programlama yaparken API'lerin ne olduğu,nasıl çalışıldığı Win32 için olan önemleri ve kategorizasyonları. Kaç çeşit oldukları,kaç şekilde ulaşılabildikleri, hafızada ki konumlarının değişkenlik haritasının tanımı gibi kafanızı darman durman edecek bilgileri anlatmaya çabılayacağım. Ve artık bunları siz iyi kavradıktan sonra hangi dil ile olursa olsun win32 programlam yapmanız çok daha basit olacaktır. Ama tabi ben isterimki programlama dili seçeneğiniz Masm32 olsun .&lt;br /&gt;
&lt;br /&gt;
API'ler&lt;br /&gt;
&lt;br /&gt;
Application Programming Interface(Uygulama Programlama Arayüzü) de derler bu arkadaşa. Ama ben de bir tanım eklersem "Programcıların başka programcılara kıyak olsun "zaten ben bi tane yazmışım gariplerim uğraşmasın" diye ve üstelik kendi programlarının veya yapılarınında bütünlük garantisi olsun diye geliştirip export ettikleri bir fonksiyonlar destesi" diyebiliriz. Şöyleki siz kullandığınız işletim sisteminde olmayan bir disk onarım programı yazdınız ama dedinizki "yaw ben bunun görselliğini iyi yapamadım hem bu fonksiyonları yazana kadar göbeğim çatladı bi de kullanılabilirliğilemi uğraşacaktım bi çok yeride eksik kaldı,banane canım: "ederim işlevsel fonksiyonları export uğraşsın başkası "" derseniz bu yaptığınız şeye api denir. millet sizin dll'yi çeker programına import eder ve o fonksiyonları kullanır ve sizinkinden daha janjanlı program yazar ise o vatandaş sizin api'lerle bu işi yaptı demektir.Ve üstelik bu sayede de hem sizin geliştirdiğiniz teknoloji dehası kodlarınız bütünlüğü ve yapısallığı ile korunmuş olacak hemde sizin şablonunuz üzerinden kim bilir daha ne proglar geliştirlecek.&lt;br /&gt;
&lt;br /&gt;
İşte Win32 Api'leride kendi yeteneklerini programcılara sunan geniş bir yelpazeyle yapar bu API işini. Aslında buna pek sunmak değilde dayatmak desek daha yerinde olur. Yani win32 açıkcası programcıların ince mevzularla kendi başlarına fazla haşır neşir olmasını istemez ve illa benim yeteneklerimi kullan der. Örneğin winnt serisinde seri porta dahi direk çıkış yapamazsınız illa bunu win32api leriyle yapıp bill gates'i rahatlatmanız lazım .&lt;br /&gt;
&lt;br /&gt;
API'ler yukarıda yapılarından da bahsettiğimiz gibi programcısının yazdığı ve export ettiği bir fonksyionlar yumağıdır ve bu api'ler executable dosyalar içerisinde hizmet etmek için depolanırlar. Kernel32.dll,ntdll.dll,gdi32.dll,user32.dll ve bazı *.exe'lerin içlerinde hayatlarını idame ettirirler. Windows amca bu api'leri bazı kategorilere ayırmıştır. örneğin&lt;br /&gt;
&lt;br /&gt;
Bir nesne veya dosya oluşturuken&lt;br /&gt;
Bir dosya ararken&lt;br /&gt;
Parametre yollar veya alırken&lt;br /&gt;
Sürücülerle çalışırken&lt;br /&gt;
Programlar arası veri transferi yaparken&lt;br /&gt;
Programdan girerken veya çıkarken&lt;br /&gt;
Hafıza ayırırken&lt;br /&gt;
Sistem mesajlarıyla boğuşurken&lt;br /&gt;
vb.. daha buna benzer veya daha farklı yaklaşık 949 ince tefferuatlı iş için KERNEL32.DLL&lt;br /&gt;
&lt;br /&gt;
String çevrim işleri yaparken&lt;br /&gt;
Kullanıcı etkileşimli dialoglar görüntülerken&lt;br /&gt;
Klavye düzeni ve mouse hareketleriyle haşır neşir olurken&lt;br /&gt;
Cut+copy+paste işlemlerini yönetirken&lt;br /&gt;
Ekrana kalıp şekiller çizerken&lt;br /&gt;
Mesajların istenilen yerlere yönlendirmesini sağlarken&lt;br /&gt;
Başka programlara erişirken&lt;br /&gt;
ekrana yazı yazdırıken &lt;br /&gt;
vb.. daha buna benzer veya daha farklı yaklaşık 732 ince tefferuatlı iş için USER32.DLL&lt;br /&gt;
&lt;br /&gt;
Fontlarla çalışırken&lt;br /&gt;
Ekrana cicili bicili şeyler çıkartırken&lt;br /&gt;
grafiklerle boğşurken&lt;br /&gt;
vb.. daha buna benzer veya daha farklı yaklaşık 609 ince tefferuatlı iş için GDI32.DLL&lt;br /&gt;
&lt;br /&gt;
gösterilebilir.&lt;br /&gt;
&lt;br /&gt;
Yukarıdakine benzer neredeyse x:\windows klasörünüz altında ki executable sayısına eşit oranda api'ler mevcuttur, ve bunları kullanmak ve keşfetmek sizin programcılık ve ihtiyaç merakınıza doğru orantılıdır.&lt;br /&gt;
&lt;br /&gt;
Benim gibi işi sadece şifre kırmak,exploit yazmak,hinliklerle uğraşmak gibi tembel işleriyle uğraşanlar için yukarıdaki api'ler yeterde artar bile. Ama unutulmamalıdırki iyi bir win32 programcısı api'leri kullandığı programlama dilinin komutları kadar iyi bilmeli ve kullanabilmelidir. Ancak o zaman ortaya yetenkli ve işlevsel bir program çıkar. &lt;br /&gt;
&lt;br /&gt;
Evet kaldığımız yerden devam edersek. Programcılar WinApi'leri ile çalışmadan önce kullandıkları programlam diline hangi api'ler ile çalışacaklar ise bunu compilerlerine belirtmek zorundadırlar. Tabi bazı programlama dilleri bunu otomatik yapmıyor değil ama şunu unutmayınki ne kadar hazır o kadar çok filesize demektir. Sadece size yarayan api'leri import etmeniz hem kodunuzun boyutunu korur hemde hızını. &lt;br /&gt;
&lt;br /&gt;
devam edecek... yoruldum :) &lt;br /&gt;
&lt;br /&gt;
&lt;span style="font-style: italic;"&gt;5 sene sonra gelen edit: yalana bak devam edecek demişim 5 sene geçmiş hala devam edicek :p&lt;/span&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-4973359813647551121?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2011-07-05T21:32:54.298+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">1</thr:total></item><item><title>Passworks for Enterprise Domain (Active Directory)</title><link>http://kernelturk.blogspot.com/2009/10/passworks-for-enterprise-domain-active.html</link><category>domain</category><category>active directory</category><category>c#</category><category>.net 3.5</category><category>passworks</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Thu, 22 Oct 2009 06:48:53 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-575324862505401447</guid><description>Büyük ölçekli domain yönetmiş arkadaşlar bilirler, piyasada bilinen mevcut domain member olan computer'lara local admin parolası çakmak için en sık kullanılan yöntem group policyler vasıtası ile bilgisayar ilkesi üzerine basılan script vasıtası ile yapılır. Bir başka yöntem ve biraz daha güvenli olanıda aslında Wmi'lar vasıtası ile yapılanı'dır, ancak onuda aşmanın yolları fazlaca mevcut. &lt;br /&gt;&lt;br /&gt;En sık kullanılan ve kolay olan yöntemin scriptler vasıtası ile yapıldığından bahsettik peki ama neden bu bir açık teşkil ediyordu ki? Domain Admin'i olan arkadaşımız Active Directory Users and Computers altından ilgili pc'lerin toplandığı OU üzerinde group policy atarken aşağıdakine benzer bir kodu kullanır:&lt;br /&gt;&lt;br /&gt;&lt;blockquote&gt;&lt;br /&gt;strPassword = "p455w0rd" 'uygulanacak şifre&lt;br /&gt;set objUser = getobject("WinNT://./Administrator,user") 'hangi user?&lt;br /&gt;objUser.SetPassword strPassword 'şifreyi ata&lt;br /&gt;objUser.SetInfo ' Değişiklikleri kaydet&lt;br /&gt;&lt;/blockquote&gt;&lt;br /&gt;&lt;br /&gt;Artık domaine üye olan her pc açıldığında ilk olarak bu scripti uygular ve böylece local admin şifresi değişmiş olur. Böylece sistem üzerinde yer alan tek tam denetimli kullanıcı güvene alınmış olunur!!!mu acaba?&lt;br /&gt;&lt;br /&gt;Bu tip bir password distributed mekanizması uygulanan domaine üye bilgisayar açıldığında ilk olarak üyesi bulunduğu domain server rolünü üstlenmiş pc de bulunan sysvol klasörü üzerinde yer alan computer policylerini barındıran oid klasörüne bağlanır ve adminin aslında group policy editoru vasıtası ile gösterdiği script var ise bunu local yönetici hesap hakları ile çalıştırır ve uygular sonrasında ise tipik gpo ayarları alınır ve oturum açan kullanıcı üzerindeki hakların alınması ile süreç devam eder. İşte bu aşamada burada kritik rol üstlenen sysvol klasörünün public erişime mecburi olarak readonly de olsa açık olması bir zaafiyeti ortaya çıkarıyor. Bu scriptin burada yer aldığını bilen kullanıcı en kısıtlı kullanıcı hakları ile bile çalışsa bu dizine erişerek passwordu ele geçirebiliyor. &lt;br /&gt;&lt;br /&gt;Olayın birde ERD Commander tarzı bootable programlar vasıtası ile yapılan local admin parolası sıfırlama kısmı var ki bunun önüne geçmek neredeyse imkansız ancak monitoring uygulamaları ile hemen bu tip bir değişiklik algılanıp denetleyici server'a bildirimi yapılarak suçu işleyen kişinin yakayı ele verdirmesini sağlayabilirsiniz. &lt;br /&gt;&lt;br /&gt;Bu aşamada nacizane bende üstüme düşen görevi yapmak için basit bir tool hazırladım. Gelişim aşaması içerisinde Dameware tarzı bir ürün ortaya çıkarmak istiyorum ama bakalım süreç neyi gösterecek. Reklam kuşağını hızlıca geçip kısa bir tanıtımının ardından programımın buglar ve hatalarla dolu ama işinizi görecek sürümünü buradan sunuyorum.&lt;br /&gt;&lt;br /&gt; Tüm os'ler ile rahatça çalışabilmesi için en son .net framework olan 3.5 derledim. Bu yüzden çalıştırmadan önce .net framework 3.5'i kurmanızı tavsiye ederin. Kabaca program'ın özellikleri şunlar:&lt;br /&gt;&lt;br /&gt;- Bağlantı protokolleri olarak tüm Ldap servislerini çalıştıran server'lardan computer ve user bilgilerini alıp üzerinde işlem yapabiliyor&lt;br /&gt;&lt;br /&gt;- Ldap connection için şu an her ne kadar programa Ldap 2 seçeneğini eklesem de sadece Ldap 3 protokolü ile bağlanıyor.&lt;br /&gt;&lt;br /&gt;- Yine bağlantı metodları olarak Negotiate, SimpleAuthenticate ve SSL destekli olarak domain server'ina bağlanabiliyor.&lt;br /&gt;&lt;br /&gt;- Şimdilik amaca uygun olarak sadece Computer ve User nesnelerini ekledim ancak tüm active directory destekli işleri yapmaya müsait bir taban üzerine inşaa etmeye çalışıyorum&lt;br /&gt;&lt;br /&gt;- Tüm domainde ki açık olan pc'lere sıralı olarak istenilen local admin parolasını çakıyor ve raporluyor.&lt;br /&gt;&lt;br /&gt;-  İstenilen pc'de istenilen local user için parola doğrulama testi yapılabiliyor&lt;br /&gt;&lt;br /&gt;- User'lar da parola sıfırlama işlemi yapılabiliyor &lt;br /&gt;&lt;br /&gt;- Seçilen pc'ye varsayılan remote monitor tool ile erişim imkanı.. &lt;br /&gt;&lt;br /&gt;Programla alakalı olumlu/olumsuz görüşlerinizi ve esprilerinizi :p bekler iyi çalışmalar dilerim.&lt;br /&gt;&lt;br /&gt; Download link: &lt;a href="http://rapidshare.de/files/48548663/Passworks_PublishBeta.rar.html"&gt;Passworks Download&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-575324862505401447?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2009-10-22T16:48:53.949+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total><enclosure url="http://rapidshare.de/files/48548663/Passworks_PublishBeta.rar.html" length="950627" type="application/octet-stream" /><media:content url="http://rapidshare.de/files/48548663/Passworks_PublishBeta.rar.html" fileSize="950627" type="application/octet-stream" /><itunes:explicit>no</itunes:explicit><itunes:subtitle>Büyük ölçekli domain yönetmiş arkadaşlar bilirler, piyasada bilinen mevcut domain member olan computer'lara local admin parolası çakmak için en sık kullanılan yöntem group policyler vasıtası ile bilgisayar ilkesi üzerine basılan script vasıtası ile yapılı</itunes:subtitle><itunes:author>noreply@blogger.com (Ibrahim Akgul)</itunes:author><itunes:summary>Büyük ölçekli domain yönetmiş arkadaşlar bilirler, piyasada bilinen mevcut domain member olan computer'lara local admin parolası çakmak için en sık kullanılan yöntem group policyler vasıtası ile bilgisayar ilkesi üzerine basılan script vasıtası ile yapılır. Bir başka yöntem ve biraz daha güvenli olanıda aslında Wmi'lar vasıtası ile yapılanı'dır, ancak onuda aşmanın yolları fazlaca mevcut. En sık kullanılan ve kolay olan yöntemin scriptler vasıtası ile yapıldığından bahsettik peki ama neden bu bir açık teşkil ediyordu ki? Domain Admin'i olan arkadaşımız Active Directory Users and Computers altından ilgili pc'lerin toplandığı OU üzerinde group policy atarken aşağıdakine benzer bir kodu kullanır: strPassword = "p455w0rd" 'uygulanacak şifre set objUser = getobject("WinNT://./Administrator,user") 'hangi user? objUser.SetPassword strPassword 'şifreyi ata objUser.SetInfo ' Değişiklikleri kaydet Artık domaine üye olan her pc açıldığında ilk olarak bu scripti uygular ve böylece local admin şifresi değişmiş olur. Böylece sistem üzerinde yer alan tek tam denetimli kullanıcı güvene alınmış olunur!!!mu acaba? Bu tip bir password distributed mekanizması uygulanan domaine üye bilgisayar açıldığında ilk olarak üyesi bulunduğu domain server rolünü üstlenmiş pc de bulunan sysvol klasörü üzerinde yer alan computer policylerini barındıran oid klasörüne bağlanır ve adminin aslında group policy editoru vasıtası ile gösterdiği script var ise bunu local yönetici hesap hakları ile çalıştırır ve uygular sonrasında ise tipik gpo ayarları alınır ve oturum açan kullanıcı üzerindeki hakların alınması ile süreç devam eder. İşte bu aşamada burada kritik rol üstlenen sysvol klasörünün public erişime mecburi olarak readonly de olsa açık olması bir zaafiyeti ortaya çıkarıyor. Bu scriptin burada yer aldığını bilen kullanıcı en kısıtlı kullanıcı hakları ile bile çalışsa bu dizine erişerek passwordu ele geçirebiliyor. Olayın birde ERD Commander tarzı bootable programlar vasıtası ile yapılan local admin parolası sıfırlama kısmı var ki bunun önüne geçmek neredeyse imkansız ancak monitoring uygulamaları ile hemen bu tip bir değişiklik algılanıp denetleyici server'a bildirimi yapılarak suçu işleyen kişinin yakayı ele verdirmesini sağlayabilirsiniz. Bu aşamada nacizane bende üstüme düşen görevi yapmak için basit bir tool hazırladım. Gelişim aşaması içerisinde Dameware tarzı bir ürün ortaya çıkarmak istiyorum ama bakalım süreç neyi gösterecek. Reklam kuşağını hızlıca geçip kısa bir tanıtımının ardından programımın buglar ve hatalarla dolu ama işinizi görecek sürümünü buradan sunuyorum. Tüm os'ler ile rahatça çalışabilmesi için en son .net framework olan 3.5 derledim. Bu yüzden çalıştırmadan önce .net framework 3.5'i kurmanızı tavsiye ederin. Kabaca program'ın özellikleri şunlar: - Bağlantı protokolleri olarak tüm Ldap servislerini çalıştıran server'lardan computer ve user bilgilerini alıp üzerinde işlem yapabiliyor - Ldap connection için şu an her ne kadar programa Ldap 2 seçeneğini eklesem de sadece Ldap 3 protokolü ile bağlanıyor. - Yine bağlantı metodları olarak Negotiate, SimpleAuthenticate ve SSL destekli olarak domain server'ina bağlanabiliyor. - Şimdilik amaca uygun olarak sadece Computer ve User nesnelerini ekledim ancak tüm active directory destekli işleri yapmaya müsait bir taban üzerine inşaa etmeye çalışıyorum - Tüm domainde ki açık olan pc'lere sıralı olarak istenilen local admin parolasını çakıyor ve raporluyor. - İstenilen pc'de istenilen local user için parola doğrulama testi yapılabiliyor - User'lar da parola sıfırlama işlemi yapılabiliyor - Seçilen pc'ye varsayılan remote monitor tool ile erişim imkanı.. Programla alakalı olumlu/olumsuz görüşlerinizi ve esprilerinizi :p bekler iyi çalışmalar dilerim. Download link: Passworks Download</itunes:summary><itunes:keywords>domain, active directory, c#, .net 3.5, passworks</itunes:keywords></item><item><title>Yeniden Uyanış</title><link>http://kernelturk.blogspot.com/2009/10/yeniden-uyans.html</link><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Tue, 20 Oct 2009 01:16:07 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-6497077964363523846</guid><description>8 sene önce aktif olarak başladığım Sistem programcılığı sürecinde ne yazık ki hep tek başıma kaldım. Bu doğrultuda başlattığım onlarca proje ya daha doğduğunda ya da bitişine çok az kala, tek kişi olmanın verdiği motivasyonsuzluk ve ekip ruhunun vermesi gerektiği sinerjinin yokluğu yüzünden ölü projeler sayfalarına girdi. Ancak sanırım artık şu sıralar bu durum değişecek gibi. 2 hafta önce tanıştığım &lt;a href="http://zararliyazilim.wordpress.com/"&gt;Emre Tınaztepe&lt;/a&gt; ve bugün bloguna denk geldiğim &lt;a href="http://kutalmis.wordpress.com/"&gt;Kutalmis&lt;/a&gt; arkadaşlarım ülkemizdeki bu hiç doğma şansı bile yakalamamış Sistem Programcılığı konusunda hala umudum olması gerektiğini hatırlattı. Kendilerine blogum vasıtası ile çalışmalarında başarılar der, fırsatı doğduğunda birlikte güzel projeleri hayata geçirebilecek ortamlarda bulunmayı dilerim.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-6497077964363523846?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2009-10-20T11:16:07.550+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">3</thr:total></item><item><title>Hepinizi Koruycam! Ama Kendimi Nasıl Koruycam?</title><link>http://kernelturk.blogspot.com/2009/10/hepinizi-koruycam-ama-kendimi-nasl.html</link><category>zemana antilogger</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Sat, 15 Oct 2011 14:28:54 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-7212224325778712844</guid><description>&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
Bir yazılım düşünün! Hedef kitlesi antivirüsler'in dahi baş edemediği zararlıları yakalamak ve engellemek. İşinde de gayet iyi gidiyor ki zaman geçtikçe müşteri yelpazesi genişliyor. Update update üstüne sürekli yeni güncellemeler ve ek özelliklerle kullanıcılarını hoşnut etmesinide biliyor. Bir gün biri çıkıp sistemleri dolayısı ile de kullanıcıları koruması gereken bu sistemin, kendini koruyamadığını ve uzman c coder'larının daha bir window'u handle edememelerinden dolayı, korumakla yükümlü oldukları tüm sistemin korumasız kaldığını buluyor. Hikayede burada başlıyor!&lt;br /&gt;
&lt;br /&gt;
Öncelikle şunu belirteyim tartışmalar &lt;a href="http://blog.zemana.com/2009/09/guncelleme-zaman.html"&gt;http://blog.zemana.com/2009/09/guncelleme-zaman.html&lt;/a&gt; adresinde yayınlanan bir bildirim yüzünden başladı. Kendi yazılımlarında ki açıkları affetmeyen!!! ve anında yamayan!!! Zemana ekibi ve çok değerli arkadaşları büyük bir operasyonla!! ilgili açığı kapatıp yeni bir versiyon yayınlıyorlar. Yukarıdaki hikayede yer alan arkadaşta kendi kendine "Halbuki bende tam 4 ay önce kritik bir açık bildirdim vede üstelik bypass filan da değil doğrudan sistemi koruması gereken uygulamanın kendisini etkisiz kılıyorum, lakin neden bundan hiç bahsedilmiyor?" diye düşünüp haklı olarak aynı konu başlığı altına gidip sitemlerini bildiriyor. Kıyamette ondan sonra kopuyor. Buyurun gidin konuyu ve tartışmaları okuyun. Bana açığı önce onlara bildirmediğimden dem vuruyorlar. Yazık diyorum ve Security uzmanı arkadaşa kendi blogunda ki şu linke bakıp utanmasını istiyorum: &lt;a href="https://www.blogger.com/comment.g?blogID=1109329877337930296&amp;amp;postID=4606210139420486142"&gt;Açığın yayınlanma çabaları&lt;/a&gt; . Sizin Error Report mekanizmanız çalışmıyorsa veya bildirimlere bakmıyorsanız suç benim mi oluyor?&lt;br /&gt;
&lt;br /&gt;
Üstelik sanki onlar adına çalışan Code Analyst'iyimişim gibi bana, "niye ifşa ediyorsun" diye kızıyorlar. Lütfen beyler biraz işinizin ehli ciddi insanlar olun. Birde kalkmış güvenlik uygulaması yazıyoruz diyorsunuz! Şu güvenlik piyasasın da bir veya on sene olsun, çalışan insanlar gayet iyi bilir ve görürler ki açıklar 2 yönlü şekilde yayınlanır ve üreticinin derhal çözüm bulması tetiklenmiş olur. Tabi sizden bahsetmiyorum sayın Zemana üyeleri. Bu tartışmalar yaşanmamış olsaydı yine de kapatacağınız muamma idi bu açığı . Bir de Zemana güvenlikçisi Erkan bey'in "global takibimizde AntiLogger'a herhangi bir virus veya spyware tarafindan bu tarzda bir saldiri yoktur olay sadece POC'tur." demesine halen gülüyorum. Mantığa bakarmısınız lütfen :) Demek ki aslında açık bildirilmeden önce bir virüs veya spyware yazmamız gerekiyromuş. Kim bilir belkide o zaman bu yazılımı kullanıp kendini güvende hisseden binlerce bedbaht insanın her türlü loglanabilecek bilgisine sahip olup saygıdeğer yazılım firmamızın cümle aleme rezil olmasını seyretmek daha etik olurdu. Yazık diyorum başkada söz bulamıyorum. &lt;br /&gt;
&lt;br /&gt;
Ciddi ciddi düşünüyorum sektör neden böyle yozlaşmış diye? Ntvmsnbc'nin gerek görsel gerek yazılı ve sanal basında cafcaflıya cafcaflıya duyurduğu Sipru adlı multimedia uygulumasında tüm sistemi köle yapan açık bulduk bildirdik üstüne hakaret yedik! Microsoftun tüm işletim sistemleri dahil Command Prompt (cmd.exe) unda policy açığı bulduk raporladık aradan 4 sene geçti açığı kapatan olmadı!Yine Microsoftun Domain Password Distrubited mekanizmasında açık bulduk yayınladık yine aynı. Bu saygıdeğer Zemanacı'lara 4 ay önce açık bildiriyoruz, bizimki sanki kritik bir açık değilmiş gibi arkadaşımızın "reg add" ile eklediği startup bypass'ını ballandıra ballandıra kapatıp ilan ediyorlar bizim açık hala yerinde. Birde son anda tartışmaya katılan ve yazdığım PoC koduna bakıp C bilgimi ortaya çıkaran Hayri bey'ide ayrıca Oscar'a aday göstermek istiyorum! 4 ay öncesinden itibaren sürekli üstüne basa basa söylediğim gibi ardı üstü bir window'a Wm_Close message'i gönderiyoruz sayın Hayri, ne bekliyodunuz yani yalandan yere kodun opcode çıktısını alıp onu shellcode haline getirip öylemi yapsaydım? Emin olun hava atmak isteseydim öyle yapardım ve koda bakanlarda vay anasını derdi. Açın bakın milw0rm ü securityfocus'u o gördüğünüz exploit kodlarının en az yarısı bu tip kodlardan oluşuyor. Neyse Hayri Bey'imizi o engin C bilgisine sahip coder'ları ile başbaşa bırakalım. &lt;br /&gt;
&lt;br /&gt;
Bu tartışmadan hemen sonra 2 DoS birde Bypass açığı buldum ama yeni versiyonlarını bekliyorum çünkü şu an hali hazırda bulmuş olduğum tüm açıklara aynı sebepten .ok atacaklarını iyi biliyorum ve o zaman ne kadar sağlam!!! ve kendi güvenliklerine önem veren bir firma olduklarını hepinizin göreceğini garanti ediyorum. Beni ve onları takip etmeye lütfen devam edin.&lt;br /&gt;
Şimdilik kalın sağlıcakla.&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-7212224325778712844?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2011-10-16T00:28:54.858+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">12</thr:total></item><item><title>SSDT Hooking nedir?</title><link>http://kernelturk.blogspot.com/2009/06/ssdt-hooking-nedir.html</link><category>kernel mode hook</category><category>kernel hook</category><category>system service desciptor table</category><category>hook nedir</category><category>winternals</category><category>ssdt</category><category>kernel mode</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Thu, 30 Sep 2010 04:39:52 PDT</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-5567273734193758813</guid><description>Bilgisayarlarımızı amacı doğrultusunda güzel güzel kullanmak varken - birde kalkmış ne yaptığı belirsiz sayısız zararlı tehdit'i ile uğraşıyoruz. Sanki her biri belirli biz masum son kullanıcıların üzerine atılmış birer KANCA! gibi.&lt;br /&gt;
&lt;br /&gt;
Çok fazla Steven Spielberg okuyorum herhalde jargonum değişti. Neyse; Hooking! Kimine göre gerekli bir mekanizma ama çoğunluk öyle düşünmüyor. İşletim sisteminde yer alan bu faideli ama tehlikeli oyuncak ile dilediğiniz emele ulaşmak içinizdeki şeytanın fısıltıları ile doğru orantılı. Gerek usermode taraflı gerekse kernel taraflı çeşitleri olan hooking işlemini kısa tanımı şöyle olsa gerek:&lt;br /&gt;
&lt;br /&gt;
KernelMode Hooking = "İşletim sistemi bünyesinde bulunan orjinal hizmet fonksiyonlarının hafıza tabanlı adreslerinin ikinci bir dış odaklı amaca hizmet edecek başka bir fonksiyon adresi ile değiştirilmesine" denir. Bu alanların değiştirilmesi işletim sistemi tarafından belirli koruma mekanizmaları ile sağlanmaktadır (bkz:cr0 flags), ancak malumdur ki bu konuda başarı sağlanamamaktadır.&lt;br /&gt;
&lt;br /&gt;
UserMode Hooking = İşletim Sisteminin GUI arayüzünü temsil eden ve usermode çağrılarının ilgili window'lara gönderilmeden önce birinci elden kendini legal hooking mekanizmasına kayıt ettiren kullanıcı processi tarafından işlenmesi ile yapılan hooking çeşitidir. Kullanımı ve dökümantasyonu Microsoft tarafından yapılır. &lt;br /&gt;
&lt;br /&gt;
Api Hooking = Kernelmode hooking de anlatılan mantıkla çalışır ancak bunu koruyan bir mekanizma yoktur. Processlere ait hafıza alanlarında yer alan fonksyion adreslerinin değiştirilmesine dayanır.&lt;br /&gt;
&lt;br /&gt;
Görüldüğü üzere var olan bir sistem akışını ikinci bir müdahale ile istenilen başka bir davranış biçimine sokmaya hooking deniyor. Bunu diler injection ile yapın dilerseniz legal olarak register ile yapın farketmez eğer amacınız sistemin veya kullanıcın hassasiyetlerini gözetmeden suistimal etmekse yaptığınız zararlı yazılım davranışı olacaktır. Burada etraflıca hooking'in bilinen tüm tekniklerini anlatmak ve örnekleri ile açıklamak gibi bir maceraya atılacağımı düşünmüyorsunuz herhalde :) Amacım sadece son yıllarda popülerliğini ve sahip olduğu low level hakimiyeti ile risk derecesini tavan yaptıran KernelMode Hooking kapsamına giren System Service Descriptor Table (SSDT)'nin nasıl modifiye edilebileceği, hangi amaçlar doğrultusunda kullanılabileceği ve nasıl bu yapının korunabileceğine dair kısa açıklamalar yapmaktır. Anlatacaklarımın kalan kısmını okuyan arkadaşların orta seviyede usermode ve kernelmode bilgisi sahibi olması tercih sebebidir.&lt;br /&gt;
&lt;br /&gt;
Win32 Api ortamında kullandığımız fonksiyonların önemli bir kısmı yeteneklerini yardımcı kütüphaneler vasıtası ile gerekli güvenlik ve parametre kontrol işlemlerinden geçtikten sonra kernel mode taraflı bir fonksiyona dallanarak gerçekleştirirler. Bunlardan en çok bilinenleri kernel32.dll ve user32.dll kütüphanelerinde yer alan fonksiyonlardır. Bu kütüphanelerinden birinin export ettiği fonksiyonu kullanan bir process'i usermode çalışan bir debugger(bkz:ollydbg) ile debug ettiğinizde kodun akışını en fazla ntdll.dll kütüphanesi içerisinde yer alan "sysenter" komutuna kadar trace edebilirsiniz. Bu komuttan sonrasını izleyemez ve arka planda gerçekte ne gibi işlemler döndüğünden haberdar olamazsınız. Örnek olarak ExitProcess api'sini uygulamanızdan çağırdınızda izlediği yol şöyledir:&lt;br /&gt;
&lt;br /&gt;
1- Processinizin iat'da yer alan JMP DWORD PTR DS:[&amp;Kernel32.ExitProcess] gerçek fonskiyon adresine zıplar .&lt;br /&gt;
2- Oradan da bir kaç dizi parametre kontrol işlemi geçirdikten sonra ntdll.NtTerminateProcess apisini çağırır&lt;br /&gt;
3- Son olarakta ntdll.dll kütüphanesi içerisinde bu api ye (NtTerminateProcess) atanmış olan serviceID (bu xp sp3 için 0x101'dir) ile birlikte parametreleride stack'te hazırlayıp "sysenter" komutu ile kontrol asıl fonksiyonu yerine getirecek kernelmode taraflı fonksiyona geçer.&lt;br /&gt;
&lt;br /&gt;
Bu aşamadan sonra süreç kernelmode katmanına geçer. Peki bu süreç nasıl işler? Şimdi de dilerseniz biraz derinlere dalalım ve sysenter sonrası işlemler silsilesine göz atalım. &lt;br /&gt;
&lt;br /&gt;
Windows Xp ve 2003'ün çıkması ile birlikte Microsoft, Intel x86 komut seti kümesine kazandırılan "sysenter" adlı komut ile system service hizmetini sunmaya başladı. Bu komutun çalışması için 2 ön şart gereklidir:&lt;br /&gt;
&lt;br /&gt;
1- Kullanılcak native api serviceID'si&lt;br /&gt;
2- Bu ServiceID'ye denk gelen kernel taraflı fonksyion adresini tutan bir tablo.&lt;br /&gt;
&lt;br /&gt;
Windows işletim sistemi boot esnasında bu tabloyu işlemci ailesine göre kullandığı uygun çekirdek dosyası ile ki genelde bu ntoskrnl.exe'dir alarak doğru fonksiyon adresleri ve serviceID'lerini hazırlar ve sysenter komutunun çevrimsel başvurusu için kendini referans gösterip usermode çağrıları için hizmet verecek hale getirir. &lt;br /&gt;
Bu tablo kernel symbol referansı olarak KiServiceTable adını alır ve KeServiceDescriptorTable olarak bilinen struct içerisinde adresi tutulur. Tabloda yer alan her serviceID'ye fonksiyonu yerine getirecek uygun kernel taraflı fonksiyonun hafıza adresleri atanır ve özetle tablo artık usermode çağrılarına cevap verecek halini almış olur. Az önce de bahsettiğim gibi normal şartlar altında bu tablo readonly dir ve kernel tarafından yazma korumalıdır ancak minik bir trick le üstesinden gelinip bsod'a meydan vermenden değişiklik yapma şansınız olabiliyor.&lt;br /&gt;
&lt;br /&gt;
Hikayenin TerminateProces ve usermode'dan bir sonraki adımına geldiğimize göre sürecin işleyişinide yukarıdaki anlatımlara göre nasıl şekillendiğinide anlamış olmalısınız. Artık posta kuşumuz elimizden uçtu ve tüm kontrol onda. Win32 api'lerinin tasarımı süphesiz kendi güvenlikliklerinide kapsıyordu ve bunun için System Service Table'larının bu amaçla kullanımı gayet uygundu. Tüm parametre ve çağrılar birinci elden usermode tarafındaki kütüphanelerde gerekli kontrollerden geçiyor ve son olarak artık kullanıcı kodunun erişim imkanı olmayan ve tamamı ile microsoft yazılımcılarının yazdığı güvenilir!!! kod akışına geçiyordu. Ta ki bu işi yüklenmiş olan bu güzide tabloya birinin müdahele etmeyi başardığı zamana kadar. &lt;br /&gt;
&lt;br /&gt;
Aslında bu tabloyu antivirüs üreticileri bile modify ederken bunu başka bir zararlının yapamayacağını düşünmek mantıksız olurdu. Evet çoğu antivirüs ve yazılım tabamlı firewall üreticileri bu tabloyu hook ederek sistemin işleyişine müdahil olurlar. Bir önceki makalemde açığından bahsettiğim Zemana Antilogger gibi HIPS kategorisindeki yazılımlarında kalbide bu katmanda atar. Günümüzde halen usermode taraflı keylogger yazmayı düşünen arkadaşların ne yazık ki bu tip doğrudan api function'una yönelik kısıtlama getiren anti'lere karşı hiç bir şansları yok. Ta ki onlarda bu tabloya müdahele edip kendi amaöçları için değiştirinceye kadar. Peki bu tabloya programcı nasıl müdahale eder. Şunun farkındayım; bu blog çatısı altında kodlama ile uğraşanların çoğu high level dillere aşina ve burada anlattıklarımı koda dökmeleri çok zor ama yinede meraklısının bilmesi gerektiği kanaatindeyim.&lt;br /&gt;
&lt;br /&gt;
Gerek zararlı rootkitler olsun, gerek sizi bu rootkitlerden koruyacağını idda eden savunma programları olsun SSDT denen bu tabloyu hook ederek bu işlevselliklerini sağlarlar. Yani iki tarafında yaptığı bu tabloyu uygun şekilde modifiye ederek kendi amaçları doğrultusunda kullanmaktan ibaret. Örneğin aslında tamamı ile Windows çekirdeğine ait fonksiyon adresleri ile dolu olması gereken bu tablonun Zemana Antilogger uğradıktan sonraki şekli aşağıdaki gibidir:&lt;br /&gt;
&lt;br /&gt;
c:\program files\antilogger\antilog32.sys&lt;br /&gt;
0x0025 - NtCreateFile&lt;br /&gt;
0x0035 - NtCreateThread&lt;br /&gt;
0x003F - NtDeleteKey&lt;br /&gt;
0x0041 - NtDeleteValueKey&lt;br /&gt;
0x0061 - NtLoadDriver&lt;br /&gt;
0x006C - NtMapViewOfSection&lt;br /&gt;
0x0074 - NtOpenFile&lt;br /&gt;
0x0077 - NtOpenKey&lt;br /&gt;
0x007A - NtOpenProcess&lt;br /&gt;
0x007D - NtOpenSection&lt;br /&gt;
0x0080 - NtOpenThread&lt;br /&gt;
0x00B4 - NtQueueApcThread&lt;br /&gt;
0x00D2 - NtSecureConnectPort&lt;br /&gt;
0x00D5 - NtSetContextThread&lt;br /&gt;
0x00F0 - NtSetSystemInformation&lt;br /&gt;
0x00F7 - NtSetValueKey&lt;br /&gt;
0x0101 - NtTerminateProcess&lt;br /&gt;
0x0115 - NtWriteVirtualMemory&lt;br /&gt;
&lt;br /&gt;
Gördüğünüz gibi 18 adet hook edilmiş fonksiyonun listesi ve yanlarında ait oldukları serviceID'leri. UserMode tarafında bir process erişimi, dosya işlemi, port erişimi, fiziksel hafızaya işlemleri ve code injection gibi bir çok işleme ait orjinal fonksiyon çağrıları birinci elden KernelMode katmanında AntiLogger sürücüsü tarafından işlenmekte. Böylelikle program sistem'de erişim kısıtlama ve erişim izni verme yetkilerinede sahip olmuş oluyor. Tabi amacı itibari ile de olması gereken bir işlem bu. Ancak bu işlemin aynını rootkitlerde yapıyor ki bu yüzden microsoft ve işlemci üreticileri buna dur diyerek KPP (Kernel Patch Protection) adı verilen bir sistemle bunun önüne geçmiş durumda(yada şimdilik öyle görünüyor) [1 yıl sonra gelen edit : evet öyle görünüyormuş artık ilk x64 rootkit örnekleri piyasaya çıktı]&lt;br /&gt;
&lt;br /&gt;
Gelelim bu tabloyu nasıl değiştireceğinize. Hızlıca özetlersem \\device\\physicalmemory nesnesine erişim izni alarak işletim sisteminizin kullandığı orjinal kernel dosyasının içerisinden (benim core2 işlemcim için bu ntkrpamp.exe'dir) orjinal Service Dispatch Table fonksiyon adreslerini alıp hook edilmiş olanların üzerlerine yazarak çalışacak her türlü anti'den önce etkisiz kalmasını sağlayabilir veya doğrudan bir kernel rootkit yazarak bazı Antilerin tümü ile etkisiz kalmasını sağlayabilirsiniz. &lt;br /&gt;
&lt;br /&gt;
Derlendiğinde sisteminizde legal veya illegal yollardan hook etmiş olan programlara ait tüm hook edilmiş fonksiyonları size listeleyen ve ardından dilerseniz  bunları orjinal kernel dosyasından ilk ve olması gereken hale getiren bir exe oluyor. Kodu çift işlemci destekli nt kernel dosyası ile çalışacak halde değiştirip bazı ek ve güzel ilavelerde bulunmaya çalıştım. Sizlerde dilediğiniz gibi üzerinde oynayabilir yada SSDT Hooking mantığını anlayıp kendi özel hook'unuzu yazıp korkusuzca sistemlerde cirit atabilirsiniz. Birdaha ki makaleye kadar sağlıcakla.&lt;br /&gt;
&lt;br /&gt;
İbrahim Akgül&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-5567273734193758813?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2010-09-30T14:39:52.641+03:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">3</thr:total></item><item><title>Benmi geç kaldım! Yoksa birileri fazlamı uyanık?</title><link>http://kernelturk.blogspot.com/2009/06/benmi-gec-kaldm-yoksa-birileri-fazlam.html</link><category>service call table</category><category>kpp</category><category>coder</category><author>noreply@blogger.com (Ibrahim Akgul)</author><pubDate>Tue, 11 Jan 2011 12:48:16 PST</pubDate><guid isPermaLink="false">tag:blogger.com,1999:blog-1664781491659878902.post-8777962885637316332</guid><description>Bilgisayar teknolojilerinin gelişimi ile birlikte iyi ve kötünün yararlı ve zararlının da savaşı siber alemde başlamış oldu. Donanımlar ve İşletim sistemleri gelişip yaygınlaştıkça, bunları suistimal edip kendi çıkarlarına kullanmaya çalışanların sayısında doğru orantılı bir artış oldu. Tabi tepkisel olarakda aynı düzlemde bu zararlılara karşı bir çok önlem alındı.&lt;br /&gt;
&lt;br /&gt;
Özellikle 90'lı yıllardan sonra büyüme trendi maksimuma çıkan ve internet'in de yaygınlaşması ile artık önü bir türlü alınamayan bilgi hırsızlığı problemi altın çağını yaşamakta. Her zaman bir adım önde olan zararlı üreticileri, kendilerini egale etmeye çalışan onlarca orta ve büyük ölçekli sistem savunma firmalarına her defasında çalım atmaktalar. Tek bir coder'in yazdığı zararlının peşinden koşan bu büyük abiler günlerce uğraşmalarına rağmen çoğu zaman çaresiz kalmaktadırlar. Şu an hepinizin anımsayacağı bu büyük Güvenlik firmaları onlarca çalışanı ve ar-ge çalışmaları ile her yeni gün savaşta bir adım daha önde olabilmek için gayret göstermekteler. Ancak bugune değin hiç bir zaman kendilerinden zararlılara karşı kökten çözüm vaadi ve kendilerini kusursuz bir savunma sistemi imiş gibi beyan ettiklerini görmedim. Çünkü böyle bir söylem işletim sistemini üretenlere bile gerçekçi gelmiyorken bu sektörde yer alan orta halli bir kullanıcıya dahi komik gelecektir. &lt;br /&gt;
&lt;br /&gt;
Ancak her ne hikmettirki uzun zamandır takip edemediğim ancak son 1 haftadır "dur bakalım neler yeni" edası ile göz atarken Türk Sistem!!! yazılımcılarının geliştirdiklerini iddaa ettikleri koruma yazılımlarından bir çoğu bu safsata ile kendilerini sektöre lanse eder olmuş. Bu beyanatlar çok dikkatimi çekmiş olacak ki bu ürünlerden en iddaalı olan üçünü sistemime kurdum ve tipik zararlı mantığı ile önce düşmanı yok et hedefini gözeterek yaptığım defeat&amp;inject testleri ile kendilerini test ettim. Sonuçmu? Home 3:0 Away &lt;br /&gt;
&lt;br /&gt;
Kendi Processlerinin açıklarını yamamayan bu yazılımlar bizi nasıl koruyacak! Açıkcası şayet bu aşamayı geçselerdi vaadettikleri koruma modüllerini deneme hevesim olacaktı.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Zaten x64 bit işlemciler sayesinde x64 Windows os'lerin desteklediği KPP sistemi ile artık kernel rootkitlerinden kurtuluyor gibi görünüyoruz. Bu vesile ile AV üreticilerinde neden tedirgin olup Microsoft ile savaşa tutuştuklarınıda anlamış oluyoruz sanırım. System Service Table'i hook edip bu yolla kernel mode'da cirit atma devri uzun bir müddet sekteye uğrayacak gibi ve bu yüzden teknolojilerinin belini bu mode'a bağlayanları epeyce üzeceğe benziyor. &lt;br /&gt;
&lt;br /&gt;
Hepiniz sağlıcakla kalın.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1664781491659878902-8777962885637316332?l=kernelturk.blogspot.com' alt='' /&gt;&lt;/div&gt;</description><app:edited xmlns:app="http://www.w3.org/2007/app">2011-01-11T22:48:16.953+02:00</app:edited><thr:total xmlns:thr="http://purl.org/syndication/thread/1.0">0</thr:total></item><media:rating>nonadult</media:rating></channel></rss>

