커널 오브젝트 커널 오브젝트란 커널에 의해 관리되는 리소스 정보를 담고있는 데이터 블록이다. 여기서 리소스란 운영체제에 의해서 생성 및 관리되고 소멸된다는 것이다. 예) 파일(리소스)에는 읽기전용 쓰기전용이 있는데, 이런 모드는 운영체제에 의해 관리된다. fopen(“test.txt” ,“r”); 위의 함수로 test 파일을 읽기 전용으로 열기를 시도했다. 운영체제는 저 파일을 찾아서 읽어 오려고 하는데 저 파일이 쓰기 전용이다. 그러면 운영체제에 의해서 읽어 오는것이 불가능하게 된다. 프로세스 기반 커널 오브젝트 (우선순위가 있다.) 프로세스가 생성될때 마다 아래 그림처럼 프로세스 관리 구조체 변수가 하나씩 생성되고, 새롭게 생성된 프로세스 정보들로 초기화되는데, 이것이 바로 커널오브젝트의 정체다. 그..
Direct 모드와 Indirect 모드 Direct 모드 명령어 구성의 문제점 변수 b가 담겨 있는 메모리 주소값 0x0100은 source의 8비트 공간에 담길 수 없다. 그래서 LOAD r2 0x0100 명령어는 표현이 불가능하다. (구성불가) 위와 같은 방법을 Direct 모드라고 하는데 , 이방법을 통해서는 메모리의 모든 영역에 대한 접근이 불가능하다. 왜냐면 Direct 모드로 메모리를 접근할 경우, 할당 된 비트 수 안에서 표현 가능한 범위의 메모리 영역만 접근이 가능하기 때문이다. 어떻게 해결해야 하나? Direct 모드와 Indirect 모드 표현 Indirect 모드 는 [ 0x10] 번지에 가서, 거기에 있는 주소값으로 이동해서 그 값을 레지스터 r1 으로로 이동시켜라. 제일 위에서 ..
Load * Store 명령어 디자인 레지스터 필요성에 초점을 맞춘다. 지금까지 구조는 모든 피연산자에는 메인 메모리의 주소값이 올 수 없다. (피연산자로 올 수 있는 것을 숫자와 레지스터로 제한 했기 때문에) 때문에 지금까지의 디자인으로 아래와 같은 연산을 할 수 없다. 위에서 마지막 줄 소스는 아래와 같이 바뀐다. ADD c a b = 더해라 / c의 메모리 주소에 저장히라 / a의 메모리 주소와/ b의 메모리주소를 지금까지 설계한 레지스터 구조에서는 위의 명령어가 불가능하다. 메모리 주소가 올 수 있는 공간이 없기 때문이다. 따라서 메인 메모리에 저장된 데이터를 레지스터로 일단 옮겨 놓은 다음에, 덧셈진행을 해야 한다. 그래서 레지스터와 메인 메모리 사이에서 데이터를 전송할 수 있는 명령어가 필요한..
컴퓨터 구조 프로그래머 관점 -컴퓨터 구조를 잘 아는 프로그래머도 컴퓨터 디자인에 참여 -컴퓨터 디자인은 레지스터와 명령어 디자인 레지스터 디자인의 핵심 - 레지스터는 몇 비트로 구성할 것인가? 일반적으로 N비트 시스템이라면 레지스터도 N비트다. 예) 32비트 시스템 = 레지스터 32비트 32비트 시스템에서 데이터의 최소 단위가 32비트이다. 그래서 레지스터도 데이터를 동일하게 32비트로 담는다. 예제에서는 16비트로 구성한다. - 몇 개 정도로 레지스터를 구성할 것인가? 많으면 많을 수록 좋다. 하지만 예제에서는 8개로 구성한다. -레지스터 각각을 무슨 용도로 사용할 것인가? 레지스터는 특별한 목적을 가지고 있는 저장장치다. 이처럼 목적과 용도를 정해 두면, 명령어가 단순해지고, 속도도 빨라진다. 예)..
Win32비트 Vs Win64비트 하드웨어 관점에서 Win32비트 Win64비트 구분 방법 -한번에 송수신 가능한 데이터 크기(BUS에 의존적이다.) -데이터 처리 능력 (CPU가 한번에 읽어 들일 수 있는 명령어 크기. 만약 16비트 데이터가 레지스터에 두개 있으면 32비트 일경우 한번에 패치 한다.) -cpu는 64비트로 처리하는데 bus가 32비트로 데이터를 이동한다면? 완벽한 64비트라고 할 수 없다. cpu , bus 둘다 일치해야 한다. 프로그래머 관점에서 32비트 Vs 64비트 32비트 시스템에서는 포인터는 32비트(4바이트) 이다. 64비트 시스템에서는 포인터는 64비트(8바이트) 이다. bus가 64비트 시스템에서 포인터를 32비트를 설정해서 프로그램을 만들었다면 bus는 주소를 어드레싱..
아스키 코드 & 유니코드 문자 집합의 종류와 특성 MBCS 기반에서 한글사용시 문제점 실제로는 문자 길이는 5인데, 출력된 문자열의 길이가 7이다. 실제 한글 한문자를 두 글자로 인식을 했다. 이부분이 한글을 사용하는데 문제가 될 수 있다. 숫자만 놓고 보면 되고 MBCS가 효율적인데, 메모리보다도 더 안정선을 중요시해서 유니코드를 사용한다. WBCS 기반의 프로그래밍 (유니코드를 위한 자료형) MBCS.cpp의 유니코드 버전 문자열 조작 함수 문자열 입출력 함수 매개변수 전달인자 유니코드화 MBCS와 WBCS 동시지원 참고 뇌를 자극하는 윈도우즈 시스템 프로그래밍 정리 - 한빛출판네트워크