Перейти к содержанию
    

Как заставить работать оба АЛУ

Доброго времени суток!

 

Пишу для Blackfin 504f программу в Visualdsp++. Необходимо, как обычно, максимально ускорить выполнение операций (для обработки сигнала в реальном времени).

Есть у меня цикл for, где выполняются 2 команды, каждая из которых загружает только 1 АЛУ. В дизасемблере они выполняются по очереди. И по количеству тактов можно судить, что так и есть. Однако хотелось бы заставить выполняться их параллельно - благо, теоретически это возможно, возможности ядра позволяют.

Когда-то давно читал о неком "заклинании" (то ли это #pragma..., то ли #define..., то ли еще что-то), которое заставляет цикл for работать быстрее именно по принципу выполнения параллельных операций. Но сейчас этого не помню, а найти не могу :(

 

Может, посоветуете что-нибудь (кроме того, чтобы написать все на ассемблере с символом "||").

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Не знаю, позволяют ли АЛУ вашего проца выполнять параллельно разные инструкции.

Часто в многопроцессорных системах и в DSP используют концепцию SIMD (single instruction, multiple data), т.е. все процессоры параллельно выполняют одни и те же инструкции, но каждый - со своими данными. Если ваши 2 АЛУ придерживаются той же идеологии, то в общем случае поставленную задачу не решить.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Доброго времени суток!

 

Пишу для Blackfin 504f программу в Visualdsp++. Необходимо, как обычно, максимально ускорить выполнение операций (для обработки сигнала в реальном времени).

Есть у меня цикл for, где выполняются 2 команды, каждая из которых загружает только 1 АЛУ. В дизасемблере они выполняются по очереди. И по количеству тактов можно судить, что так и есть. Однако хотелось бы заставить выполняться их параллельно - благо, теоретически это возможно, возможности ядра позволяют.

Когда-то давно читал о неком "заклинании" (то ли это #pragma..., то ли #define..., то ли еще что-то), которое заставляет цикл for работать быстрее именно по принципу выполнения параллельных операций. Но сейчас этого не помню, а найти не могу :(

 

Может, посоветуете что-нибудь (кроме того, чтобы написать все на ассемблере с символом "||").

 

 

http://www.analog.com/media/en/technical-d...otes/EE-149.pdf

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

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

Гость
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...