어떤 데이터 구조를 구조체에 그대로 매핑하기...
글쓴이: dopesoul / 작성시간: 일, 2005/02/13 - 12:38오전
struct bootsector710 {
BYTE bsJump[3]; // jump inst E9xxxx or EBxx90
CHAR bsOEMName[8]; // OEM name and version
CHAR bsBPB[53]; // BIOS parameter block
CHAR bsExt[26]; // Bootsector Extension
CHAR bsBootCode[418]; // pad so structure is 512b
BYTE bsBootSectSig2; // 2 & 3 are only defined for FAT32?
BYTE bsBootSectSig3;
BYTE bsBootSectSig0; // boot sector signature byte 0x55
BYTE bsBootSectSig1; // boot sector signature byte 0xAA
#define BOOTSIG0 0x55
#define BOOTSIG1 0xaa
#define BOOTSIG2 0
#define BOOTSIG3 0
};
// BPB for DOS 7.10 (FAT32)
// This one has a few extensions to bpb50.
struct bpb710 {
WORD bpbBytesPerSec; // bytes per sector
BYTE bpbSecPerClust; // sectors per cluster
WORD bpbResSectors; // number of reserved sectors
BYTE bpbFATs; // number of FATs
WORD bpbRootDirEnts; // number of root directory entries
WORD bpbSectors; // total number of sectors
BYTE bpbMedia; // media descriptor
WORD bpbFATsecs; // number of sectors per FAT
WORD bpbSecPerTrack; // sectors per track
WORD bpbHeads; // number of heads
DWORD bpbHiddenSecs; // # of hidden sectors
// 3.3 compat ends here
DWORD bpbHugeSectors; // # of sectors if bpbSectors == 0
// 5.0 compat ends here
DWORD bpbBigFATsecs;// like bpbFATsecs for FAT32
WORD bpbExtFlags; // extended flags:
#define FATNUM 0xf // mask for numbering active FAT
#define FATMIRROR 0x80 // FAT is mirrored (like it always was)
WORD bpbFSVers; // filesystem version
#define FSVERS 0 // currently only 0 is understood
DWORD bpbRootClust; // start cluster for root directory
WORD bpbFSInfo; // filesystem info structure sector
WORD bpbBackup; // backup boot sector
// There is a 12 byte filler here, but we ignore it
};
이러한 구조체가 있구요. 선언은
struct bpb710 *bpb;
로 하고,
bpb = (struct bpb710 *) ((struct bootsector710 *) SectorBuffer)->bsBPB;
이런 코드가 있습니다. 예제코드에서 찾아낸 부분인데요, 이렇게 하면 어떻게 한방에 구조체에 format 이 일정한
dump 된 byte 집합들을 넣어버릴수 있는건가요?
계속 쓰고는 있지만, 이해하기가 조금 힘드네요.
Forums:


Re: 어떤 데이터 구조를 구조체에 그대로 매핑하기...
제가 질문을 제대로 해석한건지는 모르겠지만,
넣어버린게 아니고 "가리키고" 있는 것이죠.
((struct bootsector710 *) SectorBuffer)->bsBPB에서 bsBPB의 첫바이트 주소를 bpb가 가지게 되는 것이죠.
구조체에서 필드의 주소가 어떻게 어드레싱 되는지 테스트 코드를 한번 짜보시고( printf("%x", &(x->m));), 구조체의 필드를 참조하는 오퍼레이션의 어셈블리 코드가 어떻게 생성되는지 확인해보세요 ^^
감사합니다.
#include <stdio.h> struct a { char a; char b[2]; char c[4]; char d[8]; }; int main(void) { char k[]="abcdefghijklmnop\0"; struct a *z; z = k; printf("%c\n",z->b[1]); }잘되네요. ^^ 감사합니다.
댓글 달기