회원가입 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
번호 분류 제목 글쓴이 조회 수 날짜
55 Software & IDEs HOTAllegro OrCAD 16.6 파일 보내주실 수 있나요?2 jihE 481 2018.01.28
54 Software & IDEs 소스 분석툴 관련 질문드려요2 아톰신 166 2017.01.02
53 Software & IDEs 리눅스 커널에 대해 공부하려고 하는데 서적 한부 추천 부탁드립니다.1 아톰신 167 2017.01.02
52 Software & IDEs PADS.9.4.1 받을수 있는 방법(훈련병)2 하운드 297 2016.07.13
51 Software & IDEs 리눅스는 여기 사이트와 거리가 먼거죠?1 pcb훈련변 182 2016.06.05
50 Software & IDEs epm3128act100-10n 프로그램 확인 땡쟁이 213 2015.12.17
49 Software & IDEs 신입생입니다.3 sunni 223 2015.12.09
48 Software & IDEs gps단말기 펌웨어질문입니다1 힘술쟁이 248 2015.11.18
47 Software & IDEs HOTUSB를 사용하는 디바이스 펌웨어 개발 책? 문서?1 베이아터 478 2014.01.09
46 Software & IDEs HOT큐블럭 프로그래밍 관련 질문 올립니다.1 행복이아빠 595 2013.08.22
45 Software & IDEs HOTProteus 7.7 Professional2 Keyshaun 755 2013.07.12
44 Software & IDEs HOTmsp430f1611을 사용하고 있는데 ADC에서 읽어들인 값하고 직접 테스터기로 찍은 값이 달라요1 김진성짱 812 2013.06.25
43 Software & IDEs HOTOV9620 SXGA 모드 설정 좀 도와주세요1 로미옹 515 2013.03.25
42 Software & IDEs HOT주차 시스템 회로 구성하는데요.. peng2 1201 2011.10.09
41 Software & IDEs HOTFreescale 질문인데 아시는 분 없나요? ㅠㅠ2 jzho 1550 2011.07.19
40 Software & IDEs HOTkey board 관련1 jjhuem 2448 2011.07.06
39 Software & IDEs HOT펌웨어 하다가 막히는 부분이 있어서 질문 드립니다. 마모루 1556 2011.06.13
38 Software & IDEs HOT어셈블리어 공부하기1 아이스으 2192 2011.03.22
37 Software & IDEs HOT스마트폰 앱 개발시 음성필터요..1 귤씅 2210 2011.01.28
36 Software & IDEs HOTWDK 관련 문의 입니다.1 소보루 1293 2010.11.18
  • 힘으로서 사람을 복종시키지 말고 덕으로서 사람을 복종시켜라.
    - 맹자
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
  • 내 글이 추천받음 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.