Lena Reversing
Total Page:16
File Type:pdf, Size:1020Kb
Load more
										Recommended publications
									
								- 
												  Programmation Utilisant Les Interruptions Du Syst`Eme D’Exploitation : Le Cas De MS-DOSProgrammation utilisant les interruptions du syst`eme d’exploitation : le cas de MS-DOS Patrick C´egielski Janvier 2019 Pour Ir`ene et Marie Legal Notice Copyright c 2019 Patrick C´egielski Universit´eParis XII – IUT de S´enart-Fontainebleau Route foresti`ere Hurtault F-77300 Fontainebleau [email protected] iv Table des mati`eres Pr´eface ix 0.1 Bibliographie ...................................... x 1 Lesgrandesfonctionsd’unsyst`emed’exploitation 1 1.1 Etudeg´en´erale´ ..................................... 2 1.1.1 Les deux tˆaches d’un syst`eme d’exploitation . .... 2 1.1.2 Principe des syst`emes d’exploitation . 3 1.2 CasdeMS-DOS .................................... 5 1.2.1 Mod`eleentroiscouches ............................ 5 1.3 Historique........................................ 6 1.4 Bibliographie ...................................... 9 I Le syst`eme d’exploitation comme machine virtuelle 11 2 Programmer avec le DOS 13 2.1 Lesentr´ees-sortiesstandard . ....... 14 2.1.1 Fonction 02h d’affichaged’uncaract`ere . 14 2.1.2 Fonction 01h desaisied’uncaract`ereavec´echo . 15 2.1.3 Fonction 08h desaisied’uncaract`eresans´echo . 17 2.1.4 Saisie d’une chaˆıne de caract`eres . .. 17 2.2 L’interruption 33h de manipulation de la souris . 18 2.2.1 Fonction 00h d’initialisation de la souris . 18 2.2.2 Fonctions 01h et 02h d’affichage et de transparence du pointeur . 18 2.2.3 Fonction 03h de r´ecup´eration de la position du pointeur . 19 2.2.4 Fonction 04h ded´eplacementdupointeur . 20 2.3 Fonction 05h d’impression............................... 21 2.4 Lesyst`eme ....................................... 22 2.4.1 Fonction 2Ah d’obtentiondeladate ..................... 22 2.4.2 R´ecup´eration de l’heure .
- 
												  Swsoft Gewinnt Ex-Microsoft-Systemarchitekten Als Senior Technical AdvisorSWsoft gewinnt Ex-Microsoft-Systemarchitekten als Senior Technical Advisor Mark Zbikowski kommt mit Expertenwissen über Windows- Systemprogrammierung zum Unternehmen für Virtualisierungs- und Automatisierungssoftware Darmstadt, 17.01.2008. – SWsoft vermeldet einen prominenten neuen Berater: Mark Zbikowski, ehemaliger Systemarchitekt bei Microsoft und einer der Pioniere der Softwareentwicklung überhaupt, wird für das Unternehmen als Senior Technical Advisor tätig. In dieser Funktion wird er SWsoft unterstützen, indem er das Entwicklungsteam und die Führungskräfte berät. Während seiner Zeit bei Microsoft leitete Zbikowski MS-DOS-, OS/2-, Cairo- und NT-Projekte. Im Jahre 2006 wurde er für seine 25 Dienstjahre in der Firma geehrt und war der erste Mitarbeiter - nach Bill Gates und Steve Ballmer - der diese Karrieremarke erreichte. Zbikowski entwarf das Dateiformat der „EXE“-Programme unter MS-DOS; seine Initialen „MZ“ zieren bis heute die Kopfdaten dieses Formats für ausführbare Dateien. Er war ein wichtiger Designer und Entwickler für das gängigste Dateisystem Windows NTFS. Heute lehrt Zbikowski an der University of Washington, nachdem er im Juni 2006 bei Microsoft ausgeschieden war. Er besitzt einen von Harvard verliehenen Bachelor-Grad in angewandter Mathematik und einen Master-Abschluss von Yale. "Die Unternehmenskultur bei SWsoft erinnert an die aufregenden Anfangsjahre von Microsoft – eine junge Firma voller Energie und mit riesigen Chancen, die Veränderungen wesentlich mitzugestalten, die es im Einsatz der Informationstechnologie zum Nutzen von Verbrauchern und Unternehmen überall auf der Welt geben wird“, sagt Zbikowski. „Ich freue mich sehr auf den Beginn meiner Mitarbeit an SWsofts kontinuierlicher Entwicklung von Weltklasse-Software für Virtualisierung, Management und Automatisierung.“ “Marks Erfahrungen mit der Erstellung von Systemkomponenten für die meistverbreitete Software weltweit – Microsoft Windows – sind von großer Bedeutung für unsere Arbeit", so Serguei Beloussov, CEO bei SWsoft.
- 
												  Portable Executable מאת Spl0itPortable Executable מאת Spl0it הקדמה - מה זה PE? ויקיפדיה: "PE )קיצור של Portable Executable( הוא פורמט שפותח ע"י Microsoft עבור קבצי ריצה, קבצי אובייקט, ספריות קישור-דינמי )DLL(, קבצי פונטים )FON( ועוד אשר משומשים בגרסאות ה32- וה- 64 ביט של מערכות המשתמשות במערכת ההפעלה PE .Windows הוא מבנה נתונים אשר מקבץ את המידע ההכרחי בשביל שה-Loader של Windows יצליח לנהל את הקוד בזמן ריצה". סוגי הקבצים הנפוצים ביותר המשתמשים בפורמט PE: exe - קובץ ריצה dll - ספריית קישור-דינמי sys/drv - קובץ מערכת )דרייבר לקרנל( ocx - קובץ שליטה ב-ActiveX cpl - לוח בקרה scr - שומר מסך הערה: לקבצי lib. )ספריות סטטיות( יש פורמט שונה, לא PE. מערכת ההפעלה Windows עושה שימוש בקבועים הנ"ל כדי לייצג גדלים של משתנים: גודל טיפוס בית CHAR (Character) 1 2 בתים WORD 2 בתים (SHORT (Short Integer 4 בתים (DWORD (Double Word 4 בתים (LONG (Long Integer 8 בתים (QWORD (Quad Word 8 בתים LONGLONG כלים לחקירת ה-PE: PEView - לטובת הסתכלות על ה-PE של קבצים בפורמט זה CFF Explorer - אותו דבר, אך עם פיצ'רים נוספים כגון עריכת ה-PE בהקסדצימלי והמרת הקובץ לשפת אסמבלי WinDbg - עבור ניפוי שגיאות )Debugging( בסיסי פורמט ה-PE נראה כך )התמונה ממוספרת כדי שההסברים בהמשך המאמר יהיו ברורים יותר. לתמונה "נקייה" יותר, לחצו כאן(: Portable Executable www.DigitalWhisper.co.il גליון 90, ינואר 2018 2 DOS-Header המבנה הראשון, הנמצא ב-0x0 Offset, נקרא DOS-Header והוא נראה כך )מספר 1 בתמונת פורמט ה- :)PE הערה להמשך המאמר: שדות המסומנים בכחול הם שדות שחשובים לנו. לא אוכל לכסות את כלל השדות במאמר זה, לכן אכסה רק את השדות החשובים.
- 
												  Writing Secure Code Codespine = 1.82” ”During the past two Proven techniques from the security experts to decades, computers have revolutionized the way we live. help keep hackers at bay—now updated with BEST PRACTICES They are now part of every lessons from the Microsoft security pushes BEST PRACTICES critical infrastructure, from Hackers cost countless dollars and cause endless worry every year as they attack secure software telecommunications to banking DEVELOPMENT SERIES to transportation, and they networked applications, steal credit-card numbers, deface Web sites, and slow network SECURE CODE WRITING contain vast amounts of sensitive traffi c to a crawl. Learn techniques that can help keep the bad guys at bay with this SECURE CODE WRITING data, such as personal health and entertaining, eye-opening book—now updated with the latest security threats plus WRITING fi nancial records. Building secure lessons learned from the recent security pushes at Microsoft. You’ll see how to padlock software is now more critical than your applications throughout development—from designing secure applications ever to protecting our future, and to writing robust code that can withstand repeated attacks to testing applications every software developer must for security fl aws. Easily digested chapters explain security principles, strategies, learn how to integrate security and coding techniques that can help make your code more resistant to attack. The into all their projects. Writing authors—two battle-scarred veterans who have solved some of the industry’s toughest SECURE Secure Code, which is required security problems—provide sample code to demonstrate specifi c development Second Edition reading at Microsoft and which techniques.
- 
												  ACSC 372 – Systems ProgrammingFile / Directory Manipulation ACSC 372 – Systems Programming Creating Directories Command mkdir <directory> Removing Directories Command rmdir <directory> Lecture 3: Introductory UNIX commands II Removes an empty directory 2 File / Directory Manipulation (cntd) File / Directory Manipulation (cntd) Copying Files Moving Files Command cp (options -i, -r) Command mv (option -i) Makes a copy of a file Moves a file from one location to a new location usage: cp <Source> <Destination> usage: mv <Source> <Destination> Option -i Option -i Asks if you want to write over a file that already exists Asks if you want to write over a file that already exists Option -r Recursively, will copy all files and subdirectories Used also as a rename command 3 4 File / Directory Manipulation (cntd) Examining Files Removing Files Command rm (options -i, -f, -r) Everything in UNIX is a file Removes a file Different files have different uses usage: rm <filename(s)> How do you tell what type a file is? Option -i Command file Verify the delete Examine file types Option -f Force the removal of a file Not 100% accurate. Overrides the -i flag It is based on a combination of the permission codes of the file, the name of the file, and an analysis of the first lines of option -r the file. Recursively, delete all files and directories 5 6 Examining Files (cntd) Examining Files (cntd) Examination Mechanism bash-3.1$ file test/ http://en.wikipedia.org/wiki/Magic_number_(programming) Compiled Java class files (bytecode ) start with 0xCAFEBABE on big-endian systems. test/: directory GIF image files have the ASCII code for 'GIF89a' (0x474946383961) or 'GIF87a' (0x474946383761) JPEG image files begin with 0xFFD8FF, and JPEG/ JFIF files contain the ASCII code for 'JFIF' (0x4A464946) or JPEG/ EXIF files contain the ASCII code for 'Exif' (0x45786966) beginning at byte 6 in the file, followed by more metadata about the file.
- 
												  Operating Systems Principles and Practice, Volume 4Operating Systems Principles & Practice Volume IV: Persistent Storage Second Edition Thomas Anderson University of Washington Mike Dahlin University of Texas and Google Recursive Books recursivebooks.com Operating Systems: Principles and Practice (Second Edition) Volume IV: Persistent Storage by Thomas Anderson and Michael Dahlin Copyright ©Thomas Anderson and Michael Dahlin, 2011-2015. ISBN 978-0-9856735-6-7 Publisher: Recursive Books, Ltd., http://recursivebooks.com/ Cover: Reflection Lake, Mt. Rainier Cover design: Cameron Neat Illustrations: Cameron Neat Copy editors: Sandy Kaplan, Whitney Schmidt Ebook design: Robin Briggs Web design: Adam Anderson SUGGESTIONS, COMMENTS, and ERRORS. We welcome suggestions, comments and error reports, by email to [email protected] Notice of rights. All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form by any means — electronic, mechanical, photocopying, recording, or otherwise — without the prior written permission of the publisher. For information on getting permissions for reprints and excerpts, contact [email protected] Notice of liability. The information in this book is distributed on an “As Is" basis, without warranty. Neither the authors nor Recursive Books shall have any liability to any person or entity with respect to any loss or damage caused or alleged to be caused directly or indirectly by the information or instructions contained in this book or by the computer software and hardware products described in it. Trademarks: Throughout this book trademarked names are used. Rather than put a trademark symbol in every occurrence of a trademarked name, we state we are using the names only in an editorial fashion and to the benefit of the trademark owner with no intention of infringement of the trademark.
- 
											Writing Secure Code / Michael Howard, David LeblancCopyright 2002 by Microsoft Corporation PUBLISHED BY Microsoft Press A Division of Microsoft Corporation One Microsoft Way Redmond, Washington 98052-6399 Copyright © 2002 by Microsoft Corporation All rights reserved. No part of the contents of this book may be reproduced or transmitted in any form or by any means without the written permission of the publisher. Library of Congress Cataloging-in-Publication Data Howard, Michael, 1965– Writing Secure Code / Michael Howard, David LeBlanc. p. cm. ISBN 0-7356-1588-8 1. Computer security. 2. Data encryption (Computer science) I. LeBlanc, David, 1960– II. Title. QA76.9.A25 H698 2001 005.8--dc21 2001044546 Printed and bound in the United States of America. 1 2 3 4 5 6 7 8 9 QWE 6 5 4 3 2 Distributed in Canada by Penguin Books Canada Limited. A CIP catalogue record for this book is available from the British Library. Microsoft Press books are available through booksellers and distributors worldwide. For further information about international editions, contact your local Microsoft Corporation office or contact Microsoft Press International directly at fax (425) 706-7329. Visit our Web site at www.microsoft.com/mspress. Send comments to [email protected]. Active Directory, ActiveX, Authenticode, Hotmail, Jscript, Microsoft, Microsoft Press, MS-DOS, MSDN, Visual Basic, Visual C++, Visual Studio, Win32, Windows, and Windows NT are either registered trademarks or trademarks of Microsoft Corporation in the United States and/or other countries. Other product and company names mentioned herein may be the trademarks of their respective owners. The example companies, organizations, products, domain names, e-mail addresses, logos, people, places, and events depicted herein are fictitious.
- 
												  Foreword, Bill Gates General Editor, Ray DuncanComplete and Unabridged The -.-.. 00 ~ ® Foreword, Bill Gates General Editor, Ray Duncan Olympus et al. 1107 ---'"'------------~--- -- The MS-DOS Encyclopedia ·.~ The Encyclopedia Microsoft Press Redmond, Washington 1988 Ray Duncan, General Editor Foreword by Bill Gates Published by Microsoft Press A Division of Microsoft Corporation 16011 NE 36th Way, Box 97017, Redmond, Washington 98073-9717 Copyright © 1988 by Microsoft Press All rights reserved No part of the contents of this book Encyclopedia Staff may be reproduced or transmitted in any form or by any means without the written permission of the publisher Library of Congress Cataloging in Publication Data The MS-DOS encyclopedia : versions 1 O through 3 .2 / Editor-in-Chief: Susan Lammers editor, Ray Duncan Editorial Ditector: Patricia Pratt p cm Includes indexes Senior· Editor: Dorothy l Shattuck 1 MS-DOS (Computer operating system) I Duncan, Ray, 1952- II Microsoft Press Senior· Technical Editor: David l Rygmyr QA76 76 063M74 1988 87-21452 005 4'4~-dc19 CIP Special Projects Editor: Sally A. Brunsman ISBN l-55615-174-8 Editorial Coordinator: Sarah Hersack Printed and bound in the United States of America 123456789RMRM321098 Associate Editors and Technical Editots: Distributed to the book trade in the Pamela Beason, Ann Becherer, Bob Combs, United States by Harper & Row Michael Halvorson, Jeff Hinsch, Dean Holmes, Distributed to the book trade in Chris Kinata, Gary Masters, Claudette Moore, Canada by General Publishing Company, ltd Steve Ross, Roger Shanafelt, Eric Stroo, Distributed
- 
												  Explorer's Guide to the HP 95In 1991, while experimenting with one of the very first HP 95 portable computers, this book came together. Today, more than fifteen years later, that HP 95 computer still works great, though it’s creaking and slowing down a bit and doesn’t have the battery Explorer’s Guide life it once had; I know the feeling. To The I would like to invite you to wander through this book, to see what an eleven-ounce computer could do, not all that long ago. Rumor has it that HP later released very nice palmtop computers with 100 HP 95 and 200 model numbers, even though this book knows nothing about them. I’ve simplified some illustrations for this online version, but text and page layout still look like 1991. On the left is something like the original book cover, complete with the old rabbit logo. One edition of this book was formatted with Microsoft Word for Windows 1.1. It was printed on an HP DeskJet 500 printer, which R. E. Harvey was a 300 d.p.i. B&W inkjet that scooted through about two pages per minute in best-quality mode, and cost more than $500. Body Palmtop PC Palmtop PC R text in this book is still in Bitstream Charter font, which was designed for low-resolution laser and inkjet printing. There are 112 pages and around 53,000 words. The peculiar page count begins with this title page. Maybe I was trying to make it sound like a lot of pages, while actually keeping the page count down; maybe it was something else.
- 
												  Reversing and Disassembly Tools2 REVERSING AND DISASSEMBLY TOOLS With some disassembly background under our belts, and before we begin our dive into the specifics of Ghidra, it will be useful to understand some of the other tools that are used for reverse engineering binaries. Many of these tools predate Ghidra and continue to be useful for quick glimpses into files as well as for double-checking the work that Ghidra does. As we will see, Ghidra rolls many of the capabilities of these tools into its user interface to provide a single, integrated environment for reverse engineering. Classification Tools When first confronted with an unknown file, it is often useful to answer simple questions such as, “What is this thing?” The first rule of thumb when attempting to answer that question is to never rely on a filename extension to determine what a file actually is. That is also the second, third, and fourth rules of thumb. Once you have become an adherent of the file extensions are meaningless line of thinking, you may wish to familiarize yourself with one or more of the following utilities. file The file command is a standard utility, included with most *nix-style oper- ating systems as well as the Windows Subsystems for Linux1 (WSL). This command is also available to Windows users by installing either Cygwin2 3 or MinGW. The file command attempts to identify a file’s type by examin- ing specific fields within the file. In some cases,file recognizes common strings such as #!/bin/sh (a shell script) and <html> (an HTML document).
- 
												  Tutorial Program at a GlanceConference at a Glance Saturday, June 17 4:00 pm - 9:00 pm . .On-Site Registration USENIX Sunday, June 18 ! PARTY ! PARTY ! PARTY ! PARTY ! 7:30 am - 5:00 pm . .On-Site Registration 9:00 am - 5:00 pm . .Tutorial Program USENIX CELEBRATES 6:00 pm - 7:00 pm . .Welcome Reception ITS 25TH ANNIVERSARY! 7:00 pm - 8:00 pm . .Conference Orientation Monday, June 19 What would a celebration be without parties, games, and prizes? 7:30 am - 5:00 pm . .On-Site Registration 9:00 am - 5:00 pm . .Tutorial Program Please join us for the festivities! Tuesday, June 20 7:30 am - 5:00 pm . .On-Site Registration 9:00 am - 5:00 pm . .Tutorial Program 6:00 pm - 10:00 pm . .Birds-of-a-Feather Sessions Important Dates to Remember Wednesday, June 21 Pre-Registration Discount Deadline: 7:30 am - 6:00 pm . .On-Site Registration Friday, May 12, 2000 9:00 am - 10:30 am . .Keynote Address Hotel Discount Deadline: 11:00 am - 5:30 pm . .Refereed Papers/Invited Talks/FREENIX Friday, May 26, 2000 12:00 pm - 7:00 pm . .Vendor Exhibition 5:30 pm - 7:00 pm . .Happy Hour at the Exhibition 9:00 pm - 11:00 pm . .Birds-of-a-Feather Sessions Thursday, June 22 Contents 7:30 am - 5:00 pm . .On-Site Registration 9:00 am - 5:30 pm . .Refereed Papers/Invited Talks/FREENIX 2 Conference at a Glance 10:00 am - 4:00 pm . .Vendor Exhibition 3 Letter from the Program Chair 7:00 pm - 9:00 pm . .25th Anniversary Reception 4–14 Tutorial Program 9:00 pm - 11:00 pm .
- 
												  Contents of CDContents of CD In CD you have all the source codes of this book, few other tutorials, programming tools and other useful programs. Few of them are sharewares, so if you use them you are supposed to pay the author. The CD includes: • Ralf Brown’s Interrupt List • Alexander Rusell’s Game Programming Guide and other programs • BIOS source codes • Programs for Communication between computers • Compiler creating tools • Device driver kit • Assemblers • Disassemblers • DJGPP – 32 bit compiler • Allegro library • Editor source code • Programs and tools for embedded systems • File Formats Encyclopedia • PC Game Programmers’ Encyclopedia • Graphics programs and tools • Keyboard programs • Music programs • Operating sytems’ source code • Networking libraries • TSR programs and tools • Printer programs • Virus and Anti-virus programs • Novell Netware programs • Useful programming documents • WinZip 8.0 (Shareware Evaluation version) • And many more… “Test everything. Hold on to the good.” First Chapter 1 Greetings. It is a common practice to skip the acknowledgement and book organization. So we have placed them in the First Chapter! Please read this chapter without fail to understand this book better. 1.1 Acknowledgement Throughout the world many people have contributed to this book. We must acknowledge all those good people. We sincerely thank Dr. Dennis M. Ritchie, creator of C language for granting permission to use his photo. Our thanks also goes to Dr. Ralf Brown for providing us his great source—Ralf Brown’s Interrupt List for this book. We must thank Mr. Alexander Russell for his unconditional support to this book. We are proud to thank all the real and international programmers who provided their source code to us.