Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

Что-то типа:

Отправлено vmp 24 января 2008 г. 22:34
В ответ на: тогда, кстати, проясните, что именно надо в команде (на С например, или псевдокодом) отправлено SM 24 января 2008 г. 22:12

для 32-битного варианта:
Команда "замена N" . Аргумент N - константа от 0 до 7.
Неявно используются 2 регистра - аккумулятор и адрес таблицы замены.
Описание:

uint32 acc; // аккумулятор
uint32 *uz; // адрес узла замены

uint4 temp3; // тетрада
uint32 temp32; // строка узла замены

// Выделить N-ную тетраду
temp4 = (acc >> (N * 4)) & 0xF;
// Прочитать строку узла замены
// адрес = uz + (temp4 << 2); !!!
temp32 = uz[temp4];
// Вставить тетраду из узла замены на место:
// Написано на Си, в кремнии намного проще.
temp32 &= (0xF << (N * 4)); // оставить только нужную тетраду
acc &= ~(0xF << (N * 4)); // очистить старое место в аккумуляторе
acc |= temp32; // вставить
// Результат в acc

//Для замены полного слова нужно дать 8 команд:
Замена 0
Замена 1
........
Замена 7



Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
увеличьте 3 в два раза:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru