회원가입 ID/PW 찾기

1) 지식 창고는 본인이 작성한 콘텐츠(팁/노하우/리소스/강좌 등)을 무료 혹은 가상화폐인 납포인트를 통해 공유하는 공간입니다.
2) 본인이 작성한 콘텐츠에 대해서만 지식 창고에 등록할 수 있으며, 저작권에 위배되는 콘텐츠는 사전경고 없이 삭제될 수 있습니다.
3) 콘텐츠 구매 및 첨부파일 다운로드는 회원그룹 '연구원' 이상 가능하오니, 경험치를 쌓아 진급한 후에 이용 부탁드립니다.
4) 무료 콘텐츠의 본문은 구매절차 없이 즉시 이용할 수 있으며, 판매 납포인트가 있는 콘텐츠는 구매 후 이용할 수 있습니다.
5) 콘텐츠 판매에 따른 납포인트 수익은 지정한 비율(50%)에 따라 판매자에게 지급하며, 납포인트 수익을 통해 진급을 빨리할 수 있습니다.
6) 구매 후 평가를 하면 구매 납포인트의 20%를 돌려 드립니다.

콘텐츠 수 1,041
판매자 아크마 판매 납포인트 무료 평점 0점 / 총 0명 참여
INTRODUCTION
The PIC16F87X family of microcontrollers has the ability
to write to their own program memory. This feature
allows a small bootloader program to receive and write
new firmware into memory. This application note
explains how this can be implemented and discusses
the features that may be desirable.
In its most simple form, the bootloader starts the user
code running, unless it finds that new firmware should
be downloaded. If there is new firmware to be downloaded,
it gets the data and writes it into program memory.
There are many variations and additional features
that can be added to improve reliability and simplify the
use of the bootloader, some of which are discussed in
this application note.
The general operation of a bootloader is discussed in
the OPERATION section. Appendix A contains assembly
code for a bootloader developed for the PIC16F877
and key aspects of this bootloader are described in the
IMPLEMENTATION section.
For the purpose of this application note, the term “boot
code” refers to the bootloader code that remains permanently
in the microcontroller and the term “user
code” refers to the user’s firmware written into FLASH
memory by the boot code.
FEATURES
The more common features a bootloader may have are
listed below:
• Code at the Reset location.
• Code elsewhere in a small area of memory.
• Checks to see if the user wants new user code to
be loaded.
• Starts execution of the user code if no new user
code is to be loaded.
• Receives new user code via a communication
channel if code is to be loaded.
• Programs the new user code into memory.
OPERATION
The boot code begins by checking to see if there is new
user code to be downloaded. If not, it starts running the
existing user code. If there is new user code to be
downloaded, the boot code receives and writes the
data into program memory. There are many ways that
this can be done, as well as many ways to ensure reliability
and ease of use.
Integrating User Code and Boot Code
The boot code almost always uses the Reset location
and some additional program memory. It is a simple
piece of code that does not need to use interrupts;
therefore, the user code can use the normal interrupt
vector at 0x0004. The boot code must avoid using the
interrupt vector, so it should have a program branch in
the address range 0x0000 to 0x0003.
The boot code must be programmed into memory
using conventional programming techniques, and the
configuration bits must be programmed at this time.
The boot code is unable to access the configuration
bits, since they are not mapped into the program memory
space. Setting the configuration bits is discussed in
the next section.
In order for the boot code to begin executing the user
code, it must know where the code starts. Since the
boot code starts at the Reset vector, the user code cannot
start at this location. There are two methods for
placing the starting point of the user code.
One method is to use an ORG directive to force the user
code to start at a known location, other than the Reset
vector. To start executing the user code, the boot code
must branch to this fixed location, and the user code
must always use this same location as its start address.
An alternative method is to start the user code at the
normal Reset vector and require that the user code has
a goto instruction in the first four instructions to avoid
the interrupt vector. These four instructions can then be
relocated by the boot code and programmed into the
area of program memory used by the boot code. This
simplifies the development of code for use with the
bootloader, since the user code will run when programmed
directly into the chip without the boot code
present. The boot code must take care of paging and
banking so the normal Reset conditions apply before
executing the relocated code.

모르는 것이 무엇인지 스스로 정리하고 질문하는 습관을 가집시다.
무성의/광범위하거나 직접 해보지 않고 올리는 질문은 서로를 피곤하게 합니다.
질문쪽지는 사절이오니 게시판에 글을 남겨주세요. 그래야 다같이 공유할 수 있으니까요.

첨부

profile
초보태공 2008.10.10 11:42
부트로더 구현에 성공하셨나요?
profile
시나브로69 2017.06.24 16:42
좋은 자료 감사합니다.
search
List of Articles
번호 분류 제목 평점 포인트 판매자 등록일 구매수 조회 수
공지 공공의 목적으로 공유하고자 하는 소프트웨어는 '소프트웨어 자료실'에 업로드를 요청드립니다.
공지 구매후 평점 댓글을 남겨주시면 구매포인트의 20%를 돌려드립니다.
521 마이크로프로세서 케일 사용설명서 [10] 무료 silvertac 2009-11-12 0 4758
520 마이크로프로세서 STM32 USART (interrupt mode) Example [10] 무료 아크마 2009-11-10 0 8878
519 마이크로프로세서 STM32 LED ON/OFF 예제 [10] 무료 아크마 2009-11-10 0 5706
518 마이크로프로세서 FAD을 이용한 전자계산기 만들기 [4] 무료 gbaby 2009-11-08 0 6417
517 마이크로프로세서 7부 DAC사용하기 [15] 무료 jh2gle 2009-11-07 0 4954
516 마이크로프로세서 6부 ADC 사용하기 [13] 무료 jh2gle 2009-11-07 0 4464
515 마이크로프로세서 5부 GAL 사용하기 [13] 무료 jh2gle 2009-11-07 0 3098
514 마이크로프로세서 4부 타이머로 초시계 만들기 [11] 무료 jh2gle 2009-11-07 0 4851
513 마이크로프로세서 3부 FND 구동하기 [11] 무료 jh2gle 2009-11-07 0 3729
512 마이크로프로세서 2부 8051컴파일러 [13] 무료 jh2gle 2009-11-07 0 4424
511 마이크로프로세서 1부 8051 var이란? [12] 무료 jh2gle 2009-11-07 0 4292
510 마이크로프로세서 iar-w 8051프로그램 작성하는곳 [4] 무료 jh2gle 2009-11-07 0 3348
509 마이크로프로세서 c51입니다%^^ [1] 무료 kjs85179 2009-11-05 0 4079
508 마이크로프로세서 대형 FND시계 소스(헥사파일)입니다. [2] 무료 송송양파 2009-11-03 0 6294
507 마이크로프로세서 대형 FND시계 회로도입니다. [3] 무료 송송양파 2009-11-03 0 8164
506 마이크로프로세서 smm-31515 데이터시트 [2] 무료 송송양파 2009-11-03 0 3866
505 펌웨어 & 코딩언어 C#에 관한 글텝은 없나여?? [3] 무료 전국대표이사 2009-11-02 0 1431
504 마이크로프로세서 avr 아날로그 비교기 [26] 무료 나임 2009-11-02 0 6427
503 마이크로프로세서 FriendlyARM English User Manual [2] 무료 아크마 2009-11-02 0 3773
502 마이크로프로세서 MSP430F471X6, MSP430F471X7 code examples [3] 무료 아크마 2009-11-02 0 2836
  • 시간엄수는 군주의 예절이다.
    - 루이 18세
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.