회원가입 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
번호 분류 제목 글쓴이 조회 수 날짜
1152 마이크로프로세서 코딩 질문입니다1 돼진이 375 2024.05.28
1151 마이크로프로세서 Dc모터 전원 연결해도 돌아가질 않습니다.2 전공하수 234 2023.05.08
1150 마이크로프로세서 혹 EZBL 접해 보신분 있으신가요?1 보라수정 226 2018.12.11
1149 마이크로프로세서 fnd 1234 켜지면 led 켜지는 코드1 이상원 267 2018.10.05
1148 마이크로프로세서 HOTSTM32F 개발환경을 소개합니다.4 om 1426 2018.05.13
1147 마이크로프로세서 비엔나 회로 질문1 수채화 262 2018.04.06
1146 Software & IDEs HOTAllegro OrCAD 16.6 파일 보내주실 수 있나요?2 jihE 476 2018.01.28
1145 마이크로프로세서 [news] ST마이크로일렉트로닉스, PC용 MCU 파인더 출시로 STM32 및 STM8 설계 리소스 접속 더욱 편리해져 아크마 214 2018.01.05
1144 마이크로프로세서 AT90CAN128 질문1 전문인을꿈꿔여 232 2017.09.07
1143 펌웨어 & 코딩언어 객체지향프로그래밍4 끼르 332 2017.06.19
1142 마이크로프로세서 통신관련질문1 hipertech 177 2017.06.12
1141 마이크로프로세서 디지털 시계 온도와 습도 정확도 조정을 하려면3 동안 311 2017.05.10
1140 마이크로프로세서 HOTPIC를 입문하면서 궁금한 사항5 pandaya 418 2017.04.30
1139 마이크로프로세서 HOT학교과제인데요 도무지모르겠습니다. AVR의길은 멀고도험한거같습니다.5 비언조키다 551 2017.04.24
1138 마이크로프로세서 도와주세요//MPLAP X IDE에서 내장함수 사용시 에러1 하늘색꿈 316 2017.02.21
1137 Software & IDEs 소스 분석툴 관련 질문드려요2 아톰신 160 2017.01.02
1136 Software & IDEs 리눅스 커널에 대해 공부하려고 하는데 서적 한부 추천 부탁드립니다.1 아톰신 157 2017.01.02
1135 마이크로프로세서 HOTKeil 8051 컴파일러 크랙을 부탁드려요 ! 지범이 447 2016.12.16
1134 마이크로프로세서 avr studio 소스를 codevision avr소스로 바꿔주시면 감사하겠습니다.1 xoxokgs 386 2016.12.14
1133 마이크로프로세서 리눅스 공부 할려니 막막하네요5 초보초보왕초보왕 201 2016.12.12
Prev 1 2 3 4 5 6 7 8 9 10 ... 58 Next
  • 오랜 약속보다 당장의 거절이 낫다.
    - 덴마크 격언
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
  • 내 글이 추천받음 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.