회원가입 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
번호 분류 제목 글쓴이 조회 수 날짜
972 마이크로프로세서 HOT오토캐드에서 작성한 회로도를... 땜쟁이야 1576 2011.11.22
971 마이크로프로세서 HOTinterrupt 사용법에 대해서 궁금한 점 있습니다. 해오 892 2011.11.21
970 마이크로프로세서 HOT1초마다 교대로 문자 출력하는 소스인데 안되서요 ㅠ1 허브명수 1178 2011.11.21
969 마이크로프로세서 HOT안녕하세요. 픽 두번쨰로 접한 초보입니다. 여쭈고 싶은게 있어서요 거덜러미 1040 2011.11.20
968 마이크로프로세서 HOT데이터 입력에 관한 질문입니다. 드미트리 898 2011.11.18
펌웨어 & 코딩언어 HOT외부 SRAM 컨트롤하는 것좀 도와주세요.1 쩡무 1389 2011.11.15
966 마이크로프로세서 HOTpid제어를 통해서 도립진자를 만드려는데 좀 힘드네요ㅜ 도와주세요ㅜ 매실한잔 1490 2011.11.14
965 마이크로프로세서 HOTled 제어하는데... 실마리온 1015 2011.11.14
964 마이크로프로세서 HOT8051 사거리 신호등 LED패턴 바꾸기 소스코드좀 봐주세요... LED깜빡 1511 2011.11.12
963 마이크로프로세서 HOT데이터 뽑는 소스 질문입니다 ㅠ.ㅠ; 드미트리 1086 2011.11.11
962 마이크로프로세서 HOTSTM32 Bitband 큰강아지 1708 2011.11.09
961 마이크로프로세서 HOT이제 막 배우기 시작했는데 램프하나 제대로 못켜겠어요 도와주세요1 안녕:) 1245 2011.11.06
960 마이크로프로세서 HOT8051 프로그램좀 짜주세요 ㅠ 재상 1008 2011.11.04
959 마이크로프로세서 HOT이 헤더 파일 질문입니당~ ㅠ.ㅠ; 드미트리 870 2011.11.03
958 마이크로프로세서 HOT아트메가 초보가 질문 드립니다. winglyc 1061 2011.11.03
957 마이크로프로세서 HOT데이터 뽑는 거~질문이요~2 드미트리 1421 2011.11.02
956 마이크로프로세서 HOTAVR소스를 이용한 GPS parsing 질문1 드미트리 3050 2011.11.01
955 마이크로프로세서 HOTled 점등 소스코드 부탁좀1 jounghun325 1082 2011.11.01
954 마이크로프로세서 HOT적외선센서를 ADC로 변화하는 것에 대해 궁금합니다. 경마장 1306 2011.10.25
953 마이크로프로세서 HOTAVR용 연습도구7 견우7 1678 2011.10.19
Prev 1 ... 5 6 7 8 9 10 11 12 13 14 ... 58 Next
  • 물이 너무 맑으면 물고기가 없고, 사람이 너무 살피면 친구가 없다.
    - 명심보감
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
  • 내 글이 추천받음 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.