하드디스크에 물리적인 주소에 접근하는 방법

ddaalgi의 이미지

하드디스크의 물리적인 주소로 해당 주소에 위치한 내용을 읽어오려 합니다.

read 함수로는 화일기술자를 통해서 화일에 접근하기때문에 사용하지 못할거 같고,,

목표는 하드디스크의 MBR 다음에 위치한 블록그룹의 내용 전체를 읽는 것입니다.
(블록그룹에 있는 슈퍼블록, 그룹디스크립터, 데이터블록비트맵, 아이노드비트맵, 아이노드테이블 만)

위에 나열한 데이터를 읽어서 하나의 파일로 만들려하는데,

어떻게 접근해야 될지 깜깜하네요...

커널레벨에서 이 데이터들을 읽어오는 함수가 있거나,
다른 방법으로 이 데이터들을 가져올수 있는 방법이 있으면 알려주세요!

File attachments: 
첨부파일 크기
Plain text icon hda.txt64 KB
Plain text icon hda2.txt64 KB
IsExist의 이미지

/dev/hda1 처럼 장치 파일을 직접 open 해서 읽으면 되지 않을까요.

---------
간디가 말한 우리를 파괴시키는 7가지 요소

첫째, 노동 없는 부(富)/둘째, 양심 없는 쾌락
셋째, 인격 없는 지! 식/넷째, 윤리 없는 비지니스

이익추구를 위해서라면..

다섯째, 인성(人性)없는 과학
여섯째, 희생 없는 종교/일곱째, 신념 없는 정치

ddaalgi의 이미지

IsExist wrote:
/dev/hda1 처럼 장치 파일을 직접 open 해서 읽으면 되지 않을까요.

int main()
{
	int fd, readn , i;
	char buf[1024];

	fd = open("/dev/hda2", O_RDONLY);
	readn = read(fd, buf, 1023);
	buf[1023] = '\0';

	printf("read nbyte : %d\n",readn );
	printf("read disk : ");
	for(i = 0; i<1024 ;i++)
	{
		printf("%d", buf[i]);
	}
	printf("\n");

	close (fd);
	return 0;
}

해보니까 /dev/hda2 처럼 열리긴 하는데 내용을 보면 0만 1023개가 출력됩니다.
%s로 찍으면 아무것도 안나오고요..
부트블록이 1블록이니까 그 다음 블록그룹부터 내용을 보고싶은데....
저런식으로 open하면 파일포인터가 부트블록(MBR)을 가리키게 되는거 아닌가요?
아.. 왜 아무내용도 없는거죠?

갈길이 멀지만 보일라 하나?

IsExist의 이미지

/dev/hda2 는 MBR을 갖지 않습니다.

/dev/hda1 으로 해보세요.

printf ("%02x ", (unsigned char)buf[i]);

로 수정도 하세요

---------
간디가 말한 우리를 파괴시키는 7가지 요소

첫째, 노동 없는 부(富)/둘째, 양심 없는 쾌락
셋째, 인격 없는 지! 식/넷째, 윤리 없는 비지니스

이익추구를 위해서라면..

다섯째, 인성(人性)없는 과학
여섯째, 희생 없는 종교/일곱째, 신념 없는 정치

bil78의 이미지

IsExist wrote:
/dev/hda2 는 MBR을 갖지 않습니다.

/dev/hda1 으로 해보세요.

printf ("%02x ", (unsigned char)buf[i]);

로 수정도 하세요

마찬가지로 0만 찍히던데요..

/dev/hda로 하면 먼가 찍히기는 하네요 ^^
아무래도 파티션를 해서 그런가바요.

flyingykk의 이미지

Master Boot Record(MBR) 다음에는 첫 번째 파티션(/dev/hda1)의 부트 섹터가 있지 않나요? 그 다음이 원하시는 부분 아닐까요?

ashuaria의 이미지

MBR은 당연히 /dev/hda로 봐야 보이는건데요?
hda1이면 이미 나누어진 파티션안의 내용입니다만..
fdisk 사용할때 /dev/hda라고 사용하시죠?

<FONT face="Times New Roman" size=4>שלום צליכם מאת ארוננו ישוצ המשיח</FONT>

ddaalgi의 이미지

답변해주신 분들 모두 정말 감사합니다.

답변을 토대로 아래와 같이 작성해보았습니다.

#define PERM 0666

int main() 
{
	int fd1, fd2, readn, i ;
	
	char buf[65536]; 
	
	fd1 = open ( "/dev/hda1", O_RDONLY ) ; 
	fd2 = open ( "hda1.txt", O_RDWR | O_CREAT | O_EXCL, PERM ) ;
	readn = read ( fd1, buf, 65536 ) ; 
	buf[65535] = '\0' ; 
	write ( fd2, buf, readn ) ;

	printf ( "hda1> read nbyte : %d\n", readn ) ; 
	printf ( "hda1> read disk : " ) ; 

	for ( i = 0 ; i<65536 ; i++ ) 
	{ 
		printf ( "%02x ", (unsigned char)buf[i] ) ;
	} 
	printf("\n\n"); 

	close ( fd1 ) ; 
	close ( fd2 ) ;
	
	return 0; 
}

/dev/hda1 뿐만 아니라 /dev/hda2, /dev/hda 에 대해서도 각각 해보았습니다.
각각의 경우에 생성되어진 파일을 열어보면 어떠한 내용이 들어감을 확인했는데요,
제가 목표로하는것은 / (즉, /dev/ hda2) 의 내용입니다.
그렇다면 /dev/hda2 로 접근하는게 맞는건가요? /dev/hda 와의 관계도 궁금하네요.. ^^;

현재 VMware 상에서

Filesystem  1K-blocks    Used  Available  Use%  Mounted on
/dev/hda2     3288944  859652    2262216   28%   /
/dev/hda1      101089   10086      85784   11%   /boot
none           184248       0     184248    0%   /dev/shm

이렇게 설정되어 있습니다.

혹시나 해서 /dev/hda 로 했을때와 /dev/hda2 로 해서 생성된 파일을 동봉합니다.
(다운로드 해서 보셔야 파일내용을 제대로 확인할수 있는듯 합니다)

댓글 첨부 파일: 
첨부파일 크기
Plain text icon 0바이트
Plain text icon 0바이트

갈길이 멀지만 보일라 하나?

Necromancer의 이미지

hda -> 하드디스크 전체와 대응됩니다. 그러므로 첫번째 512바이트는 MBR이 됩니다.

hda1, hda2, ... -> 하드내 각 파티션 영역과 대응됩니다. (부팅할때 커널이 분석하죠)
첫번째 512바이트는 각 파티션의 첫번째 섹터가 되는거죠.

Written By the Black Knight of Destruction

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.