Založen: Dec 11, 2015 Příspěvky: 183 Bydliště: Slovensko,Bratislava
Zaslal: so leden 20 2024, 11:22 Předmět: Wiznet W7500P
Ahojte po prací s w5500 chcel by som vyskúšať ich W7500P kde je CotexM0+PHY v jednom puzdre, tak som si pozeral možnosti programovania na
ich stránke je uvedený príklad pomocou KEIL W7500_KEIL čo je ale platený SW a free verzia je obmedzená na 32Kb ďalej je tam uvedené GNU GCC 7500_GNUGCC free.
Skúsil som si postaviť projekt v CodeBlocks na stránke je možne stiahnuť knižnice a projekty Library pre jednotlivé periférie nalinkoval som knižnice stiahol GNUWIN32 a ARM GCC a pomocou ich makefile ktorý je v každom projekte uvedený sa mi to podarilo jeden z projektov pre UART perifériu úspešné skompilovať
Chcel by som dodať že v tomto smere nie som zdatný vždy som používal veci priamo od výrobcu MCU : AtmelStudio, MicrochipStudio, Stm32Ide.
Ja by som nechcel používať externý makefile a preto som skúsil to skompilovať len pomocou CodeBlock a tam som narazil na jednu chybu s ktorou neviem pohnúť sú tam dva súbory gcc_W7500.ld a startup_W7500.S .ld je ako som zistil nejaký skript no a samozrejme .S assembler v tom asseblernom súbore sú premenne ktoré CodeBlocks nevidí a vyhadzuje ako chybu a s tým .ld súborom netuším ako pracovať a v ich makefile sa tieto dva subori linkujú ale neviem ako ich nalinkovať aby to videl aj CodeBlock
kód:
-------------- Build: Debug in hello_world (compiler: GNU GCC Compiler for ARM)---------------
2016q3/bin/../lib/gcc/arm-none-eabi/5.4.1/../../../../arm-none-eabi/lib\libc.a(lib_a-exit.o): In function `exit':
exit.c:(.text.exit+0x2c): undefined reference to `_exit'
obj\Debug\main.o: In function `main':
c:/program files (x86)/gnu tools arm embedded/5.4 2016q3/bin/../lib/gcc/arm-none-eabi/5.4.1/../../../../arm-none-eabi/lib\libc.a(lib_a-sbrkr.o): In function `_sbrk_r':
sbrkr.c:(.text._sbrk_r+0x18): undefined reference to `_sbrk'
c:/program files (x86)/gnu tools arm embedded/5.4 2016q3/bin/../lib/gcc/arm-none-eabi/5.4.1/../../../../arm-none-eabi/lib\libc.a(lib_a-closer.o): In function `_close_r':
closer.c:(.text._close_r+0x18): undefined reference to `_close'
c:/program files (x86)/gnu tools arm embedded/5.4 2016q3/bin/../lib/gcc/arm-none-eabi/5.4.1/../../../../arm-none-eabi/lib\libc.a(lib_a-lseekr.o): In function `_lseek_r':
lseekr.c:(.text._lseek_r+0x24): undefined reference to `_lseek'
c:/program files (x86)/gnu tools arm embedded/5.4 2016q3/bin/../lib/gcc/arm-none-eabi/5.4.1/../../../../arm-none-eabi/lib\libc.a(lib_a-readr.o): In function `_read_r':
readr.c:(.text._read_r+0x24): undefined reference to `_read'
c:/program files (x86)/gnu tools arm embedded/5.4 2016q3/bin/../lib/gcc/arm-none-eabi/5.4.1/../../../../arm-none-eabi/lib\libc.a(lib_a-fstatr.o): In function `_fstat_r':
fstatr.c:(.text._fstat_r+0x20): undefined reference to `_fstat'
c:/program files (x86)/gnu tools arm embedded/5.4 2016q3/bin/../lib/gcc/arm-none-eabi/5.4.1/../../../../arm-none-eabi/lib\libc.a(lib_a-isattyr.o): In function `_isatty_r':
isattyr.c:(.text._isatty_r+0x18): undefined reference to `_isatty'
collect2.exe: error: ld returned 1 exit status
Process terminated with status 1 (0 minute(s), 0 second(s))
14 error(s), 0 warning(s) (0 minute(s), 0 second(s))
Založen: Dec 11, 2015 Příspěvky: 183 Bydliště: Slovensko,Bratislava
Zaslal: út leden 23 2024, 8:19 Předmět:
Ešte ak by niekto plánoval pracovať s týmto čipom ako ja upozorňujem vopred si pozorne preštudovať datasheet a aj erratasheet a nenechať sa uniesť úvodnou stránkou a popisom periférie.
Pokud používají makefile tak ho použít musíš, je to soubor s parametry pro GNU Make který mu říká, jak a s čím má být co zkompilováno, ovšem pokud máš dobře nakonfigurovaný toolchain, tak by mu to Code::Block měl předhodit sám.
Code::Block, GNU Make, GNU GCC atd. jsou primárně linuxové věci, což řešíš hned na začátku instalací gnuwin32, což je v podstatě jen jakýsi framework pro Win pro svobodný software (navíc dost starý, co jsem se tak díval, i on pod 64bit systémy poběží v emulaci), což ale dle mého názoru není optimální cesta (ta lomítka v cestách, co jsi vložil jako ukázku, jsou mimochodem dost zjevná nápověda pro toho, kdo ví jak mají POSIXové systémy uspořádán filesystém). Wiznet i STM dost podporují Linux a otevřené projekty, a vývojáři Wiznetu z věcí od STM dost vychází - možná bys udělal líp. kdyby sis nainstaloval (nebo spustil live z USB) nějakou Linuxovou distribuci, která má v repozitáři Code::Block, (což je dnes v podstatě asi každá) a co má v repozitáři arm-none-eabi balíček (Debian, Ubuntu, Fedora, Alt Linux, případně dokompilovat) a zkusil to nativně pod ní (neslibuju nic, nutno vyzkoušet).
Ty soubory s příponou .ld nejsou scripty (nepatří to k programu LD z Binutils, ten má příponu .lds), ale co jsem tak pochopil tak jsou to soubory s parametry, které používá STM32CubeIDE prostředí. Pro Code::Block to bude zřejmě potřeba nějak upravit, tohle přesně ale nevím jak, nevím jak a čím STM32CubeIDE kompiluje projekty (a nechtělo se mi to hledat).
Založen: Dec 11, 2015 Příspěvky: 183 Bydliště: Slovensko,Bratislava
Zaslal: ne leden 28 2024, 21:45 Předmět:
Ahoj, som si upravil makefile nech pracuje len zo súbormi ktoré ma v projekte a teraz ak si vytvorím noví project alebo si ho prenesiem na iný pc tak ho len nakopírujem a pôjde skompilovať pretože sa neodkazuje na žiadne súbory mimo a tak tiež som pridal nech zobrazuje veľkosť použitých dát v mcu.
kód:
#-----------------------------------------------------------------------------
#
# W7500 compilation make file
#
#-----------------------------------------------------------------------------
#
# Configurations
#
# Choose the core instantiated, can be
# - CORTEX_M0
# - CORTEX_M0PLUS
#CPU_PRODUCT = CORTEX_M0PLUS
CPU_PRODUCT = CORTEX_M0
TOOL_CHAIN = gcc
CPU_TYPE = -mcpu=cortex-m0
Čo som zatiaľ zistil počas prace s MCU.
Na ich evaluation board schéma v prílohe, je nutne vyspajkovať R11 a na spájkovať na pozíciu R10 inak bude potrebne pri každom reprograme vypnúť zapnúť napájanie pcb
Interne hodiny je nutne kalibrovať inak periférie ako UART (dosť ma to zamestnalo až kým som nepozrel ako majú spravene wiznet funkciu
kód:
SystemInit();
) od neskalibrovaných interných hodín nebu fungovať, nikde to v datasheete ani reference manuály nie je písané že je potrebne niečo kalibrovať našiel som to u nich na fóre keď sa nato vypytoval jeden korejec.
Ich
kód:
SystemInit();
v podstate okrem tej kalibrácie nič viac nerobí takže som musel napísať svoju funkciu ktorá umožni inicializovať interne alebo externe hodiny nastaviť variabilne frekvenciu jadra a zapínať Clk deliť, pre jednotlivé periférie ktoré chcem použiť a ostatne vypnúť nakoľko defaultne je všetko zapnute
kód:
#define F_XTAL 8000000UL
#define F_INTO 8000000UL
uint32_t clk_init( const uint8_t M, const uint8_t N, const uint8_t OD, const uint8_t oscilator_select)
{
uint32_t temporary_freq = 0;
CRG->PLL_PDR = CRG_PLL_PDR_NRMLOP; // PLL power up
if (!oscilator_select) // internal oscilator set
{
//*************************************** Calibrate internal VCO calibrate value is write from factory in W7500x_INFO_BGT and W7500x_INFO_OSC *******************************
(*((volatile uint32_t *)(W7500x_TRIM_BGT))) = (*((volatile uint32_t *)(W7500x_INFO_BGT)));
(*((volatile uint32_t *)(W7500x_TRIM_OSC))) = (*((volatile uint32_t *)(W7500x_INFO_OSC)));
//*************************************** END Calibrate internal VCO ********************************************************************************************************
temporary_freq = F_INTO;
CRG->PLL_IFSR = CRG_PLL_IFSR_RCLK; // PLL input clock internal oscilator
//******************************************************* set FLCK ***********************************************
CRG->FCLK_SSR = CRG_FCLK_SSR_MCLK;// select source clock FCLK [ PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->FCLK_PVSR = CRG_FCLK_PVSR_DIV1; // prescaler for FLCK clock
//*************************************************** End set FLCK ***********************************************
//******************************************************* set ADCCLK ***********************************************
CRG->ADCCLK_SSR = CRG_ADCCLK_SSR_DIS;// select source clock ADCCLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->ADCCLK_PVSR = CRG_ADCCLK_PVSR_DIV1; // prescaler for ADCCLK clock
//*************************************************** End set ADCCLK ***********************************************
//******************************************************* set SSPCLK ***********************************************
CRG->SSPCLK_SSR = CRG_SSPCLK_SSR_DIS;// select source clock SSPCLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->SSPCLK_PVSR = CRG_SSPCLK_PVSR_DIV1; // prescaler for SSPCLK clock
//*************************************************** End set SSPCLK ***********************************************
//******************************************************* set UARTCLK ***********************************************
CRG->UARTCLK_SSR = CRG_UARTCLK_SSR_MCLK;// select source clock UARTCLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->UARTCLK_PVSR = CRG_UARTCLK_PVSR_DIV1; // prescaler for UARTCLK clock
//*************************************************** End set UARTCLK ***********************************************
//******************************************************* set TIMER0CLK ***********************************************
CRG->TIMER0CLK_SSR = CRG_TIMERCLK_SSR_DIS;// select source clock TIMER0CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->TIMER0CLK_PVSR = CRG_TIMERCLK_PVSR_DIV1; // prescaler for TIMER0CLK clock
//*************************************************** End set TIMER0CLK ***********************************************
//******************************************************* set TIMER1CLK ***********************************************
CRG->TIMER1CLK_SSR = CRG_TIMERCLK_SSR_DIS;// select source clock TIMER1CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->TIMER1CLK_PVSR = CRG_TIMERCLK_PVSR_DIV1; // prescaler for TIMER1CLK clock
//*************************************************** End set TIMER1CLK ***********************************************
//******************************************************* set PWM0CLK ***********************************************
CRG->PWM0CLK_SSR = CRG_PWMCLK_SSR_DIS;// select source clock PWM0CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->PWM0CLK_PVSR = CRG_PWMCLK_PVSR_DIV1; // prescaler for PWM0CLK clock
//*************************************************** End set PWM0CLK ***********************************************
//******************************************************* set PWM1CLK ***********************************************
CRG->PWM1CLK_SSR = CRG_PWMCLK_SSR_DIS;// select source clock PWM1CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->PWM1CLK_PVSR = CRG_PWMCLK_PVSR_DIV1; // prescaler for PWM1CLK clock
//*************************************************** End set PWM1CLK ***********************************************
//******************************************************* set PWM2CLK ***********************************************
CRG->PWM2CLK_SSR = CRG_PWMCLK_SSR_DIS;// select source clock PWM2CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->PWM2CLK_PVSR = CRG_PWMCLK_PVSR_DIV1; // prescaler for PWM2CLK clock
//*************************************************** End set PWM2CLK ***********************************************
//******************************************************* set PWM3CLK ***********************************************
CRG->PWM3CLK_SSR = CRG_PWMCLK_SSR_DIS;// select source clock PWM3CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->PWM3CLK_PVSR = CRG_PWMCLK_PVSR_DIV1; // prescaler for PWM3CLK clock
//*************************************************** End set PWM3CLK ***********************************************
//******************************************************* set PWM4CLK ***********************************************
CRG->PWM4CLK_SSR = CRG_PWMCLK_SSR_DIS;// select source clock PWM4CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->PWM4CLK_PVSR = CRG_PWMCLK_PVSR_DIV1; // prescaler for PWM4CLK clock
//*************************************************** End set PWM4CLK ***********************************************
//******************************************************* set PWM5CLK ***********************************************
CRG->PWM5CLK_SSR = CRG_PWMCLK_SSR_DIS;// select source clock PWM5CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->PWM5CLK_PVSR = CRG_PWMCLK_PVSR_DIV1; // prescaler for PWM5CLK clock
//*************************************************** End set PWM5CLK ***********************************************
//******************************************************* set PWM6CLK ***********************************************
CRG->PWM6CLK_SSR = CRG_PWMCLK_SSR_DIS;// select source clock PWM6CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->PWM6CLK_PVSR = CRG_PWMCLK_PVSR_DIV1; // prescaler for PWM6CLK clock
//*************************************************** End set PWM6CLK ***********************************************
//******************************************************* set PWM7CLK ***********************************************
CRG->PWM7CLK_SSR = CRG_PWMCLK_SSR_DIS;// select source clock PWM7CLK [ Disable, PLL = MCLK , INT OSC = RCLK, EXTERNAL OSC = OCLK ]
CRG->PWM7CLK_PVSR = CRG_PWMCLK_PVSR_DIV1; // prescaler for PWM7CLK clock
//*************************************************** End set PWM7CLK ***********************************************
//CRG->PLL_FCR = 0x50200; default value
// OD = (1 << (OD & 0x02)) * (1 << (OD & 0x01));
return temporary_freq * M/N * 1/(1 << (OD & 0x02)) * (1 << (OD & 0x01)); // return value of PLL frequency this value is use in peripherals for calculate
}
UART2 funguje z ich knižnice v poriadku .... takže idem sa venovať TOE nakoľko oni tam majú univerzálnu knižnicu pre W5500 W5501 W7500 .... a je to dosť neprehľadné
Nemůžete odesílat nové téma do tohoto fóra. Nemůžete odpovídat na témata v tomto fóru. Nemůžete upravovat své příspěvky v tomto fóru. Nemůžete mazat své příspěvky v tomto fóru. Nemůžete hlasovat v tomto fóru. Nemůžete připojovat soubory k příspěvkům Můžete stahovat a prohlížet přiložené soubory
Informace na portálu Elektro bastlírny jsou prezentovány za účelem vzdělání čtenářů a rozšíření zájmu o elektroniku. Autoři článků na serveru neberou žádnou zodpovědnost za škody vzniklé těmito zapojeními. Rovněž neberou žádnou odpovědnost za případnou újmu na zdraví vzniklou úrazem elektrickým proudem. Autoři a správci těchto stránek nepřejímají záruku za správnost zveřejněných materiálů. Předkládané informace a zapojení jsou zveřejněny bez ohledu na případné patenty třetích osob. Nároky na odškodnění na základě změn, chyb nebo vynechání jsou zásadně vyloučeny. Všechny registrované nebo jiné obchodní známky zde použité jsou majetkem jejich vlastníků. Uvedením nejsou zpochybněna z toho vyplývající vlastnická práva. Použití konstrukcí v rozporu se zákonem je přísně zakázáno. Vzhledem k tomu, že původ předkládaných materiálů nelze žádným způsobem dohledat, nelze je použít pro komerční účely! Tento nekomerční server nemá z uvedených zapojení či konstrukcí žádný zisk. Nezodpovídáme za pravost předkládaných materiálů třetími osobami a jejich původ. V případě, že zjistíte porušení autorského práva či jiné nesrovnalosti, kontaktujte administrátory na diskuzním fóru EB.