회원가입 ID/PW 찾기
AA
질문할때는 다음 사항을 정확히 설명해주셔야 답변하시는 분도 최대한 정답에 가깝에 답할 수 있습니다.
----------------------------------------------------------------------------------------------------
| 1. 컴파일러, 에디터, 운영체제등 개발환경 :
| 2. 알고리즘, 소스코드의 개발목적 :
| 3. 에러증상과 예상되는 문제점 :
----------------------------------------------------------------------------------------------------

마이크로 프로세서 관련질문은 해당 게시판에 해주세요. 이 게시판은 프로그래밍 언어에 대한 질의 응답 게시판입니다.

 

안녕하세요~ 일단 인사부터 드리겠습니다.

가입인사드릴려 하는데 어디다가 쓰는 지를 모르겠네요..

저는 이번에 임베디드 개발 회사에 입사한  초짜 펌웨어 개발자 서정무 입니다.

닉넴은 짱무구요 ㅋ

어쨋든 마이컴 박스에 와서 선배님들께 많은 것을 배우고 도움도 받고

미천하나 제가 도움이 되어주고 싶어서 왔습니다. 앞으로 잘 부탁드리고 많이 배워가겠습니다.

이상 인사는 여기까지고요~

 

인제 펌웨어라는 것을 하게된지(아직 펌웨어라고 말하기도 어렵지만..) 4개월이 넘어가는 시점에서

프로젝트가 떨어졌는데.. 저의 실력으로는 도무지 해답이 안나와서 도움을 요청합니다.

그럼 질문의 대해 설명을 드리자면은요...

 

1. MIPS 32 USIP professor 을 사용하고 있습니다.

2. Linux (Ubuntu 8.04 )기반의 MAXIM 사의 Toolchain을 이용하여 사용하고 있습니다.

3. 간단한 (간단한거 같진 않은 데 ㅜㅡ) Pinpad용 단말기를 개발하고 있습니다.

4. 소스는 전에 사용하던 부트로더 소스를 이용하고 있습니다.

 

배경은 위와 같습니다. 현재 참고용 소스는 같은 칩을 쓰고 있는 카드 단말기 소스인데요. 이 소스는

부트로더 -> 커널 -> 어플 이런식으로 진행하기 위한 소스입니다.

근데 여기서 부트로더 소스만 가지고 개발하고 있습니다. 왜냐하면 Pinpad는 커널을 필요할 정도로

큰 시스템을 가질 필요가 없어서 부트단에서 바로 어플리케이션으로 점프를 하도록 개발할 예정입니다.

지금 개발 타겟은 칩내의 ROM, SRAM, FLASH, 외부 SRAM(512k), 외부 FALSH(8M)를 가지고 있습니다.

 

문제는 이제부터 입니다. 부트로더에서 처음 CPU를 초기화를 한 후에 칩셋들을 초기화 하는 과정에서

외부 SRAM을 사용하기 위해 UMC(USIP Memories Controler)에서 설정을 한 후에, 가상 메모리에 맵핑을 하였습니다.

그리고 잘 초기화가 되었는 지 외부 SRAM을 쓰고 읽기를 하면서 테스트를 하게 되었습니다. 헌데 여기서 문제가

발생을 하게 되었습니다. 자세한 소스는 아래와 같습니다.

 

//--------------------------------------------------------SRAM 상세 정보 --------------------------------------------------

 

/*
* SLOT2
*/
#undef CONFIG_SLOT2_DEV_NONE
#undef CONFIG_SLOT2_DEV_FLASH
#define CONFIG_SLOT2_DEV_SRAM 1 //슬롯 2번에 SRAM이 설정
#undef CONFIG_SLOT2_DEV_OTHERS
#undef CONFIG_SLOT2_DEV_AM29LV800B_70
#undef CONFIG_SLOT2_DEV_AM29LV800B_90
#undef CONFIG_SLOT2_DEV_AM29LV800B_120
#undef CONFIG_SLOT2_DEV_28F128J3C150
#undef CONFIG_SLOT2_DEV_28F256J3C125
#undef CONFIG_SLOT2_DEV_S29PL064J60
#undef CONFIG_SLOT2_DEV_S29PL032J70
#undef CONFIG_SLOT2_DEV_M29W320_70N6
#define CONFIG_SLOT2_DEV_CS18LV1024 1 //SRAM의 모델명
#undef CONFIG_SLOT2_DEV_DM9000
#define CONFIG_SLOT2_DEV SRAM_CS18LV1024 //SRAM의 모델명
#define CONFIG_SLOT2_DEV_GCC_WAR SRAM_GCC_WAR_CS18LV1024 //SRAM의 모델명
#define CONFIG_SLOT2_DEV_TYPE "sram" //SRAM타입
#define CONFIG_SLOT2_HALFWORD_ADDRESSING 1 //하프 워드 전송
#undef CONFIG_SLOT2_HALFWORD_ADDRESSING_DQ15
#undef CONFIG_SLOT2_BYTE_ADDRESSING
#define CONFIG_SLOT2_ADDRESS_MODE HALFWORD_MODE //하프 워드 전송

/*
* CHIPPLUS
*/
#define SRAM_CS18LV1024 \
{ \
.name = "CS18LV1024", \
.t_elwl = 0, \
.t_avav = 55, \
.t_whwl = 40, \
.t_whgl = 0, \
.logsize = 19, \
}
#define SRAM_GCC_WAR_CS18LV1024 \
0, 55, 40, 0, 19

 

 

//---------------------------------- 메인 함수에서 SRAM(SLOT2)맵핑----------------------------------------------------

 

 

static struct map_info download_map_info = {
.paddr = USIP_SLOT2_PADDR,                                          //물리적 주소 Slot 2에  0x5000 0000
.vaddr = KSEG2,                                                                    //가상메모리 주소 0xc000 0000
};

slot = USIP_SLOTX(download_map_info.paddr);               //슬롯위치 설정
download_map_info.logsize = umc_slot_logsize(slot);
bios_map(&download_map_info);                                        //TLB(Translation Look-aside Buffer)

 

그래서 SRAM 의 가상 메모리 주소는 KSEG2 즉 0xc000 0000의 위치에 맵핑 됐습니다.

그리고 나서 SRAM 메모리 테스트를 다음과 같이 하였습니다.

int test_sram(void)

{

     unsigned char data[8];                                                            //내부 RAM안의 변수

     unsigned char *sram ;

     sram = KSEG2 ;                                                                    //외부 SRAM 가상메모리 주소 0xc000 0000(KSEG2)

    for(cnt = 0 ; cnt < SRAMSIZE; cnt += 8 )                            //SRAMSIZE = 512*1024 byte

    {

        for(i = 0; i < 8; i++)                                                               //외부SRAM에 테스트 값 쓰기

       {

           data[i] = (1 << i);

          *(sram+cnt+i) = data[i];

       }

    }

 

    for(cnt = 0 ; cnt < SRAMSIZE ; cnt++)                                 //외부 SRAM의 값을 읽기

    {

         printf("sram = %x\n", *(sram + cnt));

     }

}

 

이와 같이 테스트를 실행 시 쓸 때는 헥사 값으로

 

0x01, 0x02,0x04, 0x08, 0x10, 0x20, 0x40, 0x80

 

이렇게 8개를 반복해서 쓰는데

쓰고 나서 읽어보면

 

0x01, 0x00, 0x04, 0x00, 0x10, 0x00, 0x40, 0x00, 0x01, 0x00, 0x04, 0x00,......

 

과 같이 중간에 하나씩 빼먹어 버립니다...

커널이 없이 부트단에서 해서 그런가요..?? 선배님들 도와주세요..

 

댓글 1

하드웨어 설계 및 개발에 대하여 개발자들이 자유롭게 토론하는 공간입니다.
- Q&A, 자유주재 토론, 관련 정보 공유
- 분야 : 마이크로프로세서 응용, 전기/전자(아날로그/디지털) 회로 설계, C/C++ 프로그래밍, 펌웨어,
         PCB Artwork, 트러블슈팅 등 하드웨어 설계에 관한 전반인 내용
※ 게시글에 맞는 분류를 선택하여 글을 작성해 주시면 쾌적한 사이트 운영에 많은 도움이 됩니다.
※ 하드웨어 인사이트는 회원들간의 거래정보를 게재할 뿐이지, 그 어떤 책임과 의무도 가지지 않습니다.

search
번호 분류 제목 글쓴이 조회 수 날짜
115 중고장터 HOTAT45DB041D-SU / AT45DB161D-SU 판매합니다. 캐롤 4322 2012.11.28
114 중고장터 HOT소프트키트에서 GLCD128x64 프로그램 판매 합니다. 홍당무 6248 2012.10.31
113 중고장터 HOT30W급 BLDC 모터+ 기어박스 + 초소형드라이버 입니다.2 슈팅 8006 2012.08.09
112 중고장터 HOTpvsm 구입원함(8051지원) 카푸리오 4673 2012.05.19
111 중고장터 HOTMPLAB ICD2 팝니다.1 reon 11595 2012.02.17
110 중고장터 HOT수삽 체인 콘베어1 박팔뚝 9580 2012.01.27
109 중고장터 HOTLevel shifter, Level translator 2channel 구입합니다.. 발가락마저곱지아니한가 7371 2012.01.18
108 중고장터 HOTSTM32F103ZET 판매 아크마 8138 2011.02.27
107 중고장터 HOTIPAD Wifi 64G A급 팔아요 DKMG 8428 2011.10.23
106 중고장터 HOTTFT LCD 7" 판매 8bit - 16bbit MCU로 제어도 가능한 솔로션도 있습니다. 플래시맨 8891 2011.10.18
105 중고장터 HOT라인트레이서 구매 독도는우리땅 8054 2011.08.29
104 중고장터 HOTpcb 노이즈 방지!!전문서적 팜 말하는늑대 11983 2011.08.06
103 중고장터 HOTLabTool-848 koscillo 10876 2011.07.03
102 중고장터 HOTROM ERASER 판매합니다.1 루미사인 28770 2011.06.29
101 중고장터 HOTPIC 개발툴 MR.PIC 판매합니다. 루미사인 10230 2011.06.29
100 중고장터 HOT텍트로닉스 디지털 오실로 스코프 TDS220 루미사인 8395 2011.06.29
99 중고장터 HOTLED Matrix(전광판) 개발 Kit 팝니다. (Full 소스제공) - 파격 할인 Golilla20 10545 2011.06.27
98 중고장터 HOTAtmega128, ISP, 블루투스모듈, RS232케이블, 모터기어박스 등각각팝니다 btnim 8460 2011.06.11
97 중고장터 HOTM68UICS08 + M68EPT08JLK Demo board 아크마 6122 2011.05.22
96 중고장터 HOTOLIMEX PIC-P40-20Mhz, Development boards 아크마 5893 2011.05.22
  • 사랑은 홍역과 같다. 우리 모두가 한번은 겪고 지나가야 한다.
    - J.K 제롬
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
  • 내 글이 추천받음 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.