vak: (Default)
Serge Vakulenko ([personal profile] vak) wrote2007-05-25 01:08 am

Сравнение архитектур процессоров

Берем простой, хотя и нетривиальный си-шный код, и сравниваем количество получившихся машинных команд. Компилятор GCC 4.1.2, оптимизация -O1. Исходный код такой:
unsigned long rot13_hash (unsigned char *str, unsigned int len)
{
unsigned long hash = 0;

while (len-- > 0) {
hash += *str++;
hash -= (hash << 13) | (hash >> 19);
}
return hash;
}
Результаты:

АрхитектураКоманд в циклеВсего команд
ARM613
Thumb817
MIPS32917
Intel 386925
MIPS161017
Blackfin1122

Для MIPS и Blackfin компилятор не догадался заменить два арифметических сдвига на один циклический. Предположим, мы исправили компилятор. Тогда получится так:

АрхитектураКоманд в циклеВсего команд
ARM613
MIPS32715
MIPS16815
Thumb817
Blackfin819
Intel 386925

Хорошо видно, насколько архитектура Intel 386, она же Pentium, проигрывает RISC-процессорам.

[identity profile] panchul.livejournal.com 2007-05-24 09:42 pm (UTC)(link)
Ох, Сережа, ты бы испытал большой кайф, если бы работал в Microtec Research, где я работал в 1995-м году (их потом скушал Mentor Graphics). У Microtec Research были симуляторы, компиляторы и рт-осы для кучи процессоров, включая довольно извратные. Это был (до съедения его MGC) мировой лидер в тулах для embedded systems (после съедения он почти исчез с рынка). Офис был в треугольном здании сразу рядом с Интелом (почти стенка к стенке (кстати, я сейчас хожу в гнусный Интел по поводу проекта верификационой модели графической памяти))). Из моего офиса в Microtec Research окрывался шикарный вид Силиконовой Долины. Здание было, как я уже сказал, в виде треугольной призмы, что вызывало первые пару недель ощущение шизофрении (идешь по коридору, повернул раз, повернул два - и вдруг ты в той же точке, откуда начал). Там я губил свою молодость, играясь с моделями этих процессоров ;-)