|
Переход AVR to ARM, посоветуйте с чего начать:) |
|
|
|
 |
Ответов
(1 - 50)
|
Oct 12 2009, 12:12
|
Гуру
     
Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448

|
Цитата(Br.Misha @ Oct 12 2009, 15:54)  ...а потом увидел LPC21** и они мне очень понравились(особенно их цена). Лучше посмотрите 23 и 24 - должны понравится еще сильнее. Цитата(Br.Misha @ Oct 12 2009, 15:54)  Подойдет ли LPC для моего проекта? еси да, то напишите пожалуйста какую литературу мне нада почитать и какой компил использовать. ИМХО, обязательная литература: - ARM7TDMI Technical Reference Manual - User Manual на выбранный кристалл - Technical Reference Manual на VIC Пункты 1 и 3 доступны на arm.com Без прочтения данной литературы неизбежно будут вопросы по работе прерываний. Компилятор - какой нравится. Если привыкли к IAR'у - используйте его, если нет - посмотрите Keil.
|
|
|
|
|
Oct 12 2009, 21:25
|
Местный
  
Группа: Validating
Сообщений: 253
Регистрация: 21-12-08
Пользователь №: 42 646

|
Большое спасибо всем кто ответил  К сожалению AT32 очень дорогие(самая дешевая стоет 105 грн) и в магазине тока под заказ не менее чем 10 шт. У LPC23 очень много ног, минимум 100. Хотя я хз для чего они предназначены но врятле они мне пригодяться, самый дешевый (LPC2364FBD100) 55 грн. А вот еси посмотреть на LPC21 то там самый простой LPC2101FBD48 и стоет 30 грн и у него 44 ноги, я думаю что для меня этого достаточно. Для меня главное - СКОРОСТЬ
|
|
|
|
|
Oct 12 2009, 21:50
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(Br.Misha @ Oct 12 2009, 23:25)  Для меня главное - СКОРОСТЬ Тогда зачем было нужно поминать всуе Цитата хочу разработать один девайс в котором мне нада заюзать граф.дисплей, ММС и т.д. Контроллеров которых у 21xx нет. Цитата Хотя я хз для чего они предназначены но врятле они мне пригодяться Обалдеть  И поле этого Цитата я думаю что для меня этого достаточно.  Детский сад какой-то...
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Oct 13 2009, 13:15
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(Br.Misha @ Oct 13 2009, 15:58)  что на этих дисплеях от мобильников из мусорника Цитата обычный SPI интерфейс И MMC карточку где-то нашел, о о существовании SD и контроллере Вы не подозреваете..... Вот я и говорю - радиолюбительство. Совсем другие "критерии" оценки и об этом нужно обязательно упоминать с самого начала, иначе просто пустая трата времени.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Oct 13 2009, 18:19
|
Гуру
     
Группа: Свой
Сообщений: 2 702
Регистрация: 14-07-06
Пользователь №: 18 823

|
Цитата(Br.Misha @ Oct 12 2009, 14:54)  Подойдет ли LPC для моего проекта? Для какого проекта, браток? А то модераторы нервничают  SPI для ЖКИ, SPI для SD-card, UARTс IrDA, USB device... Ффсе? Память внутренняя. STM32 гляньте, один из самых дешевых контроллеров ARM.
--------------------
Уходя, оставьте свет...
|
|
|
|
|
Oct 13 2009, 18:45
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(Dog Pawlowa @ Oct 13 2009, 21:19)  UARTс IrDA Которого, кстати, тоже у 21xx нет в отличие от 23/24xx. Для SD SPI тоже не нативный интерфейс. Про использование дисплеев от старинных мобилок вместо нормальных LCD подключаемых набортным LCD контролерам тоже уже писал. Но это все это видимо из разряда Цитата хз для чего они предназначены но врятле они мне пригодяться
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Oct 22 2009, 12:50
|
Участник

Группа: Участник
Сообщений: 23
Регистрация: 22-10-09
Пользователь №: 53 141

|
В это теме задавались вопросы исключительно по выбору производителей микроконтроллеров с архитектурой ARM. Но я хочу задать несколько конкретных вопросов по самой архитектуре. Прочитал я ARM7TDMI Technical Reference Manual. Вроде все понятно за исключение некоторых нюансов. Так начнем с исключительных ситуаций. Аварийные ситуации. Насколько я понял возникает в зависимости от линии ABORT. Но вот совсем непонятно применение данной искл. ситуации. В документе описывается пример с виртуальной памятью, но если чесно перечитывал 5 раз, ничего не понял вообще, не могли бы вы обьяснить тот пример более по-простому? Ну и если можно привести ещё парочку промеров, где можно удачно применять аварийные ситуации? Как я понял они есть двух видов: аварийная предварительная выборка и аварийны данные. Я вообще не нашел в документе где описывается различие между ними. Не обьясните в чем между ними разница? И зачем они возникают. Программные прерывание. Очень хорошо понял зачем они применяются благодаря объяснению: ТЫЦНо я так и не поня как процессор попадает в это состояние? И что мне нужно в кде написать что бы попасть в это прерывание? И ещё вопрос: команды thunb выполняются медленнее? Правильно ли это? И ещё какие минусы применения thumb ещё наблюдаются? Спасибо.
|
|
|
|
|
Oct 22 2009, 13:01
|
Гуру
     
Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448

|
Цитата(arm123 @ Oct 22 2009, 16:50)  Ну и если можно привести ещё парочку промеров, где можно удачно применять аварийные ситуации? "Удачно применить" их можно разве что при отладке - узнать, например, где процессор обратился по невыровненному адресу или к несуществующей памяти. Цитата(arm123 @ Oct 22 2009, 16:50)  Как я понял они есть двух видов: аварийная предварительная выборка и аварийны данные. Я вообще не нашел в документе где описывается различие между ними. Не обьясните в чем между ними разница? И зачем они возникают. Prefetch Abort - исключение, возникающее при попытке ядра прочитать инструкцию, Data Abort - при попытке прочитать или записать данные. Вообще же, так как сигнал ABORT является внешним, то ситуации, в которых он генерируются, зависят от конкретной реализации контроллера памяти и отличаются у разных производителей. Цитата(arm123 @ Oct 22 2009, 16:50)  Программные прерывание. Очень хорошо понял зачем они применяются благодаря объяснению: ТЫЦНо я так и не поня как процессор попадает в это состояние? И что мне нужно в кде написать что бы попасть в это прерывание? Попадает по команде SWI. Компиляторы, как правило, предоставляют обертку, позволяющую оформить SWI как вызов: Код __swi int func(int, int); Цитата(arm123 @ Oct 22 2009, 16:50)  И ещё вопрос: команды thunb выполняются медленнее? Правильно ли это? И ещё какие минусы применения thumb ещё наблюдаются? Thumb - это всего лишь метод упаковки команд, на скорость выполнения он не влияет. А вот на скорость выполнения программы в целом - да, влияет, и не в лучшую сторону. Учитывая постоянно растущий объем доступной на кристалле памяти, использование Thumb представляется все менее целесообразным.
|
|
|
|
|
Oct 22 2009, 13:43
|
Участник

Группа: Участник
Сообщений: 23
Регистрация: 22-10-09
Пользователь №: 53 141

|
Цитата(aaarrr @ Oct 22 2009, 16:01)  Попадает по команде SWI. Компиляторы, как правило, предоставляют обертку, позволяющую оформить SWI как вызов Спасибо, я все понял не понятно одно. Вот есть основная программа и обработчик swi. В обработчик мы попадаем как swi 14, к примеру. 14 находится в поле команты как констанка, которая игнорируется процессором. Но мне не понятно как мы её можем использовать попав уже в обработчик SWI? Это что получается нужно читать команду с которой мы перешли из памяти или как? Поясните пожалуйста. А скорость при Thumb попадает из-за того что компилятор не может оптимально выстраивать конструкции, например я вычитал что в режиме thumb процессор только инструкции перехода могут выполнятся по условию. Получается конструкцию: если (условие) то Операция1 иначе Операция1 в режиме ARM можно выполнить так: 1. Вычислить условие и поставить Флаг1 по результатам вычисления 2. Выполнить Операция1 при условии выставленного Флаг1 3. Выполнить Операция2 при условии невыставленного Флаг1 а в режиме Thumb мы как и в других системах должны использовать привычную для x86 конструкцию: 1. Вычислить условие 2. Если условие выполнено, то идти к 5 3. Выполнить Операция1 4. Идти к 6 5. Выполнить Операция2 6. … Получается в режиме ARM код лишен одного условного и одного безусловного перехода, которые обычно больно бьют по производительности конвейерных архитектур. Правильно ли я трактовал? Вы бы не могли привести общие рекомендации когда нужгно использовать ARM а когда Thumb?
|
|
|
|
|
Oct 22 2009, 13:51
|
Гуру
     
Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448

|
Цитата(arm123 @ Oct 22 2009, 17:43)  Но мне не понятно как мы её можем использовать попав уже в обработчик SWI? Это что получается нужно читать команду с которой мы перешли из памяти или как? Поясните пожалуйста. Да, именно так. Вот, например, обработчик от ARM: CODE ;;; Copyright ARM Ltd 1998. All rights reserved.
PRESERVE8 AREA SWI_Area, CODE, READONLY
EXPORT SWI_Handler IMPORT C_SWI_Handler
T_bit EQU 0x20
SWI_Handler
STMFD sp!, {r0-r3, r12, lr} ; Store registers MOV r1, sp ; Set pointer to parameters MRS r0, spsr ; Get spsr STMFD sp!, {r0, r3} ; Store spsr onto stack and another ; register to maintain 8-byte-aligned stack TST r0, #T_bit ; Occurred in Thumb state? LDRNEH r0, [lr,#-2] ; Yes: Load halfword and... BICNE r0, r0, #0xFF00 ; ...extract comment field LDREQ r0, [lr,#-4] ; No: Load word and... BICEQ r0, r0, #0xFF000000 ; ...extract comment field
; r0 now contains SWI number ; r1 now contains pointer to stacked registers
BL C_SWI_Handler ; Call main part of handler LDMFD sp!, {r0, r3} ; Get spsr from stack MSR spsr_cf, r0 ; Restore spsr LDMFD sp!, {r0-r3, r12, pc}^ ; Restore registers and return
END
Цитата(arm123 @ Oct 22 2009, 17:43)  Правильно ли я трактовал? Вы бы не могли привести общие рекомендации когда нужгно использовать ARM а когда Thumb? Нужно еще прибавить урезанность работы с immediate, методов адресации и т.п. Я бы сказал, что всегда нужно работать в ARM.
|
|
|
|
|
Oct 22 2009, 14:16
|
Участник

Группа: Участник
Сообщений: 23
Регистрация: 22-10-09
Пользователь №: 53 141

|
Цитата(aaarrr @ Oct 22 2009, 16:51)  Я бы сказал, что всегда нужно работать в ARM. Наверное за исключение когда обьемы FLASH ограничены. Мне вот дали пример большого проекта под АРМ, я ещё не смотрел что он делает, но если собрать его под Thumb то получается 70155, а под ARM 116639, разница в 46К что более чем в полтора раза больше. В описании указано, что ARM поддерживает оба порядка следования байт little-endian и big-endian. Сказано что по-умолчанию используется little-endian, но никак не могу найти где описано как эту смену произвести? В компиляторе нашел флаг смены порядка, но как это делается командами процессора? кстати читал что такие большие команды как "STMFD sp!, {r0-r3, r12, lr}"регулярно использоваться не рекомендуется так как значительно повышает латентность прерываний. Вообще читал, что высокая латентность большой из недостатков данной архитектуры, так ли это? А то что-то не верится
|
|
|
|
|
Oct 22 2009, 14:26
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(arm123 @ Oct 22 2009, 17:16)  Наверное за исключение когда обьемы FLASH ограничены. Мне вот дали пример большого проекта под АРМ, я ещё не смотрел что он делает, но если собрать его под Thumb то получается 70155, а под ARM 116639, разница в 46К что более чем в полтора раза больше. Это что-то жуткое написано (скорее чего-нибудь в стиле восьмибитовика)- разница у меня обычно крайне не велика - единицы процнентов, ну 10. Цитата В описании указано, что ARM поддерживает оба порядка следования байт little-endian и big-endian. Сказано что по-умолчанию используется little-endian, но никак не могу найти где описано как эту смену произвести? Как правило никак - ядро это одно, а реализация в железе, как правило не поддерживает такую возможность. Цитата кстати... А что Вы хотели заказав зараз пересылку кучи регистров?
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Oct 22 2009, 14:27
|
Гуру
     
Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448

|
Цитата(arm123 @ Oct 22 2009, 18:16)  Наверное за исключение когда обьемы FLASH ограничены. Мне вот дали пример большого проекта под АРМ, я ещё не смотрел что он делает, но если собрать его под Thumb то получается 70155, а под ARM 116639, разница в 46К что более чем в полтора раза больше. Использование Thumb из-за ограниченного размера флеш все же крайний случай, ИМХО. Цитата(arm123 @ Oct 22 2009, 18:16)  В описании указано, что ARM поддерживает оба порядка следования байт little-endian и big-endian. Сказано что по-умолчанию используется little-endian, но никак не могу найти где описано как эту смену произвести? В компиляторе нашел флаг смены порядка, но как это делается командами процессора? Эндианизм задается аппаратно сигналом BIGEND ядра, поменять его программно нельзя. Цитата(arm123 @ Oct 22 2009, 18:16)  кстати читал что такие большие команды как "STMFD sp!, {r0-r3, r12, lr}"регулярно использоваться не рекомендуется так как значительно повышает латентность прерываний. Вообще читал, что высокая латентность большой из недостатков данной архитектуры, так ли это? А то что-то не верится  Да, это так. Некоторые компиляторы имеют опцию принудительного разбиения LDM/STM.
|
|
|
|
|
Oct 22 2009, 15:59
|
Участник

Группа: Участник
Сообщений: 23
Регистрация: 22-10-09
Пользователь №: 53 141

|
Цитата(zltigo @ Oct 22 2009, 17:26)  Это что-то жуткое написано (скорее чего-нибудь в стиле восьмибитовика) Давно хотел спросить, а что означает фраза "написано в стиле восьмибитовика"???
|
|
|
|
|
Oct 22 2009, 17:20
|
Участник

Группа: Участник
Сообщений: 23
Регистрация: 22-10-09
Пользователь №: 53 141

|
Я понял лучше всего использовать uint32_t и тому подобное. И это получается если я даже знаю что переменная хранит значение не больше 256, или вообще ноль/не_ноль, но все-равно лучше использовать 32-битную переменную? Ну и аналогично просто 16 битную переменную?
|
|
|
|
|
Oct 22 2009, 17:38
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(arm123 @ Oct 22 2009, 20:20)  но все-равно лучше использовать 32-битную переменную? Для портируемости правильнее что-то типа int_fast8_t, int_least8_t P.S. Вообще-то Ваши вопросы правильные, что редкость, то тем не менее на форуме они обсуждались МНОГОКРАТНО. Надо-бы ознакомиться с предшественниками  , для начала.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Oct 25 2009, 07:10
|
Участник

Группа: Участник
Сообщений: 23
Регистрация: 22-10-09
Пользователь №: 53 141

|
Цитата(aaarrr @ Oct 22 2009, 17:51)  Да, именно так. Вот, например, обработчик от ARM: Кстати Вы очень часто приводите стандартные примеры от ARM. Но я их что-то нигде найти не могу, подскажите от куда вы их выдираете?
|
|
|
|
|
Oct 25 2009, 08:44
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(arm123 @ Oct 25 2009, 10:10)  ...примеры от ARM Все это добро, обычно с компиляторами идет, а от "ARM" это Keil, который давненько уже "ARM Company". Только особо не обольщайтесь, хоть и "Company", но исходники там больше "Студеческие".
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Oct 25 2009, 09:01
|
Участник

Группа: Участник
Сообщений: 23
Регистрация: 22-10-09
Пользователь №: 53 141

|
2zltigo, А есть где-нибудь просторах интернета исходники какого-нибудь проекта написанного не-"студенчески"? Хочу проанализировать для общеобразовательных целей.
|
|
|
|
|
Oct 25 2009, 10:10
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(arm123 @ Oct 25 2009, 12:01)  2zltigo, А есть где-нибудь просторах интернета исходники какого-нибудь проекта написанного не-"студенчески"? Цельного не встречал  . А так, приличные исходники встречаются. У "студенческих" тоже на самом деле тоже есть чему поучится - им цельности не хватает, но отдельные элементы и приемы, которым, видимо учили, весьма познавательны. Сшивки между ними ну буквально "белыми нитками" и самодельные куски страшные встречаются  .
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Oct 25 2009, 17:17
|

Профессионал
    
Группа: Участник
Сообщений: 1 620
Регистрация: 22-06-07
Из: Санкт-Петербург, Россия
Пользователь №: 28 634

|
Цитата(arm123 @ Oct 25 2009, 13:01)  2zltigo, А есть где-нибудь просторах интернета исходники какого-нибудь проекта написанного не-"студенчески"? Хочу проанализировать для общеобразовательных целей. Держите. Надеюь, из состояния писанины "студенческих" исходников я уже вырос... Хотя, возможны недоработки в плане структуры программы. Между прочим, как раз пример того, как я переходил с AVR (ATMega32) на ARM (AT91SAM7S64). Тема здесь - http://forum.cqham.ru/viewtopic.php?t=17803Для сборки ARM версии используется YAGARTO, для AVR - WinAVR.
Сообщение отредактировал Genadi Zawidowski - Oct 25 2009, 17:26
|
|
|
|
|
Oct 25 2009, 19:36
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(aaarrr @ Oct 25 2009, 15:06)  Если бы это был Keil, то я бы так и написал. Это добро из комплекта RVDS. смотрим на тот-же файл из поставки Keil: CODE ;/*****************************************************************************/ ;/* SWI.S: SWI Handler */ ;/*****************************************************************************/ ;/* This file is part of the uVision/ARM development tools. */ ;/* Copyright © 2005-2006 Keil Software. All rights reserved. */ ;/* This software may only be used under the terms of a valid, current, */ ;/* end user licence from KEIL for a compatible version of KEIL software */ ;/* development tools. Nothing else gives you the right to use this software. */ ;/*****************************************************************************/
T_Bit EQU 0x20
PRESERVE8 ; 8-Byte aligned Stack AREA SWI_Area, CODE, READONLY ARM
EXPORT SWI_Handler SWI_Handler
STMFD SP!, {R12, LR} ; Store R12, LR MRS R12, SPSR ; Get SPSR STMFD SP!, {R8, R12} ; Store R8, SPSR TST R12, #T_Bit ; Check Thumb Bit LDRNEH R12, [LR,#-2] ; Thumb: Load Halfword BICNE R12, R12, #0xFF00 ; Extract SWI Number LDREQ R12, [LR,#-4] ; ARM: Load Word BICEQ R12, R12, #0xFF000000 ; Extract SWI Number
LDR R8, SWI_Count CMP R12, R8 BHS SWI_Dead ; Overflow ADR R8, SWI_Table LDR R12, [R8,R12,LSL #2] ; Load SWI Function Address MOV LR, PC ; Return Address BX R12 ; Call SWI Function
LDMFD SP!, {R8, R12} ; Load R8, SPSR MSR SPSR_cxsf, R12 ; Set SPSR LDMFD SP!, {R12, PC}^ ; Restore R12 and Return
SWI_Dead B SWI_Dead ; None Existing SWI
SWI_Cnt EQU (SWI_End-SWI_Table)/4 SWI_Count DCD SWI_Cnt
IMPORT __SWI_0 IMPORT __SWI_1 IMPORT __SWI_2 IMPORT __SWI_3 SWI_Table DCD __SWI_0 ; SWI 0 Function Entry DCD __SWI_1 ; SWI 1 Function Entry DCD __SWI_2 ; SWI 2 Function Entry DCD __SWI_3 ; SWI 3 Function Entry ; ... SWI_End
END
Главные отличия в свежих годах Copyright ну и естественно теперь ©Keil. Что-то я совсем не понимаю предмета спора
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Oct 25 2009, 19:58
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(Genadi Zawidowski @ Oct 25 2009, 20:17)  Держите. Надеюь, из состояния писанины "студенческих" исходников я уже вырос... Не  "студентов" тоже писавших, например, мультиплатформенный TI стек SimpleIT в извращениях превзойти трудно  . Ну и такого типа фишки: Код if ((baud_value % 10) >= 5) baud_value = (baud_value / 10) + 1; else baud_value /= 10; Вместо: Код baud_value = ( (baud_value + 5) / 10) Вполне по-студенчески - об округлении уже знают, но с реализацией  P.S. Не принимайте близко к сердцу - выложить исходники в качестве образца, это не подвиг, но что-то героическое в этом есть! Мне такое не по силам, обычно.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Oct 25 2009, 20:04
|
Гуру
     
Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448

|
Цитата(zltigo @ Oct 25 2009, 22:58)  такого типа фишки Это пять  Цитата(zltigo @ Oct 25 2009, 22:58)  ...выложить исходники в качестве образца, это не подвиг, но что-то героическое в этом есть! Мне такое не по силам, обычно. Угу. Иногда хочется что-то выложить, да стыдно. Причесать можно но, лень. А с тем, за что изначально не стыдно, оказывается жалко расставаться. Вот и остается выкладывать разве что фрагменты в 10 строк максимум.
|
|
|
|
|
Oct 25 2009, 20:51
|

Профессионал
    
Группа: Участник
Сообщений: 1 620
Регистрация: 22-06-07
Из: Санкт-Петербург, Россия
Пользователь №: 28 634

|
Цитата(zltigo @ Oct 25 2009, 23:58)  Не принимайте близко к сердцу - выложить исходники в качестве образца, это не подвиг, но что-то героическое в этом есть! Мне такое не по силам, обычно. Ох ничего себе! Честно говоря, этот кусок скопипастил сам знаете откуда... Срочно поправил на Код unsigned int baud_value = main_clock / baud_rate;
return ((baud_value + 8) / 16);
|
|
|
|
|
Oct 25 2009, 21:16
|

Профессионал
    
Группа: Участник
Сообщений: 1 620
Регистрация: 22-06-07
Из: Санкт-Петербург, Россия
Пользователь №: 28 634

|
Если бы вы, как внимательные читатели, не обратили внимание на этот кусок, так бы оно и неслось по волнам истории, не опускаясь на дно... короче, чтобы закончить жизнь этого наследия, пишу так: Код const unsigned int divisor = baud_rate * 16;
return (main_clock + divisor / 2) / divisor; Интересно, поможет ли начать программировать под ARM это кому-нибудь? Прочитал про копи-пэйст. Поскольку осваивать пришлось весьма спешно, специально начал с минимального файла (единственный main и последовательность кода для ножкодрыгательства), без использования этого набора функций от атмела. Через некоторое время стала понятна идеология разработчиков периферии, уже знал что и где искать в даташите. Startup сначала был от yagarto, потом слегка переделывал.
Сообщение отредактировал Genadi Zawidowski - Oct 25 2009, 22:08
|
|
|
|
|
May 10 2011, 16:48
|
Местный
  
Группа: Свой
Сообщений: 443
Регистрация: 22-07-06
Из: Украина, г. Харьков
Пользователь №: 19 006

|
Цитата(Br.Misha @ May 9 2011, 23:51)  Тут кстати у меня очередная проблема: нигде в украине нет стм32-дискавери. Может кто мне его продать? Или может есть где то схема программатора для stm32, ну и желательно схема отладочной платы. Быть то он есть, в космодроме например, только цену двойную за него ломят. За 11 баксов, как тут вон вверху компеловский баннер рекламирует, я бы и сам с удовольствием взял... Ну там плюс минус. А 20 отдавать как-то пока жаба давит. Хотя может и придется.
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|