Вверх ↑
Этот топик читают: Гость
Ответов: 1304
Рейтинг: 405
#196: 2014-01-15 23:58:53 ЛС | профиль | цитата
Netspirit, решил немного покопаться в hiMathParse дабы запустить в x64 но результат не порадовал, пример приведённый выше не совсем корректный, компиляции удалось добиться только с директивами как в следующем примере
code_32818.txt
но результат вычислений не соответствует реальному. Кроме того вставка директив в hiMathParse приводит к синтаксическим ошибкам.
Netspirit писал(а):
А по поводу MathParse - я посмотрю, вроде объявленные там функции должны быть стандартными для FPC, использую их.
наверное это лучший вариант.

карма: 3

0
файлы: 1code_32818.txt [1.3KB] [551]
Ответов: 1304
Рейтинг: 405
#197: 2014-01-17 19:11:31 ЛС | профиль | цитата
Netspirit, убрал ASM вставки из hiMathParse заменив на тождественные из набора базовых функций, компиляция на x64 прошла успешно а вот результат вычислений для плавающих типов поплыл . Ниже правленый hiMathParse.
http://forum.hiasm.com//getfile/32841
карма: 3

1
файлы: 1projectwin64.rar [6.4KB] [503]
Голосовали:Netspirit
Ответов: 4628
Рейтинг: 749
#198: 2014-01-17 19:31:44 ЛС | профиль | цитата
Сейчас не могу проверить твой вариант.
Там в FPC есть стандартные функции в Math: FPC2srcobjpasmath.pp
Ещё, если кто разбирается, можно эти функции переписать на иснтрукциях SSE вместо MMX.
карма: 26

0
Ответов: 1304
Рейтинг: 405
#199: 2014-01-17 19:58:42 ЛС | профиль | цитата
Netspirit, в архиве маленький пример который показует что проблема глубже чем убрать ASM вставки из hiMathParse.
карма: 3

0
Ответов: 4628
Рейтинг: 749
#200: 2014-01-18 21:30:32 ЛС | профиль | цитата
Проблема не в неправильных вычислениях, а в неправильном выводе результатов - в x64 неправильно работает функция KOL.Extended2Str.
code_32846.txt
------------ Дoбавленo в 21.30:
Переписал Extended2Str на аналогичную из FPC. Поправил MathParse.

Распаковать архив с заменой в папку HiAsm.
После распаковки выполнить HiAsmcompilerFPC2src\_make_x64.bat

карма: 26

1
файлы: 1code_32846.txt [1KB] [613]
Голосовали:MAV
Ответов: 1304
Рейтинг: 405
#201: 2014-01-19 20:44:40 ЛС | профиль | цитата
Netspirit, внесённые изменения заработали без ошибок. Далее три доработаных компонента совместимых с x64.
ps: старый fpc как старая мебель и место занимает и выкинуть жалко , куда ему тягаться с новым fpc x32.
ps2: Netspirit, зпустить бы ещё панель и редакторы текста
карма: 3

0
файлы: 1fpcx64_fix.rar [2.9KB] [334]
Ответов: 4628
Рейтинг: 749
#202: 2014-01-20 11:49:41 ЛС | профиль | цитата
MAV писал(а):
зпустить бы ещё панель и редакторы текста

Попробую
карма: 26

0
Ответов: 1841
Рейтинг: 369
#203: 2014-01-28 18:34:11 ЛС | профиль | цитата
Всё конечно хорошо, но без отладчика отлаживать всё это дело, тяжко
Попробую прикрутить отладчик к пакету, посмотрим что выйдет.

А для более удобного и быстрого исследования кода, прикрутил пакет к среде Lazarus, жаль только, пока не получилось произвести компиляцию из среды Лазаруса
карма: 1
0
Ответов: 4628
Рейтинг: 749
#204: 2014-01-28 22:46:42 ЛС | профиль | цитата
Из Лазаруса по-умолчанию не скомпилируется - нужно внести некоторые поправки в модуль Windows и пересобрать. Или попробовать взять этот модуль отсюда, но придется пересобрать другие зависимые модули.
Также может быть лучшим вариантом натравить Лазарус на использование только модулей в папке compilerFPC2unitsXX. Для этого нужно поместить в папку с проектом файл fpc.cfg с соответствующими параметрами или настроить в свойствах проекта. Не знаю, правда, будет ли работать отладчик.
карма: 26

0
Ответов: 1841
Рейтинг: 369
#205: 2014-01-29 13:19:00 ЛС | профиль | цитата
Netspirit, это я уже понял, но мне как то всё равно, откуда запускать, задача была получить больше информации, в случае критической ошибки
Вот кстати, чего я добился:
Debug Line



Это кстати схема DelphiExampleDrawAll_Img_Draw_&_Print.sha
Как оказалось, отладчик подключается на раз-два, а вот вывести информацию о строках с ошибками, уже не так просто.
В качестве решения пришлось подключить exeinfo.pp, lineinfo и зависимые модули, из исходников fpc, что дало возможность получать расширенную информацию об ошибке
------------ Дoбавленo в 04.24:
Итак, пока не заснул, вот архив с добавлением расширенной информации об ошибках.
hiasm_fpc_debug.zip

Последовательность действий:
1) Распаковать в каталог с HiAsm.
2) Добавить 2 новых компилятора, запустив: HiAsmcompilerFPC2Install_debug.his
2.1) Или добавив вручную:
Командная строка FPCx32_Debug

"%fname%" -Twin32 -Scghi -O1 -g -gl -WG -viewnhi

-FU"%upath%units32_debug"
-Fu"%curdir%compilerFPC2units32_debug"
-FE"%opath%"
Командная строка FPCx64_Debug

"%fname%" -Twin64 -Scghi -O1 -g -gl -WG -viewnhi

-FU"%upath%units64_debug"
-Fu"%curdir%compilerFPC2units64_debug"
-FE"%opath%"
Остальные параметры соответствуют профилям FPCx32 и соответственно FPCx64

3) Собрать модули, запустив HiAsmcompilerFPC2src\_make_x32_debug.bat и/или HiAsmcompilerFPC2src\_make_x64_debug.bat.
4) Если ничего не упустил (сонный), теперь при компиляции схемы с одним из новых профилей компиляторов, при возникновении ошибок, мы получим расширенную информацию.

Как то так
------------ Дoбавленo в 13.19:
Так, теперь бы подключить к пакету ещё и кодовою базу Lazarusa, но как я понял, это будет не так уж и просто
карма: 1
2
файлы: 1hiasm_fpc_debug.zip [16.8KB] [360]
Голосовали:Netspirit, LastLeader
Ответов: 4628
Рейтинг: 749
#206: 2014-02-09 20:14:14 ЛС | профиль | цитата
CriDos, никак не удалось получить сообщения об ошибках с названиями файлов и процедур как у тебя.
Вот как я для себя сделал. Пробовал даже твой вариант без изменений. Посмотри, может что не так.
Или программу нужно запускать под отладчиком?
карма: 26

0
Ответов: 1841
Рейтинг: 369
#207: 2014-02-10 08:03:53 ЛС | профиль | цитата
Netspirit писал(а):
Или программу нужно запускать под отладчиком?

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

Netspirit, только что проверил, вроде всё работает.
Если ты проверял на примере "DelphiExampleDrawAll_Img_Draw_&_Print.sha", то нужно сначало исправить тип аргументов методов в файле "hiIntegerArray.pas" с cardinal на NativeInt, и потом скомпилировать схему 64 битным компилятором (FPCx64_Debug), т.к. с 32 битным проблем не возникает в данной схеме.

На всякий случай, архив с интегрированным дебагом:
HiAsm_AltBuild_fpc.7z
После извлечения, необходимо будет запустить _make_x32_debug.bat и/или _make_x64_debug.bat.
карма: 1
0
Ответов: 4628
Рейтинг: 749
#208: 2014-02-10 22:22:47 ЛС | профиль | цитата
Да, на этой схеме у меня тоже заработало. В некоторых случаях прием не срабатывает: на выходных целый день искал ошибки с помощью расстановки MessageBox'ов.
карма: 26

0
Ответов: 1841
Рейтинг: 369
#209: 2014-02-11 04:54:37 ЛС | профиль | цитата
Netspirit, ну, вообще, если взглянуть на эту мешанину ASM, fpc старого синтаксиса, delphi старого синтаксиса, delphi нового синтаксиса и новый компилятор FPC, я удивился, что данный способ вообще заработал)
В общем, к-во граблей использованных в пакете Delphi и библиотеке KOL, просто зашкаливает, и первое что пришло в голову: "блин, легче переписать пакет ", т.к. в дальнейшем на отлов ошибок (особенно логических), может уйти куча времени...

В итоге, у нас имеется: Куча потенциальных ошибок в оригинальном пакете + грабли под старые компиляторы, и теперь ещё в придачу, куча ошибок в новом + переработанные грабли под новый компилятор и x64 битку + ещё больше потенциально новых ошибок, и всё это приправлено новым KOL с исправленными ошибками и с возможными новыми ошибками
Отсутствие вспомогательных современных инструментов, так же в разы усиливает "эффект жести"...

p.s. Это так, размышления в слух
карма: 1
0
Ответов: 4628
Рейтинг: 749
#210: 2014-02-11 12:13:45 ЛС | профиль | цитата
Да, я тоже считаю, что KOL написана в стиле "баг на костылях, граблями подгоняемый". Но единственная проблема в том, что автор тестирует её только на Delphi без какой-либо оглядки на FPC, при этом не гнушаясь использовать "грязные хаки" по особенностях конкретного компилятора.
Но не вижу никаких принципиальных трудностей, не позволяющих довести связку новых FPC+KOL 32/64 до юзабельного состояния.

Из недавно обнаруженного: в KOL отключено выравнивание записей с комментарием "align off, otherwise code is not good". Необходимость в этом вероятно возникла из-за использования относительных смещений в каких-то функциях. Тогда как выравнивание наоборот призвано ускорить доступ к полям записей, а в x64 ещё и Windows API требуют записей, выровненных по 8 байт. Приходится объявленные в KOL записи искусственно "выравнивать" дополнительными полями. Проверю, будет ли много ошибок, если выравнивание таки включить.
карма: 26

0
Сообщение
...
Прикрепленные файлы
(файлы не залиты)