реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> Вразумите по SAM7S
MSprut
сообщение Nov 21 2007, 07:45
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 225
Регистрация: 25-04-06
Из: Украина, Луганск
Пользователь №: 16 476



Долгое время работал с АТ90 и Atmega AVR, но вот пришел день, когда появилась необходимость ставить ARM. В проекте есть ЖКИ 320х240 с тач-панелью и кусок автоматики. Если делать на меге, то придется ставить 2 проца - один на ЖКИ, один на автоматику и вот я решил поставить SAM7S256, но... Начитавшись всяких описаний и форумов увидел что не все так сказочно. Много новых, непонятных для моего мозга наворотов, типа ремапа, регистров, которые туда-сюда между режимами бродят и прочего бутора. Использовать планировал компилятор IAR, но загрузив пару примеров не смог провести для себя параллель между Atmega и ARM-ом. Мозг пытается найти привычные вещи, а что-то их нету. Я бы эту тему не поднимал, если бы не сжатые сроки для проекта - до января нужно чтобы он хоть как-то начал жить, и всю обвеску, кроме проца, уже наваял, готовлюсь плату развести, а с самим процем в ступоре. И Мегу ставить не хочется, потому что для ЖКИ не смогу ничего путнего в неё впихнуть и не знаю сколько мне понадобится для освоения SAM7S256. Короче в голове полная каша. Не могу понять что нужно делать, а что не нужно чтобы все это сразу заработало, как на меге, т.е. создал проект, подключил заголовичники, создал пару функций и чтобы это сразу завелось. Куда что ремапить нужно или не нужно и т.д. Может кто из уважаемых форумчан растолкует мне чего я не могу понять в ARM-е, хотя бы для того чтобы определится ставить этот проц или забить на все и ставить две меги с внешней памятью и т.д, потому что не реально за 1 месяц заставить ARM как-то работать? Буду очень признателен.
Go to the top of the page
 
+Quote Post
xelax
сообщение Nov 21 2007, 08:05
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 370
Регистрация: 7-11-06
Пользователь №: 22 035



Возможно я подзабыл, но разве IAR сам не цепляет к проекту стартапный код. Где уже есть раскладка векторов, выделение стека, ремап и прочие стартовые вещи.
А девелоперу надо только написать пару функций.
По крайней мере я так начинал, правда на lpc2106.
Go to the top of the page
 
+Quote Post
MSprut
сообщение Nov 21 2007, 08:22
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 225
Регистрация: 25-04-06
Из: Украина, Луганск
Пользователь №: 16 476



За IAR для ARM ничего не могу сказать, в стартапе для авр у меня только очистка памяти была. Но там и лишних телодвижений не нужно было, все работало сразу
Go to the top of the page
 
+Quote Post
anpilog
сообщение Nov 21 2007, 08:56
Сообщение #4


Частый гость
**

Группа: Свой
Сообщений: 145
Регистрация: 11-12-06
Пользователь №: 23 382



По собственному опыту скажу.
В принципе для не сверх сложной задачи, можно стартонуть и без ремапов и т.п. непонятных вещей.

За месяц можно вполне толково разобраться в нужной переферии для ваянии несложных проектов.


--------------------
---
human traffic - всегда 8)
Go to the top of the page
 
+Quote Post
MSprut
сообщение Nov 21 2007, 09:56
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 225
Регистрация: 25-04-06
Из: Украина, Луганск
Пользователь №: 16 476



Ну нужно будет работать с АЦП, с таймером, SPI и порт 32-х битный как-то поделить на всех. ЖКИ блин 8-и битный. В АРМе можно с 8-и битными данными работать или нет. Какой режим использовать лучше на старте, АРМ или Тумб? Можно это все запускать без JTAG? А еще у меня самая первая версия SAM7S256 из партии 58818С с багами во флеш, еще где-то. Куплен давно и только сейчас может найтись ему применение.
Go to the top of the page
 
+Quote Post
IV_K
сообщение Nov 21 2007, 10:11
Сообщение #6


Частый гость
**

Группа: Свой
Сообщений: 121
Регистрация: 17-06-05
Пользователь №: 6 087



в арме главное мышление на 32 бита перевести =) остальное приложится.. режим арм или тумб пофик какой, для сишного кода оно не так важно, с 8-ми битными данными работать так же как всегда, без житага работать можно, есть такая замечательная вещь, как samba - загрузчик по юсб и компорту. но житаг советую купить, с ним намного проще
Go to the top of the page
 
+Quote Post
MSprut
сообщение Nov 21 2007, 10:36
Сообщение #7


Местный
***

Группа: Свой
Сообщений: 225
Регистрация: 25-04-06
Из: Украина, Луганск
Пользователь №: 16 476



Ну с 32-х битными регистрами понятно, и с переменными такой же длины а вот с переменными меньшей длины чето не очень пока. Или компилятор допускает использование переменных короче чем разрядность проца? И с портом получается придется работать по маске. В АВРке разрядность портов и данных совпадала и можно было целиком пихать все в порт, а тут получается по маске вытер, по маске записал. Еще не понятно что за прикол с выполнением функций из SRAM? Я привык что все во флеш компилится и оттуда же выполняется, а тут на каждом шагу стереотипы ломают.
Go to the top of the page
 
+Quote Post
zhevak
сообщение Nov 21 2007, 10:43
Сообщение #8


Знающий
****

Группа: Свой
Сообщений: 723
Регистрация: 29-08-05
Из: Березовский
Пользователь №: 8 065



Наверно я ретроград.

Будь я на Вашем месте, я бы все-таки выбрал реализацию на том, что знаешь хорошо. И вот почему.

Постулат №1. Вашему заказчику (т.е. тому, кто платит Вам деньги), на сколько я понял из вашего сообщения, без разницы на чем будет построен девайс -- на АРМе-ли, на АВРке-ли. Ему нужен конечный результат. Заказчик платит за конечный результат.

Постулат № 2. Ваша цель -- заработать деньги. Ну так и зарабатывайте! Ничто Вам не мешает.

Нехватает "прыгучести" АВР-ки, возьмите две, три штуки, назначьте им конкретные задачи и свяжите их по какой-нибудь шине. Выиграете и по времени разработки, и по скорости работы устройства в целом.

Что АВР-ки, что АРМ-ы -- стоят сейчас копейки, соизмерьте их стоимость со стоимостью своего рабочего часа. А времени, как я понял, у Вас -- месяц. Ну и на чем вы сэкономите? На паре микросхем? Помните, старые туфли ноги не трут, а Вам предстоит ответственный забег за деньгами. Что Вы выберите?

Если Вам не важен результат, на деньги Вы не повязаны, тогда смело выбирайте АРМ. Освоите новый камень.

И еще. Не надо смотреть на мир АРМов глазами АВР/i51/i8080/i86. Это абсолютно другой мир. Разница между мирами даже не в разрядности и тактовой частоте, а совсем в друом. Пока Вы сами не поработаете с той и с другой архитектурой, пока не познаете ту и другую философию, Вы не будете в состоянии сделать правильный выбор.

Искренне желаю удачи Вам!

Сообщение отредактировал zhevak - Nov 21 2007, 10:55


--------------------
Хочешь рассмешить Бога -- расскажи ему о своих планах!
Go to the top of the page
 
+Quote Post
MSprut
сообщение Nov 21 2007, 11:12
Сообщение #9


Местный
***

Группа: Свой
Сообщений: 225
Регистрация: 25-04-06
Из: Украина, Луганск
Пользователь №: 16 476



Спасибо, доходчивая мотивация. Тут как раз вариант №4: важен рельтат и время, но на деньги я не завязан. Хотя больше меня привлекает вариант с установкой 2-х АВР-ок, но тогда, думаю, придется забыть про нормальный GUI-евый интерфейс, а хотелось бы заложится на него, если не сразу написать, то в перспективе чтобы мощи хватило. Вот и мучаюсь с выбором.
Go to the top of the page
 
+Quote Post
IV_K
сообщение Nov 21 2007, 11:27
Сообщение #10


Частый гость
**

Группа: Свой
Сообщений: 121
Регистрация: 17-06-05
Пользователь №: 6 087



при использовании переменных меньшей длины отдельно - каждая будет занимать 32 бита, в виде структур можно задать упаковку (в иаре смотреть #pragma pack) разрядность портов и данных тут тоже совпадает =)) с PIO в сам7 работать кстати удобно, надо только привыкнуть.. и еще.. арм НЕ НОГОДРЫГАЛКА =) на работу с периферией нужно много тактов, поэтому там куча аппаратных наворотов типа DMA. насчет выполнения команд из рамы.. в арме адресное пространство в отличие от авров ОДНО и ЛИНЕЙНО, поэтому процу вобще пофик откуда выполнять команды и откуда брать данные. для запуска функций из рам их сначала надо туда скопировать из флеши, для этого есть в иаре __ramfunc - копирует в рам код стартапа, ну или ручками копировать.. код из рамы выполняется БЫСТРЕЙ, чем из флеш. и еще преимущество.. код из рамы может выполняться во время стирания/записи флеши, удобно для загрузчиков

p.s. за меся КАК-ТО работать сам7 заставить можно, но написать с нуля целевую программу нереально
Go to the top of the page
 
+Quote Post
zltigo
сообщение Nov 21 2007, 12:05
Сообщение #11


Гуру
******

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



Цитата(MSprut @ Nov 21 2007, 09:45) *
... не реально за 1 месяц заставить ARM как-то работать?

За месяц - реально, только если вместо задаваемых здесь риторических вопросов потратите день на изучение архитектуры и чтение вопросов/ответов ранее задаваемых на этом форуме Вашими предшественниками. Ну и если настрой будет другой - за здравие а не за упокой.
Я в свое время ровно за два выходных дня начал, отпортировал минимальные начальные вещи со 186 на ARM и получил стартовый результат.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Nov 21 2007, 12:21
Сообщение #12


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(zhevak @ Nov 21 2007, 12:43) *
Будь я на Вашем месте, я бы все-таки выбрал реализацию на том, что знаешь хорошо. И вот почему.
Категорически не согласен. Если человек имеет достаточно опыта, чтобы реализовать описанный проект хотя бы на меге - освоение ARMа на уровне, достаточном для написания того же займет пару дней - неделю. Надо только не лениться читать документацию. А возможности системы на ARMе будут гораздо выше. Плюс человек получит мощный инструмент в своем арсенале. Пока не нужен загрузчик - не нужно заморачиваться о всяких ремапах, стартапах - в библиотеках компилятора уже все сделано.
Про переменные меньшей, чем 32 бита длины: Во-первых система команд поддерживает работу с 8- и 16-битными данными. В С просто объявляете uint8_t, uint16_t, uint32_t или unsigned char, unsigned short, unsigned long и получаете данные нужной длины. По запись байта в порт - у портов SAM7 есть набор регистров OWER, OWDR, OWSR, в которых вы можете указать, какие именно биты будут писаться в порт при записи в ODSR. Вы можете указать необходимые 8 бит и писаться в порт будут именно они.
Резюме - не так страшен черт.

Цитата(IV_K @ Nov 21 2007, 13:27) *
при использовании переменных меньшей длины отдельно - каждая будет занимать 32 бита,
Где вы такое вычитали? Каждая переменная будет занимать столько места, каков ее размер. Другое дело, что начальные адреса переменных выравниваются - 4-байтных на 4 байта, 2-байтных на 2 байта. Поэтому long, char, char, short и long, char, short, char займут 8 и 9 байт, а не 16 как следует из вашего утверждения.

С остальным соглаcен.
Цитата(IV_K @ Nov 21 2007, 13:27) *
p.s. за меся КАК-ТО работать сам7 заставить можно, но написать с нуля целевую программу нереально
Задача формулировалась несколько иначе - "до января нужно чтобы он хоть как-то начал жить", а это, на мой взгляд, вполне реально.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
IV_K
сообщение Nov 21 2007, 12:56
Сообщение #13


Частый гость
**

Группа: Свой
Сообщений: 121
Регистрация: 17-06-05
Пользователь №: 6 087



Цитата(Сергей Борщ @ Nov 21 2007, 15:21) *
Где вы такое вычитали? Каждая переменная будет занимать столько места, каков ее размер. Другое дело, что начальные адреса переменных выравниваются - 4-байтных на 4 байта, 2-байтных на 2 байта. Поэтому long, char, char, short и long, char, short, char займут 8 и 9 байт, а не 16 как следует из вашего утверждения.


звиняюсь, фигню сказал.. хотел про упаковку структур сказать, но что-то не то вышло =)
Go to the top of the page
 
+Quote Post
MSprut
сообщение Nov 21 2007, 13:09
Сообщение #14


Местный
***

Группа: Свой
Сообщений: 225
Регистрация: 25-04-06
Из: Украина, Луганск
Пользователь №: 16 476



Убедили, всем большое спасибо. Закладываю АРМ...

Сообщение отредактировал MSprut - Nov 21 2007, 13:10
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 27th July 2025 - 17:46
Рейтинг@Mail.ru


Страница сгенерированна за 0.03132 секунд с 7
ELECTRONIX ©2004-2016