지풍@blog

지풍@blog RSS

This is a simplified model of TCP/IP over Ethernet behaviour of a single TCP connection intended to provide insight into throughput limitations of TCP/IP due to network transit latency. In the model, TCP/IP sends the maximum TCP receive window size worth of application data (filling the maximum possible receive buffer), then waits for a single acknowledgement for the entire max. window size burst. The model also assumes that the instant the acknowledgement is sent, the data is emptied from the receive buffer and the entire window size is again fully available.

Analysis assumes no lost data (no retransmits are required, no delay associated with retransmit timer waits & no ACK timer waits); All datagrams sent are maximum size; No allowance for TCP slow start algorithm delay; This results in an upper bound style result. Bear in mind that this simulates the performance of a single application, not an aggregate usage model of multiple simultaneous users on a network. Furthermore, at the upper limit of TCP performance the model assumes that computer hardware and network equipment can sustain the peak TCP allowed data rates.


In Basic TCP, the maximum number of bytes that can be in transit (specified by the TCP receive window size) is limited to 64KB by the 16 bit window size in the TCP header. Often the 64KB value is used to illustrate the maximum theoretical throughput of TCP. This is only partially true. In the early 1990s Van Jacobsen et Al. recognized that higher bandwidths were becoming available and that TCP needed to be updated to support high bandwidth, high latency networks. The work culminated in 1992 with the publication of RFC1323 which specified modifications to TCP to support the high bandwidth, high latency networks. This removed the 64 KB limit, in theory.

In practise, most TCP stacks do not support RFC 1323 extensions and still have a maximum TCP window size on the order of 8 KB. An example is Microsoft TCP/IP v.2.0 used in Windows NT. It has a 8760 Byte maximum receive window. Windows 2000, while supporting RFC 1323 extensions, by default has a maximum receive window of 17520 Bytes. To enable the RFC1323 extensions in Windows 2000, registry entries must be manually adjusted.

   

Select Line Rate : Gigabit Ethernet

   

Custom TCP Receive Window (for best perf. Use even multiples of 1460) : 65536 Bytes

   

Gigabit Ethernet

  

  

  

  

Round Trip Latency (2T)

Maximum User Data Throughput (64KB Window)

Maximum User Data Throughput (WinNT)

Maximum User Data Throughput (Win2K)

Maximum User Data Throughput (Custom)

0.1 mS

803,755 Kbps

403,166 Kbps

565,965 Kbps

803,755 Kbps

0.2 mS

696,915 Kbps

255,931 Kbps

403,166 Kbps

696,915 Kbps

0.4 mS

550,550 Kbps

147,903 Kbps

255,931 Kbps

550,550 Kbps

0.6 mS

454,993 Kbps

104,003 Kbps

187,468 Kbps

454,993 Kbps

0.8 mS

387,702 Kbps

80,199 Kbps

147,903 Kbps

387,702 Kbps

1 mS

337,750 Kbps

65,262 Kbps

122,128 Kbps

337,750 Kbps

2 mS

205,418 Kbps

33,793 Kbps

65,262 Kbps

205,418 Kbps

3 mS

147,591 Kbps

22,799 Kbps

44,528 Kbps

147,591 Kbps

4 mS

115,170 Kbps

17,203 Kbps

33,793 Kbps

115,170 Kbps

5 mS

94,427 Kbps

13,812 Kbps

27,228 Kbps

94,427 Kbps

6 mS

80,016 Kbps

11,538 Kbps

22,799 Kbps

80,016 Kbps

7 mS

69,421 Kbps

9,907 Kbps

19,609 Kbps

69,421 Kbps

8 mS

61,304 Kbps

8,680 Kbps

17,203 Kbps

61,304 Kbps

9 mS

54,886 Kbps

7,723 Kbps

15,322 Kbps

54,886 Kbps

10 mS

49,685 Kbps

6,957 Kbps

13,812 Kbps

49,685 Kbps

20 mS

25,510 Kbps

3,491 Kbps

6,957 Kbps

25,510 Kbps

30 mS

17,160 Kbps

2,330 Kbps

4,649 Kbps

17,160 Kbps

40 mS

12,929 Kbps

1,749 Kbps

3,491 Kbps

12,929 Kbps

50 mS

10,371 Kbps

1,400 Kbps

2,795 Kbps

10,371 Kbps

60 mS

8,658 Kbps

1,167 Kbps

2,330 Kbps

8,658 Kbps

70 mS

7,431 Kbps

1,000 Kbps

1,998 Kbps

7,431 Kbps

80 mS

6,509 Kbps

875 Kbps

1,749 Kbps

6,509 Kbps

90 mS

5,790 Kbps

778 Kbps

1,555 Kbps

5,790 Kbps

100 mS

5,214 Kbps

700 Kbps

1,400 Kbps

5,214 Kbps

110 mS

4,742 Kbps

637 Kbps

1,272 Kbps

4,742 Kbps

120 mS

4,349 Kbps

584 Kbps

1,167 Kbps

4,349 Kbps

130 mS

4,016 Kbps

539 Kbps

1,077 Kbps

4,016 Kbps

140 mS

3,730 Kbps

500 Kbps

1,000 Kbps

3,730 Kbps

150 mS

3,482 Kbps

467 Kbps

933 Kbps

3,482 Kbps

160 mS

3,266 Kbps

438 Kbps

875 Kbps

3,266 Kbps

170 mS

3,074 Kbps

412 Kbps

824 Kbps

3,074 Kbps

180 mS

2,904 Kbps

389 Kbps

778 Kbps

2,904 Kbps

190 mS

2,751 Kbps

369 Kbps

737 Kbps

2,751 Kbps

200 mS

2,614 Kbps

350 Kbps

700 Kbps

2,614 Kbps

210 mS

2,490 Kbps

334 Kbps

667 Kbps

2,490 Kbps

220 mS

2,377 Kbps

318 Kbps

637 Kbps

2,377 Kbps

230 mS

2,274 Kbps

305 Kbps

609 Kbps

2,274 Kbps

240 mS

2,180 Kbps

292 Kbps

584 Kbps

2,180 Kbps

250 mS

2,093 Kbps

280 Kbps

560 Kbps

2,093 Kbps

260 mS

2,012 Kbps

269 Kbps

539 Kbps

2,012 Kbps

270 mS

1,938 Kbps

259 Kbps

519 Kbps

1,938 Kbps

280 mS

1,869 Kbps

250 Kbps

500 Kbps

1,869 Kbps

290 mS

1,804 Kbps

242 Kbps

483 Kbps

1,804 Kbps

300 mS

1,744 Kbps

234 Kbps

467 Kbps

1,744 Kbps

310 mS

1,688 Kbps

226 Kbps

452 Kbps

1,688 Kbps

320 mS

1,636 Kbps

219 Kbps

438 Kbps

1,636 Kbps

330 mS

1,586 Kbps

212 Kbps

425 Kbps

1,586 Kbps

340 mS

1,540 Kbps

206 Kbps

412 Kbps

1,540 Kbps

350 mS

1,496 Kbps

200 Kbps

400 Kbps

1,496 Kbps

360 mS

1,454 Kbps

195 Kbps

389 Kbps

1,454 Kbps

370 mS

1,415 Kbps

189 Kbps

379 Kbps

1,415 Kbps

380 mS

1,378 Kbps

184 Kbps

369 Kbps

1,378 Kbps

390 mS

1,342 Kbps

180 Kbps

359 Kbps

1,342 Kbps

400 mS

1,309 Kbps

175 Kbps

350 Kbps

1,309 Kbps

410 mS

1,277 Kbps

171 Kbps

342 Kbps

1,277 Kbps

420 mS

1,247 Kbps

167 Kbps

334 Kbps

1,247 Kbps

430 mS

1,218 Kbps

163 Kbps

326 Kbps

1,218 Kbps

440 mS

1,190 Kbps

159 Kbps

318 Kbps

1,190 Kbps

450 mS

1,164 Kbps

156 Kbps

311 Kbps

1,164 Kbps

460 mS

1,138 Kbps

152 Kbps

305 Kbps

1,138 Kbps

470 mS

1,114 Kbps

149 Kbps

298 Kbps

1,114 Kbps

480 mS

1,091 Kbps

146 Kbps

292 Kbps

1,091 Kbps

490 mS

1,069 Kbps

143 Kbps

286 Kbps

1,069 Kbps

500 mS

1,047 Kbps

140 Kbps

280 Kbps

1,047 Kbps

   

Data:

Ethernet Frame Size : 1518 Bytes

Ethernet Preamble : 8 Bytes

Interframe Gap : 12 Bytes

Total Inter-Frame Time : 1538 Bytes

Ethernet Overhead : 38 Bytes

Ethernet Data : 1500 Bytes

IP Datagram Overhead : 20 Bytes

TCP Datagram Overhead : 20 Bytes

Maximum User Data per Ethernet Frame : 1460 Bytes


Line Rate

Ethernet 10000000 10000000

Fast Ethernet 100000000 100000000

Gigabit Ethernet 1000000000 1000000000

   

Maximum TCP Receive Window : 65536 Bytes

Maximum Windows NT TCP Receive Window (on Ethernet) : 8760 Bytes

Maximum Windows 2000 TCP Receive Window : 17520 Bytes

   

Application Throughput:

Application Data Size/(Ethernet Serialization Delay + Round Trip Latency)

   

출처 : http://www.babinszki.com/Networking/Max-Ethernet-and-TCP-Throughput.html

사용자 삽입 이미지
비스타에서 한글 2007을 설치 하고 hwp 파일을 마우스 오른쪽 버튼으로 클릭하면 위와 같이 나옵니다

상당히 보기도 지저분하고 저 메뉴를 클릭 해도 아래와 같이 실행도 안 되고 자동 업데이트를 해도 해결 되지 않습니다
사용자 삽입 이미지

해결 방법은 레지스트리 편집기로 잘못된 키값을 지워 주면 깨끗이 해결됩니다
사용자 삽입 이미지
HKEY_LOCAL_MACHINE\SOFTWARE\Classes\Hwp.Document.7\shell\DefaultIcon

위 키값을 지워 주면 아래와 같이 해결됩니다

사용자 삽입 이미지

redhat 계열에서는(redhat, Fedora, Red Hat Enterprise Linux, CentOS등) 해당하는 배포판의 버전을 /etc/redhat-release에 해당하는 배포판의 버전이 있습니다

간혹 하위 버전의 배포판으로 만들어진 소스가 상위 버전의 배포판에서도 컴파일이 되지만

지원하지 않는 배포판이라고 컴파일이 안 될 경우에는 이 파일에 해당하는 하위 버전의 배포판으로 변경해 주면 됩니다

참고로 아래는 자주 쓰는 redhat 9 이랑 Fedora에서 redhat-release입니다

Fedora Core release 1 (Yarrow)
Fedora Core release 2 (Tettnang)
Fedora Core release 3 (Heidelberg)
Fedora Core release 4 (Stentz)
Fedora Core release 5 (Bordeaux)
Fedora Core release 6 (Zod)
Fedora Core release 7 (Moonshine)
Red Hat Linux release 9 (Shrike)

사용자 삽입 이미지

위 사진처럼 윈도우 업데이트시 폰트 크기가 커져 버려서 확인버튼이 나오지 않은 경우에는

<Alt> + A 키를 눌러서 확인을 강제로 누르게해서 다음으로 넘어 갈수 있습니다

사용자 삽입 이미지
인텔의 서버 프로세서 브랜드명은 Xeon(제온)이다.

Xeon은 다시 두가지 종류의 프로세스로 구분이 되는데, DP와 MP이다.
DP는 Dual Processor, MP는 Multi Processor의 약자이다.

1. Intel Xeon Processor (Paxvile DP)
90나노미터 공정의 프로세서로 Dual-Core Xeon Processor이다. HT(HyperThread)를 지원하므로 1CPU 한개당 4개(Dual-Core *  HT)의 Thread를 처리할 수 있으며, Lindenhurst Chipset기반에서 작동이 된다.

- Dempsy (뎀시)
65나노미터 공정의 프로세서

- Sossaman (소싸만)
초 저전력 프로세서로서 Yohna(모바일 프로세서)기반으로 31W의 저전력 프로세서

- Woodcrest (우드크레스트)
Core microarchitecture를 채택한 프로세서로, 일반 모델과 저전력 모델(LV)모델이 있다. LV 모델의 경우 소비전력은 40W로 초 저전력 서버 프로세서이다. 얼마전 시장에 나왔다.

- Clovertown (클로버타운)
Core microarchitechure기반의 Quad-Core 프로세서이다. Bensley 플랫폼의 일환으로 공급될 것이며 2007년 1분기에 출시 예정인 프로세서다.

2. Intel Xeon Processor MP (Paxville MP)
4 CPU 이상을 지원하는 Dual-Core Xeon Processor 명으로 Truland 플랫폼 기반으로 제공된다.

- Tulsa (툴사)
65나노미터공정 Dual-Core 기반의 프로세서로 16MB의 대용량 L3 캐시 메모리를 탑재한 서버 프로세서이다. 이 프로세서는 인텔의 가상화 기술과 캐쉬 메모리 보호 기술인 Pellston 기술을 채용하여 미션 크리티컬한 업무에 사용되는 고가용성 프로세서이다.

- Tigerton (타이거톤)
65나노미터공정의 Caneland 플랫폼에서 채택될 프로세서로, Core microarchitecture의 초고속 채널 연결 기술을 사용할 프로세서이다 출시는 2007년으로 예상

- Dunnington (더닝톤)
Tigerton을 잇는 프로세서로 2008년 출시 예정인 프로세서이다.

* 플랫폼 명칭 설명
- Bensley (벤슬리) : Intel Xeon DP
- Truland (트루랜드) : Intel Xeon MP
- Caneland (케인랜드) : 향후 MP 시리즈 플랫폼


출처 : http://cusee.net/2460475

C/C++의 Data Type 입니다. 그런데 이것은 OS나 컴파일러에 따라서 차이가 있을 수 있습니다. 가령 16비트OS에서 int 는 16비트이고, 32비트OS에서 int 는 32비트입니다. 여기서는 일반적으로 가장 널리 쓰이는 "비주얼C++ (32비트 버전)"를 기준으로 한 것입니다.

정수 자료형

▶ char, unsigned char          1 byte (8비트)
------------------------------------------------------
char 의 최소값: -128
char 의 최대값: 127

unsigned char 의 최소값: 0
unsigned char 의 최대값: 255 (0xff)


▶ short, unsigned short        2 bytes (16비트)
------------------------------------------------------
short 의 최소값: -32768
short 의 최대값: 32767

unsigned short 의 최소값: 0
unsigned short 의 최대값: 65535 (0xffff)


▶ wchar_t 또는 __wchar_t       2 bytes (16비트)
------------------------------------------------------
wchar_t 의 최소값: 0
wchar_t 의 최대값: 65535

※ wchar_t 는 유니코드 글자 1개를 저장합니다. "unsigned short"과 동일.


▶ int, unsigned int            4 bytes (32비트)
------------------------------------------------------
int 의 최소값: -2147483648
int 의 최대값: 2147483647

unsigned int의 최소값: 0
unsigned int의 최대값: 4294967295 (0xffffffff)


▶ long, unsigned long          4 bytes (32비트)
------------------------------------------------------
long 의 최소값: -2147483648L
long 의 최대값: 2147483647L

unsigned long 의 최소값: 0UL
unsigned long 의 최대값: 4294967295UL (0xffffffffUL)

※ 32비트OS에서의 long 은 int 와 동일


▶__int64 또는 long long        8 bytes (64비트)
------------------------------------------------------
__int64 의 최소값: -9223372036854775808i64
__int64 의 최대값: 9223372036854775807i64

unsigned __int64 의 최소값: 0ui64
unsigned __int64 의 최대값: 18446744073709551615ui64 (0xffffffffffffffffui64)


실수 자료형

▶ float                        4 bytes (32비트)
------------------------------------------------------
가장 작은 양수: 1.175494351e-38F
가장 큰 양수  : 3.402823466e+38F


▶ double                       8 bytes (64비트)
------------------------------------------------------
가장 작은 양수: 2.2250738585072014e-308
가장 큰 양수  : 1.7976931348623158e+308


▶ long double                  8 bytes (64비트)
------------------------------------------------------
double 과 같음.


 출처 : http://mwultong.blogspot.com/2006/09/c-char-int-float-data-type-ranges.html

리눅스 부팅 프로세스 연구 (한글)
Master Boot Record 부터 사용자 공간 애플리케이션 까지 부팅 가이드

난이도 : 초급

M. Tim Jones, Consultant Engineer, Emulex

2006 년 8 월 18 일

리눅스® 시스템의 부팅 과정은 많은 단계들을 거칩니다. 표준 x86 데스크탑을 부팅하든 아니면 PowerPC®를 부팅하든 그 단계는 놀랍게도 많이 비슷합니다. 이 글에서는 리눅스 부팅 과정을 초기 부트스트랩부터 첫 번째 사용자 애플리케이션의 시작 단계 까지 설명합니다. 아울러 부트 로더, 커널 디컴프레션(decompression), 초기 RAM 디스크, 기타 리눅스 부트 엘리먼트를 설명합니다.

초기에 컴퓨터를 부트스트랩(bootstrapping) 한다고 하면 부트 프로그램이 포함된 종이 테이프를 공급하거나 프론트 패널 address/data/control 스위치를 사용하여 부트 프로그램을 직접 로딩하는 것을 의미했다. 오늘날 컴퓨터에는 부팅 과정을 단순화시키는 장치들이 장착되어 있지만 꼭 그렇게 단순한 것 같지는 않다.

리눅스 부팅 과정을 보다 높은 시각에서 조망해야지만 전체적으로 볼 수 있다. 그런 다음 각각의 단계를 자세히 살펴봐야겠다. 곳곳에 첨부한 소스 자료가 커널 트리를 연구하는데 도움이 될 것이다.


개요

그림 1은 리눅스 부트 프로세스 개요도이다.

사용자 삽입 이미지

시스템이 처음 부팅되거나 리셋되면 프로세서는 잘 알려진 위치에 코드를 실행한다. PC의 경우, basic input/output system (BIOS)이다. 이것은 마더보드의 플래시 메모리에 저장된다. 임베디드 시스템에 있는 CPU는 리셋 벡터를 호출하여 플래시/ROM의 알려진 주소에서 프로그램을 시작한다. 두 경우 모두 결과는 같다. PC가 훨씬 유연하고, BIOS는 어떤 장치들이 부팅 후보인지를 결정해야 한다.

부팅 장치를 찾으면 첫 번째 단계 부트 로더는 RAM으로 로딩되어 실행된다. 이 부트 로더는 길이는 512 바이트 미만이고 하는 일은 두 번째 단계의 부트 로더를 로딩하는 것이다.

제 2 단계 부트 로더가 RAM에 있고 실행되면 스플래시 스크린이 디스플레이 되고 리눅스와 초기 RAM 디스크 옵션(임시 루트 파일 시스템)이 메모리에 로딩된다. 이미지가 로딩될 때 2 단계 부트 로더는 제어를 커널 이미지로 전달하고 커널은 압축이 해제되어 초기화 된다. 이 때 2 단계 부트 로더는 시스템 하드웨어를 검사하고 첨부된 하드웨어 장치들을 열거하고, 루트 장치를 마운트 하고 필요한 커널 모듈을 로딩한다. 완료되면 첫 번째 사용자-공간 프로그램(init)이 시작되고 고급 시스템 초기화가 이루어진다.

여기까지가 리눅스 부팅 과정을 간략하게 묘사한 것이다. 이제 리눅스 부팅 과정을 보다 자세하게 살펴보도록 하자.


시스템 시작

시스템 시작 단계는 리눅스가 부팅되는 하드웨어에 기반하고 있다. 임베디드 플랫폼에서, 부트스트랩 환경은 시스템이 켜지거나 리셋될 때 사용된다. U-Boot, RedBoot, MicroMonitor 등이 그 예이다. 임베디드 플랫폼에는 일반적으로 부트 모니터가 장착된다. 이 프로그램들은 목표 하드웨어의 플래시 메모리의 특별한 영역에 있고 리눅스 커널 이미지를 플래시 메모리로 다운로드 하는 방식을 제공하고 이를 실행한다. 리눅스 이미지를 저장하고 부팅하는 기능 외에도 이 부트 모니터는 시스템 테스트와 하드웨어 초기화를 수행한다. 임베디드 환경에서 이러한 부트 모니터들은 제 1 부트 로더와 제 2 부트 로더를 관장한다.

MBR 추출하기

MBR의 내용을 보려면 다음 명령어를 사용한다:

# dd if=/dev/hda of=mbr.bin bs=512 count=1
# od -xa mbr.bin
루트에서 실행되어야 하는 dd 명령어는 /dev/hda (첫 번째 Integrated Drive Electronics, IDE 드라이브)에서 512 바이트를 읽고 이를 mbr.bin 파일에 작성한다. od 명령어는 16진수와 ASCII 포맷으로 바이너리 파일을 프린트한다.

PC에서 리눅스 부팅은 BIOS에서 주소 0xFFFF0로 시작된다. BIOS의 첫 번째 단계는 POST (power-on self test)이다. POST가 하는 일은 하드웨어를 검사하는 것이다. BIOS의 두 번째 단계는 로컬 장치 열거(enumeration)와 초기화이다.

BIOS 기능에 따라 사용처도 다르며, BIOS는 두 부분으로 구성된다. POST 코드와 런타임 서비스이다. POST가 완료된 후에 이것은 메모리에서 플러시(flush)되지만 BIOS 런타임 서비스는 그대로 남아있고 해당 운영 체계에서 사용할 수 있다.

운영 체계를 부팅하기 위해서 BIOS 런타임은 complementary metal oxide semiconductor (CMOS)에서 정의된 선호도 순으로 활성화 되고 부팅 가능한 장치를 찾는다. 부트 장치는 플로피 디스크, CD-ROM, 하드 디스크 파티션, 네트워크 상의 장치, USB 플래시 메모리 스틱이 될 수도 있다.

일반적으로 리눅스는 하드 디스크에서 부팅되고, Master Boot Record (MBR)에는 주 부트 로더가 포함되어 있다. MBR은 512-바이트 섹터이고 디스크의 첫 번째 섹터(sector 1 of cylinder 0, head 0)에 위치해 있다. MBR이 RAM이 로딩된 후에 BIOS는 제어권을 여기에 넘겨준다.


Stage 1 부트 로더

MBR에 있는 주 부트 로더는 512-바이트 이미지로서 프로그램 코드와 작은 파티션 테이블이 포함되어 있다. (그림 2) 첫 번째 446 바이트는 주 부트 로더이고 여기에는 실행 코드와 에러 메시지 텍스트가 포함된다. 그 다음 64 바이트는 파티션 테이블인데, 네 개의 파티션(각 16 바이트)의 레코드가 포함되어 있다. MBR은 매직 넘버(0xAA55)로 정의된 2 바이트로 끝난다. 매직 넘버는 MBR의 밸리데이션에 사용된다.

사용자 삽입 이미지

주 부트 로더의 작업은 2차 부트 로더(stage 2)를 찾아 로딩하는 것이다. 액티브 파티션을 찾기 위해 파티션 테이블을 검사한다. 액티브 파티션을 찾으면 테이블에 남아있는 파티션들을 검사하여 이들이 모두 비활성 상태인지를 확인한다. 확인이 되면 액티브 파티션의 부트 레코드는 장치에서 RAM으로 읽혀지고 실행된다.


Stage 2 부트 로더

2차 또는 제 2 단계 부트 로더는 커널 로더라고 불린다. 이 단계에서의 작업은 리눅스 커널과 선택적인 초기 RAM 디스크를 로딩하는 것이다.

GRUB stage 부트 로더

/boot/grub 디렉토리에는 stage1, stage1.5, stage2 부트 로더들 뿐만 아니라 대안 로더들(예를 들어, CR-ROM은 iso9660_stage_1_5를 사용한다.)이 있다.


주/부 부트 로더의 결합은 x86 PC 환경에서 Linux Loader (LILO) 또는 GRand Unified Bootloader (GRUB)이라고 한다. LILO는 몇 가지 단점을 갖고 있고 GRUB이 이를 수정했으므로 GRUB을 살펴보도록 하자. (GRUB과 LILO에 대한 자세한 내용은 참고자료를 참조하라.)

GRUB의 좋은 점은 리눅스 파일 시스템을 알고 있다는 점이다. LILO 처럼 디스크 상의 미가공 섹터를 사용하는 대신 GRUB은 ext2 또는 ext3 파일 시스템에서 리눅스 커널을 로딩할 수 있다. 2 단계 부트 로더를 3 단계 부트 로더로 만든다. Stage 1 (MBR)은 리눅스 커널 이미지를 포함하고 있는 특정 파일 시스템을 알고 있는 stage 1.5 부트 로더를 부팅한다. reiserfs_stage1_5 (Reiser 저널링 파일 시스템에서 로딩함) 또는 e2fs_stage1_5 (ext2 또는 ext3 파일 시스템에서 로딩함)가 좋은 예이다. stage 1.5 부트 로더가 로딩 및 실행되면 stage 2 부트 로더가 로딩될 수 있다.

stage 2가 로딩되면서 GRUB은 사용 할 수 있는 커널 리스트를 디스플레이 한다. (/etc/grub.conf에서 정의됨. /etc/grub/menu.lst 와 /etc/grub.conf의 링크 포함). 여러분은 커널을 선택하고 추가 커널 매개변수로 이를 수정할 수도 있다. 부트 프로세스에 보다 직접적인 관여를 하려면 명령행 쉘을 사용할 수도 있다.

Stage 2 부트 로더가 메모리에 있는 상태에서 파일 시스템이 참조되고 디폴트 커널 이미지와 initrd이미지가 메모리로 로딩된다. 이미지가 준비되면 stage 2 부트 로더는 커널 이미지를 호출한다.


커널

커널 이미지가 메모리에 있고 stage 2 부트 로더에서 컨트롤도 넘어왔다면 커널 단계가 시작된다. 커널 이미지는 실행 커널은 아니고 다만 압축된 커널 이미지이다. 일반적으로 이것은 zImage (압축 이미지, 512KB이하) 또는 bzImage (큰 압축 이미지, 512KB 이상)이고 이들은 이전에 zlib로 압축된 것이다. 커널 이미지의 앞에 있는 루틴은 최소한의 하드웨어 설정을 수행한 다음 커널 이미지에 포함된 커널의 압축을 풀고 이를 큰 메모리에 둔다. 초기 RAM 디스크 이미지가 있다면 이 루틴은 이것을 메모리로 옮기고 기록해 둔다. 루틴은 커널을 호출하고 커널 부팅이 시작된다.

bzImage (i386 이미지 용)가 호출되면 start 어셈블리 루틴(그림 3의 주 흐름도 참조)의 ./arch/i386/boot/head.S에서 시작한다. 이 루틴은 기본적인 하드웨어 설정을 수행하고 ./arch/i386/boot/compressed/head.S에 있는 startup_32 루틴을 호출한다. 이 루틴은 기본 환경(스택 같은)을 설정하고 Block Started by Symbol (BSS)을 청소한다. 커널은 decompress_kernel (./arch/i386/boot/compressed/misc.c에 있음)이라고 하는 C 함수를 호출하여 압축이 풀린다.

새로운 startup_32 함수(swapper 또는 process 0)에서, 페이지 테이블이 초기화되고 메모리 페이징이 실행된다. CPU 유형이 검사되고 아울러 FPU (floating-point unit)도 검사된다. start_kernel 함수가 호출되면(init/main.c) 일반(non-architecture specific) 리눅스 커널이 된다.

GRUB의 수동 부팅

GRUB 명령행에서 initrd이미지로 특정 커널을 부팅할 수 있다:
 

grub> kernel /bzImage-2.6.14.2

   [Linux-bzImage, setup=0x1400, size=0x29672e]


grub> initrd /initrd-2.6.14.2.img

   [Linux-initrd @ 0x5f13000, 0xcc199 bytes]


grub> boot


Uncompressing Linux... Ok, booting the kernel.

부팅 할 커널 이름을 모르겠다면 포워드 슬래시(/)를 치고 탭 키를 누른다. 그러면 커널과 initrd 이미지 리스트가 디스플레이 된다.

사용자 삽입 이미지
start_kernel을 호출하면 초기화 함수의 긴 리스트가 호출되어 인터럽트를 설정하고 보다 구체적인 메모리 설정이 이루어지고 초기 RAM 디스크를 로딩한다. kernel_thread (arch/i386/kernel/process.c)를 호출하면 init 함수가 시작되는데 이는 최초의 사용자 공간 프로세스이다. 마지막으로 유휴 태스크가 시작되고 스케줄러가 주도권을 잡는다. (cpu_idle 호출 후). 인터럽트가 실행되면서 선점 스케줄러는 주기적으로 주도권을 잡아 멀티태스킹을 수행한다.

커널이 부팅되는 동안 stage 2 부트 로더에 의해 메모리로 로딩된 initial-RAM disk (initrd)가 RAM으로 복사 및 마운트 된다. initrd는 RAM에서 임시 루트 파일 시스템의 역할을 하고 커널이 물리적 디스크를 마운트 하지 않고도 완전히 부팅될 수 있도록 한다. 주변 기기와 인터페이싱 할 때 필요한 모듈이 initrd의 일부가 될 수 있기 때문에 커널은 매우 작아질 수 있지만 그래도 여전히 많은 하드웨어 설정들을 지원한다. 커널이 부팅된 후에 루트 파일 시스템이 (pivot_root를 통해) 회전되고 이곳에서 initrd 루트 파일 시스템이 언마운트(unmount)되어 실제 루트 파일 시스템이 마운트 된다.

decompress_kernel 아웃풋

decompress_kernel 함수를 통해서 일반적인 디컴프레션(decompression) 메시지를 볼 수 있다.
 

Uncompressing Linux... Ok, booting the kernel.


Init

커널이 부팅 및 초기화 된 후에 커널은 최초의 사용자 공간(user-space) 애플리케이션을 시작한다. 이것은 표준 C 라이브러리로 컴파일 된 첫 번째 프로그램이다. 이전에는 어떤 표준의 C 애플리케이션도 실행되지 않았다.

데스크탑 리눅스 시스템에서 시작된 첫 번째 애플리케이션은 일반적으로 /sbin/init이다. 하지만 꼭 이럴 필요는 없다. 임베디드 시스템은 init (/etc/inittab을 통해 설정됨)에서 제공하는 초기화를 거의 필요로 하지 않는다. 많은 경우에, 필요한 임베디드 애플리케이션을 시작하는 간단한 쉘 스크립트를 호출하곤 한다.


요약

리눅스가 그러하듯, 리눅스 부트 프로세스도 매우 유연하고 많은 프로세서와 하드웨어 플랫폼을 지원한다. 초기에는 loadlin 부트 로더가 있었다. LILO 부트 로더는 부팅 기능을 확장했지만 파일 시스템 인식 부분에서 부족했다. GRUB과 같은 최신 부트 로더가 생기면서 많은 파일 시스템(Minix 부터 Reiser 까지)에서 리눅스를 부팅할 수 있게 되었다.


필자소개

사용자 삽입 이미지
M. Tim Jones는 임베디드 소프트웨어 아키텍트이자 GNU/Linux Application Programming, AI Application Programming, BSD Sockets Programming from a Multilanguage Perspective의 저자이다. 정지 우주선용 커널 부터 임베디드 시스템 아키텍처, 네트워킹 프로토콜 개발에 이르기 까지 그의 커널 개발 범위는 광대하다. 그는 현재 콜로라도 롱몬트에 위치한 Emulex Corp의 컨설턴트 엔지니어이다.

출처 : http://www.ibm.com/developerworks/kr/library/l-linuxboot/index.html

구글 툴바를 사용시 주소창에 넣은 한글도메인을 기본적으로 검색하는 기능을 지원합니다

아래와 같이 "우리은행"을 입력시 우리은행 홈페이지로 들어 가는게 아니라 우리은행을 구글에서 검색하게 됩니다

사용자 삽입 이미지

한글도메인에 많이 적응하신 분에게는 상당히 귀찮은 부분인데 구글 툴바도 아래와 같은 설정을 하면 한글도메인이 가능합니다

사용자 삽입 이미지
구글툴바 설정으로 들어 간 다음

사용자 삽입 이미지

추가 옵션 - 검색 설정 알리미 및 바로찾기 - 주소표시줄에서 바로찾기 기능 활성화 를 체크하면 한글 도메인을 쓸수 있습니다

XMB 이란?

백과사전/컴퓨터 2007. 2. 28. 02:09 by 지풍

XMB란 Xross Media Bar의 약자로

PSP와 PS3에 채택된 십자가 형식의 메뉴의 인터페이스를 말하는 것이라고 하네요

아래는 PSP에서의 XMB 입니다

사용자 삽입 이미지

그리고 아래는 PS3에서의 XMB 입니다

사용자 삽입 이미지

최근에 노트북에 깔린 불법 프로그램들을 그 기능을 대신할 프리웨어로 바꾸는 프로젝트를 수행햇답니다

아크로벳을 Foxit Reader로 그리고 포토샵을 Paint.Net 으로

그런데 ACDSee를 대신할 이미지 뷰어를 찾을수가 없다군요

ACDSee 만큼 강력해야 하며 버전업은 충실히 되어 가며(죽은 프로그램이 아니여야 하며)

그리고 깔끔해야 한다는 것 이점을 모두 만족 하는 이미지 뷰어야 하는데

지금까지는 찾을수 없었는데 그 조건을 만족 하는 프로그램을 드디어~! 찾아 냈습니다

바로 XnView

버전업도 2007년 2월로 상당히 충실히 업데이트 되며 살아 있는 프로그램이고 그리고 물론~ 공짜지요

사용자 삽입 이미지

위와 같이 관리 프로그램도 존재 하며(저는 이런거는 별로 필요는 없는뎅...ㅠㅠ)

사용자 삽입 이미지

이렇게 뷰어도 같이 있답니다 물론 속도는 상당히 빠릅니다

인기 많았던 초기버전 ACDSee 만큼의 속도와 비슷한것 같습니다

단 한가지 아쉬운점은 아직 100%의 한글이 아니더군요 랭귀지팩이 약간 미숙한 점

또 설치시 기본으로 이미지 파일들의 뷰어로 이 프로그램이 지정이 안 된다는 점입니다

사용자가 설정에서 설정을 해줘야지 기본으로 설정 된답니다

그거만 빼면 상당히 좋은 프로그램 같습니다

공식 홈페이지는 http://www.xnview.com/ 입니다
1 2 3 
분류 전체보기 (202)
내가 사는 이야기 (2)
백과사전 (89)
컴퓨터 (26)
리눅스 (35)
안드로이드 (10)
돈 굴리기 (11)
이것저것 (7)
듣고 보는 것 (0)
세상 이야기 (1)
맛집 투어 & 여행 (0)
컴퓨터 이야기 (110)
게임 이야기 (0)
위시리스트 (0)
스포츠 이야기 (0)
영화 이야기 (0)
우하하하하 (0)

공지사항

최근에 올라온 글

최근에 달린 댓글

최근에 받은 트랙백