π
<-
Chat plein-écran
[^]

Liste des instructions [eZ80] + temps d'exécution !

Assembleur, Axe, C/C++, ICE...

Liste des instructions [eZ80] + temps d'exécution !

Unread postby grosged » 30 Mar 2016, 14:11

A l'aide d'un petit programme en asm (de ma conception) , je suis parvenu à mesurer très précisément le temps d'éxecution de (presque) chacune des instructions eZ80 (il reste 10% que je ne peux mesurer : les formes d'instructions de sortie OUT car celles-ci font planter la TI83PCE)
Comment ai-je fait ? Hé bien grâce à l'utilisation du cpu-clock-timer !
À noter que les tests ont été effectués en mode ADL=1, et que les adressages-mémoire ne sortaient pas de la zone RAM-VRAM (de $D40000 à $D657FF) afin d'avoir en permanence les même temps d'accès-mémoire en écriture ou lecture.
(voir http://wikiti.brandonw.net/index.php?ti ... ait_States pour plus d'infos)

Je vous dévoile donc cette liste en 2 versions : par ordre alphabétique, puis selon le temps d'exécution (ordre croissant)
Et tout ça en format ODS, HTML, PDF 8-)

J'espère que cela vous sera utile dans vos optimisations :)

https://tiplanet.org/forum/archives_voir.php?id=469451 et disponible ici aussi : https://wiki.tiplanet.org/Timings_des_instructions_eZ80

Ah! encore une précision sur la légende:
n = valeur 8bits
Mmn = valeur 24bits
r = registre 8bits
Last edited by grosged on 30 Mar 2016, 15:26, edited 6 times in total.
User avatar
grosgedVIP++
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Level up: 30.8%
 
Posts: 770
Images: 75
Joined: 14 Sep 2011, 12:29
Gender: Not specified
Calculator(s):
MyCalcs profile

Re: [eZ80] Liste des instructions EZ80 + tps d'exéc. !

Unread postby Ti64CLi++ » 30 Mar 2016, 14:12

Merci pour le copié collé de la description :troll:
Revenons à nos moutons, bravo à toi, je pense que cela va en aider plus d'un ;)
Image
User avatar
Ti64CLi++Modo
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 32.2%
 
Posts: 3440
Images: 75
Joined: 04 Jul 2014, 14:40
Location: Clermont-Ferrand 63
Gender: Male
Calculator(s):
MyCalcs profile
Class: ENS Rennes
GitHub: Ti64CLi

Re: [eZ80] Liste des instructions EZ80 + tps d'exéc. !

Unread postby grosged » 30 Mar 2016, 14:35

Bah ouais, j'avais la flemme, quoi ! Ha ha :p
Après ce dur labeur, fallait s'y attendre =D

Je viens de mettre à jour le ZIP : il contient maintenant 3 formats: ODS, HTML et PDF et en 2 versions (l'une classée par ordre alphabétique, l'autre selon le temps d'exécution)
User avatar
grosgedVIP++
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Level up: 30.8%
 
Posts: 770
Images: 75
Joined: 14 Sep 2011, 12:29
Gender: Not specified
Calculator(s):
MyCalcs profile

Re: Liste des instructions [eZ80] + temps d'exécution !

Unread postby TheMachine02 » 30 Mar 2016, 18:38

Intéressant. Par contre, je crains que le temps mis par les instructions soit un peu plus complexe en fonction des instructions attenantes. Je m'explique :

Le ez80 fetch les instructions pendant la phase décode-execute de la précédente. Théoriquement, cela permet de supprimer le besoin de dépenser des cycles pour fetcher l'instruction. Cependant, à cause des waits-states rajoutés sur le read (3+1 effectif), le nombre de cycle nécessaires pour accéder à la RAM dépasse le nombre de cycles maskables par le fetch en même temps que le décode; MAIS ça reste dépendant de l'instruction, puisque certaines possèdent un temps d'éxecution long.

Par exemple, l'instruction add hl,de, en considérant le cache de fetch vide (après un jp par exmple) sera découpé de cette manière :

FETCH : 1 read + 3 wait states : 4 TStates
DECODE&EXEC : 1 TState

Soit 5 TStates pour add hl, de

Par contre, si on considère qu'il y a une instruction avant, de 1 TState d'éxecution :
FETCH 1 read + 3 wait states : 4 TStates -1 (provenant du chargement du système pendant l'execute de l'instruction précédante)
DECODE&EXECUTE : 1 TStates

Soit 4 TStates !

Pourrait tu tester de timer ce code :

Code: Select all
mlt hl
add hl,de


mlt étant une instruction à longue latence d'éxecute, add hl,de devrait paraitre comme une instruction à 1 TState.

Bref, tout cela est compliquer, et le meilleur moyen c'est quand même de tester :p

EDIT : en me relisant, je remarque que j'ai combiner Execute&décode mais je crois que ce n'est même pas le cas sur ez80; aucune idée sur ce que ça change par contre (+1TStates ?)
User avatar
TheMachine02Modo
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 29.3%
 
Posts: 337
Images: 0
Joined: 16 Jan 2013, 18:27
Gender: Not specified
Calculator(s):
MyCalcs profile
Class: Médecine

Re: Liste des instructions [eZ80] + temps d'exécution !

Unread postby Epharius » 30 Mar 2016, 19:36

Geygey, ça a du prendre du temps. Personnellement je comptais faire la même chose mais avec les instructions Ti-Basic. Genre quel est le plus rapide entre :
Code: Select all
If A=5
Then
End

Code: Select all
If A=5

Bon là c'est évident mais vous avez compris le principe :p

Par contre, comme le dit TheMachine42, c'est très complexe et dépend beaucoup de la configuration de la calculatrice, enfin ça peut toujours être utile pour avoir une idée du temps de chacune des instructions ;)
Le projet Geometry Dash est terminé ! N'hésitez pas à aller jeter un coup d’œil au topic du projet ! Vous pouvez le télécharger ici.

Unis par la flèche sacrée de cupidon :favorite:
Image
User avatar
EphariusPremium
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 6.2%
 
Posts: 1050
Images: 4
Joined: 08 Dec 2014, 17:38
Gender: Not specified
Calculator(s):
MyCalcs profile
Class: Ensimag
GitHub: MathisLav

Re: Liste des instructions [eZ80] + temps d'exécution !

Unread postby grosged » 30 Mar 2016, 19:44

Tout d'abord, merci pour votre intérêt ;)

C'est vrai qu'avec son traitement des instructions en parallèle ("pipeline") j'avais des doutes sur l'efficacité de mon programme!
Je vais expliquer brièvement le fonctionnement de mon programme:
L'instruction (ou le groupe d'instructions) est mesurée
256
fois d'affilée
Puis le programme ne retient que la valeur la plus basse (car il arrive bien souvent que l'instruction et le cpuclock-timer ne soient pas synchronisés: l'idéal étant le timer qui incrémente , et ce, juste au moment où l'instruction est traitée)
Code: Select all
.nolist
#include "ti84pce.inc"
.list
.org userMem-2
.db tExtTok,tAsm84CeCmp
.assume ADL=1

      di
      ld hl,$f20030
      ld a,(hl)
      and %11000000
      ld (hl),a
      inc l
      set 1,(hl)

      ld b,0

loop:   push bc
      ld hl,$f20000
      ld de,0
      ld (hl),e
      inc l
      ld (hl),de
      ld l,$30
      set 0,(hl)
      push hl
   ld hl,EnRam
   ld bc,EnRam
   ld de,EnRam
   ld ix,EnRam
;-------------------------------

      mlt hl

;-------------------------------
      pop hl
      res 0,(hl)
      ld l,h
      ld hl,(hl)
      ld a,(data)
      cp l
      jr c,pass
      ld a,l
      ld (data),a
pass:   pop bc
      djnz loop
      ld hl,(data)
      ld de,-109
      add hl,de
      jp _DispHL
data:   .db 255,0,0
EnRam:   .db 0,0,0,0,0,0,0,0


Je viens de mesurer le temps que prend le code
Code: Select all
mlt hl
add hl,de

Le programme me donne
16
comme résultat :)

PS: et si on ne met rien à mesurer, le programme affiche bien 0 ;)

EDIT:
j'ai aussi testé ce mélange:
Code: Select all
mlt hl
      mlt hl
      add hl,de
      mlt hl
      mlt hl
      add hl,de
      add hl,de

Ce qui nous donne bien
60
;)
Last edited by grosged on 31 Mar 2016, 21:32, edited 5 times in total.
User avatar
grosgedVIP++
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Level up: 30.8%
 
Posts: 770
Images: 75
Joined: 14 Sep 2011, 12:29
Gender: Not specified
Calculator(s):
MyCalcs profile

Re: Liste des instructions [eZ80] + temps d'exécution !

Unread postby Adriweb » 30 Mar 2016, 20:18

Très bon boulot :)

Je suggère de créer une page dédiée sur notre wiki, histoire que ce soit accessible d'autant plus facilement (et plus collaboratif?)
Par exemple: https://wiki.tiplanet.org/Timings_des_instructions_eZ80 ?

Tu peux t'inspirer d'autres pages (par exemple ici) pour la syntaxe des tableaux, ou n'hésite pas à demander de l'aide sinon.


( Edit: BTW, tu devrais venir sur IRC, sur le channel #ez80-dev des serveurs EFNet :) )
Image
MyCalcs
: Help the community's calculator documentations by filling out your calculators info!
MyCalcs
: Aidez la communauté à documenter les calculatrices en donnant des infos sur vos calculatrices !
Inspired-Lua.org
: All about TI-Nspire Lua programming
(website in temporary maintenance)
User avatar
AdriwebAdmin
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 75.4%
 
Posts: 14093
Images: 1139
Joined: 01 Jun 2007, 00:00
Location: France
Gender: Male
Calculator(s):
MyCalcs profile
Twitter: adriweb
GitHub: adriweb

Re: Liste des instructions [eZ80] + temps d'exécution !

Unread postby grosged » 30 Mar 2016, 20:35

Merci Adriweb ;)

Oui ! Bonne idée la page "Timings des instructions eZ80" :)
Par contre , je ne sais pas comment créer une page de ce genre :o

Ce qui m'embête un peu , c'est que le timing de bon nombre d'instructions peut légèrement changer si l'on travaille avec des adressages hors de l'espace-mémoire RAM+VRAM...
C'est pour cela que ma liste est (pour l'instant) "généraliste"
Je réfléchis quant à une solution d'affichage plus détaillée, mais en même temps pas trop "lourde" (il ne faut pas que l'on s'y perde !)
User avatar
grosgedVIP++
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Level up: 30.8%
 
Posts: 770
Images: 75
Joined: 14 Sep 2011, 12:29
Gender: Not specified
Calculator(s):
MyCalcs profile

Re: Liste des instructions [eZ80] + temps d'exécution !

Unread postby Adriweb » 30 Mar 2016, 20:43

J'ai commencé une conversion pour toi :P

https://wiki.tiplanet.org/Timings_des_instructions_eZ80

(j'ai converti ton fichier .ods en .csv, puis utilisé http://area23.brightbyte.de/csv2wp.php )
Image
MyCalcs
: Help the community's calculator documentations by filling out your calculators info!
MyCalcs
: Aidez la communauté à documenter les calculatrices en donnant des infos sur vos calculatrices !
Inspired-Lua.org
: All about TI-Nspire Lua programming
(website in temporary maintenance)
User avatar
AdriwebAdmin
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 75.4%
 
Posts: 14093
Images: 1139
Joined: 01 Jun 2007, 00:00
Location: France
Gender: Male
Calculator(s):
MyCalcs profile
Twitter: adriweb
GitHub: adriweb

Re: Liste des instructions [eZ80] + temps d'exécution !

Unread postby grosged » 30 Mar 2016, 20:51

Super !!! =D

EDIT :
Par contre, je n'ai encore parlé des quelques valeurs comme par exemple "13,8" pour JR cc',d
dans ce cas-précis, si la condition cc' est remplie, le saut relatif est effectué (alors le temps=13)
sinon, le temps=8

Je m'étais dit que si j'utilisais une fraction"13/8", le tri n'aurait pas fonctionné,..Si ?
User avatar
grosgedVIP++
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Level up: 30.8%
 
Posts: 770
Images: 75
Joined: 14 Sep 2011, 12:29
Gender: Not specified
Calculator(s):
MyCalcs profile

Next

Return to Langages alternatifs

Who is online

Users browsing this forum: No registered users and 1 guest

-
Search
-
Social TI-Planet
-
Featured topics
Comparaisons des meilleurs prix pour acheter sa calculatrice !
Aidez la communauté à documenter les révisions matérielles en listant vos calculatrices graphiques !
1234
-
Donations / Premium
For more contests, prizes, reviews, helping us pay the server and domains...
Donate
Discover the the advantages of a donor account !
JoinRejoignez the donors and/or premium!les donateurs et/ou premium !


Partner and ad
Notre partenaire Jarrety Calculatrices à acheter chez Calcuso
-
Stats.
511 utilisateurs:
>445 invités
>60 membres
>6 robots
Record simultané (sur 6 mois):
6892 utilisateurs (le 07/06/2017)

-
Other interesting websites
Texas Instruments Education
Global | France
 (English / Français)
Banque de programmes TI
ticalc.org
 (English)
La communauté TI-82
tout82.free.fr
 (Français)