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

 
 
> Вычисляемый GOTO на pic18f45j10, максимальное быстродействие
=GM=
сообщение May 19 2008, 15:31
Сообщение #1


Ambidexter
*****

Группа: Свой
Сообщений: 1 589
Регистрация: 22-06-06
Из: Oxford, UK
Пользователь №: 18 282



Понадобилось написать на ассемблере вычисляемый GOTO, аналог switch k на си, с максимально возможным быстодействием. Пока дошёл до такого кода
Код
       movlw   HIGH v8goto
       movwf   PCLATH
       movf    k,w
       addwf   k,w
       addwf   PCL,1
v8goto
       bra     v8mf0     ;k=00
       bra     v8mf1     ;k=01
       bra     v8mf0     ;k=02-MF2(cylinder 1 & 5)
       bra     v8mf0     ;k=03
       bra     v8mf0     ;k=04
и т.д.

Проблема состоит в размещении кода в любом месте программы. После компиляции смотрю, где лежит таблица переходов, если не пересекает 256-байтную границу, то всё в порядке. Интересно бы посмотреть, как кто делает.


--------------------
Делай сразу хорошо, плохо само получится
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
volodya
сообщение May 21 2008, 06:44
Сообщение #2


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

Группа: Свой
Сообщений: 194
Регистрация: 14-02-07
Из: УКРАИНА
Пользователь №: 25 344



Цитата(=GM= @ May 19 2008, 18:31) *
Понадобилось написать на ассемблере вычисляемый GOTO, аналог switch k на си, с максимально возможным быстодействием. Пока дошёл до такого кода
Код
       movlw   HIGH v8goto
       movwf   PCLATH
       movf    k,w
       addwf   k,w
       addwf   PCL,1
v8goto
       bra     v8mf0    ;k=00
       bra     v8mf1    ;k=01
       bra     v8mf0    ;k=02-MF2(cylinder 1 & 5)
       bra     v8mf0    ;k=03
       bra     v8mf0    ;k=04
и т.д.

Проблема состоит в размещении кода в любом месте программы. После компиляции смотрю, где лежит таблица переходов, если не пересекает 256-байтную границу, то всё в порядке. Интересно бы посмотреть, как кто делает.


Попробуйте иначе:

Код
       movlw   HIGH v8goto
       movwf   PCLATH
               movlw  LOW v8goto
       addwf   k,w
       addwf   k,w
               btfsc    STATUS, C
               incf PCTATH, f
       movwf   PCL
v8goto
       bra     v8mf0    ;k=00
       bra     v8mf1    ;k=01
       bra     v8mf0    ;k=02-MF2(cylinder 1 & 5)
       bra     v8mf0    ;k=03
       bra     v8mf0    ;k=04
и т.д.

теперь граница = 0xffff если больше то PCLATH-UP добавить.


--------------------
"Для того чтобы избежать критики, надо ничего не делать, ничего не говорить и никем не быть"
"Каждый из нас бывает дураком по крайней мере пять минут в день; мудрость заключается в том, чтобы не превысить лимит." Элберт Хаббард
Go to the top of the page
 
+Quote Post
=GM=
сообщение May 21 2008, 10:23
Сообщение #3


Ambidexter
*****

Группа: Свой
Сообщений: 1 589
Регистрация: 22-06-06
Из: Oxford, UK
Пользователь №: 18 282



Цитата(volodya @ May 21 2008, 05:44) *
Попробуйте иначе:
Код
   movlw  LOW v8goto
   addwf  k,w
   addwf  k,w
   btfsc  STATUS, C
   incf   PCTATH, f
   movwf  PCL

теперь граница = 0xffff если больше то PCLATH-UP добавить.

Вы считаете, что после первого сложения переноса никогда не будет, а может быть только после второго? Пусть например, LOW v8goto=0xFF, а k=2, тогда после первого сложения будет перенос, а у вас он не учитывается.


--------------------
Делай сразу хорошо, плохо само получится
Go to the top of the page
 
+Quote Post
volodya
сообщение May 22 2008, 12:13
Сообщение #4


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

Группа: Свой
Сообщений: 194
Регистрация: 14-02-07
Из: УКРАИНА
Пользователь №: 25 344



Цитата(=GM= @ May 21 2008, 13:23) *
Вы считаете, что после первого сложения переноса никогда не будет, а может быть только после второго? Пусть например, LOW v8goto=0xFF, а k=2, тогда после первого сложения будет перенос, а у вас он не учитывается.


LOW adr_ROM для команды всегда четный - поскольку команды P18 16(32)бит,
в первом сложении перенос исключен.


--------------------
"Для того чтобы избежать критики, надо ничего не делать, ничего не говорить и никем не быть"
"Каждый из нас бывает дураком по крайней мере пять минут в день; мудрость заключается в том, чтобы не превысить лимит." Элберт Хаббард
Go to the top of the page
 
+Quote Post
=GM=
сообщение May 22 2008, 13:03
Сообщение #5


Ambidexter
*****

Группа: Свой
Сообщений: 1 589
Регистрация: 22-06-06
Из: Oxford, UK
Пользователь №: 18 282



Цитата(volodya @ May 22 2008, 11:13) *
LOW adr_ROM для команды всегда чётный - поскольку команды P18 16(32)бит, в первом сложении перенос исключен


Выше был выбран неудачный пример, пусть LOW v8goto=0xF0, а k=19, вполне реальные числа, у меня три таких вычисляемых GOTO с Кмах=36, 36 и 60. Как видите, адрес чётный и есть перенос при первом сложении.

Не скажу, что я не вижу способов решения задачи, они есть, но все они какие-то громоздкие, крокозябистые...или у меня руки кривые, или это следствие корявой архитектуры и системы команд для пиков, одно из двух (:-).

Опять же, для расчёта количества оборотов двигателя в минуту написал программу деления двух 32-битных чисел, еле поместился в 900 с лишком машинных циклов, ну можно скинуть сотню-другую циклов, но...как-то некрасиво всё выходит (:-(.


--------------------
Делай сразу хорошо, плохо само получится
Go to the top of the page
 
+Quote Post
volodya
сообщение May 23 2008, 04:59
Сообщение #6


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

Группа: Свой
Сообщений: 194
Регистрация: 14-02-07
Из: УКРАИНА
Пользователь №: 25 344



Цитата(=GM= @ May 22 2008, 16:03) *
Выше был выбран неудачный пример, пусть LOW v8goto=0xF0, а k=19, вполне реальные числа, у меня три таких вычисляемых GOTO с Кмах=36, 36 и 60. Как видите, адрес чётный и есть перенос при первом сложении.

Не скажу, что я не вижу способов решения задачи, они есть, но все они какие-то громоздкие, крокозябистые...или у меня руки кривые, или это следствие корявой архитектуры и системы команд для пиков, одно из двух (:-).

Опять же, для расчёта количества оборотов двигателя в минуту написал программу деления двух 32-битных чисел, еле поместился в 900 с лишком машинных циклов, ну можно скинуть сотню-другую циклов, но...как-то некрасиво всё выходит (:-(.


Да ВЫ правы корректнее
Код
       movlw   HIGH v8goto
       movwf   PCLATH
      
       bcf STATUS, C
       rlcf  k, w
       btfsc    STATUS, C      
               incf PCTATH, f  
      
        addlw  LOW v8goto      
        btfsc    STATUS, C
               incf PCTATH, f
       movwf   PCL
TablJMP code 0xYYY00  ;для принудительного расположения в ПЗУ программ
                                ;переносы можно упустить при к < 128
v8goto
       bra     v8mf0 ;k=00
       bra     v8mf1 ;k=01
       bra     v8mf0 ;k=02-MF2(cylinder 1 & 5)
       bra     v8mf0 ;k=03
       bra     v8mf0 ;k=04
и т.д.

Лучше стараться поместится в страницу 128 переодов и распологать принудительно внутри страници ПЗУ - тогда можно не принимать во внимение перенос - экономить такты и восплользоваться Вашим первым вариантом кода.
Архитектура имеет свои плюсы и минусы. Думаю спор о приемуществах и недостатках приведет к maniac.gif .
Хотя согласен с Вами - математика большой производительностью не блещет. Деление занимет много времени. - ограничение ситемы команд.
Тут наверное или мириться или менять CPU.
Удачи!

Сообщение отредактировал volodya - May 23 2008, 05:39


--------------------
"Для того чтобы избежать критики, надо ничего не делать, ничего не говорить и никем не быть"
"Каждый из нас бывает дураком по крайней мере пять минут в день; мудрость заключается в том, чтобы не превысить лимит." Элберт Хаббард
Go to the top of the page
 
+Quote Post
=GM=
сообщение May 23 2008, 15:10
Сообщение #7


Ambidexter
*****

Группа: Свой
Сообщений: 1 589
Регистрация: 22-06-06
Из: Oxford, UK
Пользователь №: 18 282



Цитата(volodya @ May 23 2008, 03:59) *
Лучше стараться поместить в страницу 128 переходов и располагать принудительно внутри страницы ПЗУ - тогда можно не принимать во внимание перенос - экономить такты и воспользоваться Вашим первым вариантом кода


Пожалуй, воспользуюсь я вашим советом и размещу три таблицы в начале трёх страниц. С учётом того, что пока k<61 (а в обозримом будущем вряд ли будет больше) код получится более-менее приличный

Код
   movlw   HIGH v8goto
   movwf   PCLATH
   bcf     STATUS,C
   rlcf    k,w   ;k<128, no carry
   movwf   PCL,f

v8goto
   bra    v8mf0 ;k=00
   bra    v8mf1 ;k=01
   bra    v8mf0 ;k=02-MF2(cylinder 1 & 5)
   bra    v8mf0 ;k=03
   bra    v8mf0 ;k=04
и т.д.

Так лучше, чем мой первоначальный код, потому что здесь код вычисления перехода не обязательно размещать прямо перед таблицей. А в том коде ещё одна проблема возникнет с вычислением адреса перехода, если таблица займёт целую страницу (для k=128).


--------------------
Делай сразу хорошо, плохо само получится
Go to the top of the page
 
+Quote Post



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

 


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


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