Re: Более удобное представление ассемблера...
От: kov_serg Россия  
Дата: 01.11.25 06:04
Оценка: 6 (3) +1
Здравствуйте, Shmj, Вы писали:

S>А если еще умнее, типа:


https://en.wikipedia.org/wiki/Blackfin
https://microsin.net/programming/dsp/blackfin-instruction-set-reference-part1.html
https://microsin.net/programming/dsp/blackfin-instruction-set-reference-part2.html
Re: Более удобное представление ассемблера...
От: netch80 Украина http://netch80.dreamwidth.org/
Дата: 31.10.25 16:16
Оценка: 5 (3) +1
Здравствуйте, Shmj, Вы писали:

S>let eax = eax + 4;


https://github.com/torvalds/linux/blob/master/arch/hexagon/kernel/head.S
The God is real, unless declared integer.
Re: Более удобное представление ассемблера...
От: alpha21264 СССР  
Дата: 30.10.25 08:47
Оценка: +3
Здравствуйте, Shmj, Вы писали:

S>Вот ранее был типа High-Level Assembler:

...
S>А если еще умнее, типа:

S>
S>let ebx = eax;
S>let eax = eax + 4;
S>


S>Вроде чел. делал такой проект, кто помнит?


А зачем? Языки высокого уровня придуманы в 1960-х годах.
И если ты сейчас пишешь на ассемблере, то и пиши на ассемблере.

PS.
Ассемблер DEC VAX был весьма высокоуровневым.
И... нормально переносился на Альфу — процессор совершенно другой архитектуры.

Течёт вода Кубань-реки куда велят большевики.
Re[5]: Более удобное представление ассемблера...
От: Privalov  
Дата: 06.11.25 13:33
Оценка: +2
Здравствуйте, Shmj, Вы писали:

S>В реальном режиме — это под какую ОС?


MS DOS. Приходилось пару раз опускаться на уровень железа. Однажды даже для какого-то проекта русификатор клавиатуры встроенный сделал. Уже не помню, чем там коллег обычный драйвер не устроил. На встроенном ассемблере это оказалось очень просто.

S> Если ассемблер в отдельных файлах, то можно настроить сборку и перевести сами файлы под конкретную платформу. Когда же все намешано внутри C-кода — это ужас.


Так я ж писал: зе беспорядочное использование встроенного ассемблера надо отрывать руки.
Re[3]: Более удобное представление ассемблера...
От: CRT  
Дата: 06.11.25 14:16
Оценка: +2
Здравствуйте, Shmj, Вы писали:


S>А если немного синтаксического сахара? К примеру — метки с человеческим именем — ведь в машинных кодах это просто номер ячейки


Метки в ассемблере и так уже с человеческим именем, как и команды. В этом и есть смысл ассемблера — заменить числовые коды на человеческие легко запоминаемые имена.

Ассемблер — это взаимнооднозначное отображение команды ассемблера и ее операндов в машинную команду и операнды.

а вот это
if( eax > ebx ) then
stdout.put("eax > ebx", nl);
endif;

Это что такое? Никак не ассемблер.

С тем же успехом можно выучить наизусть как конструкции С++ переводятся в машинные команды и назвать С++ ассемблером.

Ну конечно у С++ есть оптимизатор поэтому одно и то же может в разные команды переводиться. Хорошо, допустим мы отключаем оптимизатор.
Re[3]: Более удобное представление ассемблера...
От: netch80 Украина http://netch80.dreamwidth.org/
Дата: 06.11.25 08:52
Оценка: 2 (1)
Здравствуйте, Михаил Романов, Вы писали:

N>>https://github.com/torvalds/linux/blob/master/arch/hexagon/kernel/head.S

МР>А можете дать ссылку на описание этой нотации?

Из статьи про hexagon есть ссылки на всякое про ISA.

МР>По расширению имени файла я предположил было, что это GNU-нотация для ассемблера, но она (как я посмотрел) все же ближе к традиционной <мнемоника>+<операнды>, там отличие от того же Intel в некоторых деталях синтаксиса.


Это действительно ассемблер, просто некоторые из них сделаны чуть более похожими по стилю на C. Названный в соседнем постинге Blackfin ещё ближе к этому (я его сходу не нашёл, но помнил; вспомнил бы сразу, запостил бы про него, а не Hexagon). Вот понравилось кому-то делать ассемблер в другом стиле — не словесные мнемоники, а знаки.
The God is real, unless declared integer.
Re: Более удобное представление ассемблера...
От: Евгений Музыченко Франция https://software.muzychenko.net/ru
Дата: 30.10.25 09:14
Оценка: +1
Здравствуйте, Shmj, Вы писали:

S>Вот ранее был типа High-Level Assembler:


Это грубый, неэффективный и тупиковый путь. Годится лишь для упертых фанатов ассемблера. Гораздо эффективнее добавлять доступ к процессорным регистрам и командам в "низкоуровневые ЯВУ" вроде C.
Re: Более удобное представление ассемблера...
От: SergeyIT Россия  
Дата: 30.10.25 11:45
Оценка: +1
Здравствуйте, Shmj, Вы писали:

S>А если еще умнее, типа:


S>
S>let ebx = eax;
S>let eax = eax + 4;
S>


S>Вроде чел. делал такой проект, кто помнит?


Так это Basic...
Извините, я все еще учусь
Re: Более удобное представление ассемблера...
От: BlackEric http://black-eric.lj.ru
Дата: 30.10.25 17:29
Оценка: +1
Здравствуйте, Shmj, Вы писали:

По состоянию на 2025 год я бы ассемблером высокого уровня назвал С. Ну или хотя бы С отнес к языкам среднего уровня. Потому что считать, что С, C#, Java и Python являются языками одного уровня я бы не стал.
Получается по уровням от низкого к высокому что-то вроде
1. Assembler
2. C, возможно JavaScript
3. C#, Java, Python, TypeScript.
https://github.com/BlackEric001
Re: Более удобное представление ассемблера...
От: hi_octane Беларусь  
Дата: 30.10.25 20:24
Оценка: +1
S>Вроде чел. делал такой проект, кто помнит?
Был проект С-- (си минус минус) — пишешь почти на C, но в тоже время на асме. Я писал на нём всего пару прог, но ощущение было "как инструмент под задачу пушкабомба". Получалась просто золотая середина между близким к железу и обычным программированием.
Re[2]: Более удобное представление ассемблера...
От: Shmj Ниоткуда  
Дата: 06.11.25 04:45
Оценка: +1
Здравствуйте, alpha21264, Вы писали:

A>А зачем? Языки высокого уровня придуманы в 1960-х годах.

A>И если ты сейчас пишешь на ассемблере, то и пиши на ассемблере.

Это и есть ассемблер — ты не уходишь от регистров. На ЯВУ — нет прямого доступа к регистрам.

Просто чуть другой формат записи и немного синтаксического сахара.
=сначала спроси у GPT=
Отредактировано 06.11.2025 4:47 Shmj . Предыдущая версия .
Re[2]: Более удобное представление ассемблера...
От: AWSVladimir  
Дата: 06.11.25 04:54
Оценка: :)
Здравствуйте, hi_octane, Вы писали:

S>>Вроде чел. делал такой проект, кто помнит?

_>Был проект С-- (си минус минус) — пишешь почти на C, но в тоже время на асме.

Зачем?
Макроассемблером вполне можно писать как на высоком языке программирования.
Re[3]: Более удобное представление ассемблера...
От: Евгений Музыченко Франция https://software.muzychenko.net/ru
Дата: 06.11.25 18:45
Оценка: +1
Здравствуйте, Shmj, Вы писали:

S>ассемблерные вставки?


Нет. Ассемблерные вставки — это костыли "от бедности". Правильный путь — псевдопеременные для обращения к регистрам и флагам, intrinsic-функции для выполнения спецкоманд процессора, и т.п.
Re[3]: Более удобное представление ассемблера...
От: Евгений Музыченко Франция https://software.muzychenko.net/ru
Дата: 06.11.25 19:00
Оценка: +1
Здравствуйте, Shmj, Вы писали:

S>Это и есть ассемблер — ты не уходишь от регистров.


Любой язык, идущий "от ассемблера" (то есть, от системы команд), будет по определению архитектурно-зависимым, и с этим ничего не сделать.

Если же идти "от ЯВУ", то даже самые основные средства, вроде intrinsic-функций, реализующих операции, которые есть во многих архитектурах, решают примерно 80% задач, ради которых приходится использовать ассемблер.

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

S>На ЯВУ — нет прямого доступа к регистрам.


В некоторых есть.

S>Просто чуть другой формат записи и немного синтаксического сахара.


А нету в нем практического смысла. Его еще лет тридцать-сорок назад не было, хотя по инерции продолжали добавлять в ассемблеры псевдоконструкции для условных операций, циклов, автоматическое формирование стековых кадров и прочего. А потом уже остался только один путь — снижать уровень наиболее подходящих ЯВУ. Повышать уровень ассемблера — абсурд.
Более удобное представление ассемблера...
От: Shmj Ниоткуда  
Дата: 30.10.25 07:46
Оценка:
Вот ранее был типа High-Level Assembler:

mov( ebx, eax );
add( 4, eax );
if( eax > ebx ) then
    stdout.put("eax > ebx", nl);
endif;


А если еще умнее, типа:

let ebx = eax;
let eax = eax + 4;


Вроде чел. делал такой проект, кто помнит?
=сначала спроси у GPT=
Отредактировано 30.10.2025 7:46 Shmj . Предыдущая версия .
Re: Более удобное представление ассемблера...
От: ononim  
Дата: 30.10.25 10:17
Оценка:
такое знаю https://v8.dev/blog/csa
Как много веселых ребят, и все делают велосипед...
Re[2]: Более удобное представление ассемблера...
От: Pauel Беларусь http://blogs.rsdn.org/ikemefula
Дата: 05.11.25 08:19
Оценка:
Здравствуйте, BlackEric, Вы писали:

BE>Получается по уровням от низкого к высокому что-то вроде

BE>1. Assembler
BE>2. C, возможно JavaScript

Интересная штука, у меня переход на JS вызвал ровно те же ощущения, как в далёком детстве при переходе с Паскаля на Ассемблер. Везде за всем надо следить и тд.
Re[2]: Более удобное представление ассемблера...
От: Михаил Романов Удмуртия https://mihailromanov.wordpress.com/
Дата: 05.11.25 08:51
Оценка:
Здравствуйте, netch80, Вы писали:

N>https://github.com/torvalds/linux/blob/master/arch/hexagon/kernel/head.S

А можете дать ссылку на описание этой нотации?

По расширению имени файла я предположил было, что это GNU-нотация для ассемблера, но она (как я посмотрел) все же ближе к традиционной <мнемоника>+<операнды>, там отличие от того же Intel в некоторых деталях синтаксиса.

А больше я с ходу не нашел ничего (а выглядит реально интересно).
Re: Более удобное представление ассемблера...
От: CRT  
Дата: 05.11.25 21:27
Оценка:
Здравствуйте, Shmj, Вы писали:

S>Вот ранее был типа High-Level Assembler:


S>
S>mov( ebx, eax );
S>add( 4, eax );
S>if( eax > ebx ) then
S>    stdout.put("eax > ebx", nl);
S>endif;
S>



S>Вроде чел. делал такой проект, кто помнит?


это не ассемблер. Ассемблер это машинные команды просто представленные в более удобном для восприятия виде. То есть команда ассемблера = машинная команда.
Re[2]: Более удобное представление ассемблера...
От: Shmj Ниоткуда  
Дата: 06.11.25 04:38
Оценка:
Здравствуйте, CRT, Вы писали:

CRT>это не ассемблер. Ассемблер это машинные команды просто представленные в более удобном для восприятия виде. То есть команда ассемблера = машинная команда.


А если немного синтаксического сахара? К примеру — метки с человеческим именем — ведь в машинных кодах это просто номер ячейки памяти. Далее — если вместо mov( ebx, eax ); — написать let ebx = eax; — что поменялось? Это тоже команда, просто в более удобном для восприятия виде.
=сначала спроси у GPT=
Re[2]: Более удобное представление ассемблера...
От: Shmj Ниоткуда  
Дата: 06.11.25 04:45
Оценка:
Здравствуйте, Евгений Музыченко, Вы писали:

ЕМ>Это грубый, неэффективный и тупиковый путь. Годится лишь для упертых фанатов ассемблера. Гораздо эффективнее добавлять доступ к процессорным регистрам и командам в "низкоуровневые ЯВУ" вроде C.


Т.е. ассемблерные вставки? Еще хуже когда намешано.
=сначала спроси у GPT=
Re[2]: Более удобное представление ассемблера...
От: Shmj Ниоткуда  
Дата: 06.11.25 04:46
Оценка:
Здравствуйте, SergeyIT, Вы писали:

SIT>Так это Basic...


В Basic нет прямого доступа к регистрам.
=сначала спроси у GPT=
Re[3]: Более удобное представление ассемблера...
От: Shmj Ниоткуда  
Дата: 06.11.25 09:59
Оценка:
Здравствуйте, Михаил Романов, Вы писали:

N>>https://github.com/torvalds/linux/blob/master/arch/hexagon/kernel/head.S

МР>А можете дать ссылку на описание этой нотации?

Всезнайка ответило:

Короткий ответ: это синтаксис ассемблера Qualcomm Hexagon (QDSP6)

https://docs.qualcomm.com/bundle/publicresource/topics/80-N2040-60/instructions.html

=сначала спроси у GPT=
Re[3]: Более удобное представление ассемблера...
От: Privalov  
Дата: 06.11.25 12:56
Оценка:
Здравствуйте, Shmj, Вы писали:

S>Т.е. ассемблерные вставки? Еще хуже когда намешано.


Я в своё время использовал встроенный ассемблер. В реальном режиме было очень удобно. Не надо было сильно париться с моделями памяти. И о правильной передаче аргументов не надо было думать.
Только, как и с любым другим инструментом, нужно включать голову при использовании. За беспорядочное использование встроенного ассемблера надо руки отрывать. Как сегодня за беспорядочное использование dynamic в Шарпе.
Re[4]: Более удобное представление ассемблера...
От: Shmj Ниоткуда  
Дата: 06.11.25 13:27
Оценка:
Здравствуйте, Privalov, Вы писали:

P>Я в своё время использовал встроенный ассемблер. В реальном режиме было очень удобно.


В реальном режиме — это под какую ОС?

Тут еще вопрос переносимости. Голый C++|C все-таки не привязан к архитектуре, более-менее соберется под все платформы. Если ассемблер в отдельных файлах, то можно настроить сборку и перевести сами файлы под конкретную платформу. Когда же все намешано внутри C-кода — это ужас.
=сначала спроси у GPT=
Re[6]: Более удобное представление ассемблера...
От: Shmj Ниоткуда  
Дата: 06.11.25 13:40
Оценка:
Здравствуйте, Privalov, Вы писали:

P>MS DOS. Приходилось пару раз опускаться на уровень железа. Однажды даже для какого-то проекта русификатор клавиатуры встроенный сделал. Уже не помню, чем там коллег обычный драйвер не устроил. На встроенном ассемблере это оказалось очень просто.


И зачем после этого было опускаться до запросов на C#? Нужно было так и продолжить на низком уровне.
=сначала спроси у GPT=
Re[7]: Более удобное представление ассемблера...
От: Privalov  
Дата: 06.11.25 14:05
Оценка:
Здравствуйте, Shmj, Вы писали:

S>И зачем после этого было опускаться до запросов на C#? Нужно было так и продолжить на низком уровне.


Затем, что я работу сменил. Иногда мне приходилось JNI для проекта на Java делать. Тоже низкий уровень. Иногда мне нужно было кое-какие дополнения для виндовых editbox-ов делать.
А C# вспомнил потому, что достался мне в наследство один небольшой проект на нём. И вот там как раз и dynamic, и рефлексия разбросаны по всему коду. Повбывав бы.
Re[2]: Более удобное представление ассемблера...
От: Евгений Музыченко Франция https://software.muzychenko.net/ru
Дата: 06.11.25 18:48
Оценка:
Здравствуйте, hi_octane, Вы писали:

_>Был проект С-- (си минус минус) — пишешь почти на C, но в тоже время на асме.


Совершенно ничто не мешает иметь подобное хоть в обычном C, хоть в самом распоследнем C++.
Re[3]: Более удобное представление ассемблера...
От: Евгений Музыченко Франция https://software.muzychenko.net/ru
Дата: 06.11.25 19:01
Оценка:
Здравствуйте, AWSVladimir, Вы писали:

AWS>Макроассемблером вполне можно писать как на высоком языке программирования.


Зачем?
Re[6]: Более удобное представление ассемблера...
От: Евгений Музыченко Франция https://software.muzychenko.net/ru
Дата: 06.11.25 19:02
Оценка:
Здравствуйте, Privalov, Вы писали:

P>зе беспорядочное использование встроенного ассемблера надо отрывать руки.


А сам встроенный ассемблер — изживать в пользу более внятных языковых средств.
Re[7]: Более удобное представление ассемблера...
От: Privalov  
Дата: 07.11.25 16:09
Оценка:
Здравствуйте, Евгений Музыченко, Вы писали:

ЕМ>А сам встроенный ассемблер — изживать в пользу более внятных языковых средств.


Это про использование всяких функций типа inport/outport и им подобных. Отчасти верно. но во многих случаях использование встроенного ассемблера было удобнее. И если встроенный ассемблер не использовать беспорядочно, то с этим вполне можно было жить. Те, кто работал на более высоком уровне, просто вызывали функцию, не интересуясь, как она сделана.
Re[8]: Более удобное представление ассемблера...
От: Евгений Музыченко Франция https://software.muzychenko.net/ru
Дата: 07.11.25 19:04
Оценка:
Здравствуйте, Privalov, Вы писали:

P>во многих случаях использование встроенного ассемблера было удобнее.


Оно не удобнее, а привычнее для программиста, знакомого с ассемблером, и проще для разработчика компилятора.
Re[3]: Более удобное представление ассемблера...
От: SergeyIT Россия  
Дата: 07.11.25 21:17
Оценка:
Здравствуйте, Shmj, Вы писали:

S> Далее — если вместо mov( ebx, eax ); — написать let ebx = eax; — что поменялось? Это тоже команда, просто в более удобном для восприятия виде.


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