caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
From: redfire <jeremie.salvucci@free.fr>
To: Guillaume Yziquel <guillaume.yziquel@citycable.ch>
Cc: caml-list@inria.fr
Subject: Re: [Caml-list] Byte code generation for the Ocaml virtual machine (ZAM)
Date: Sun, 01 May 2011 15:24:34 +0200	[thread overview]
Message-ID: <1304256274.4147.70.camel@localhost.localdomain> (raw)
In-Reply-To: <20110501130102.GX17796@localhost>

Bonjour,

Le dimanche 01 mai 2011 à 15:01 +0200, Guillaume Yziquel a écrit :
> Bonjour.
> 
> Je pense que cela serait une bonne idée que vous soyez plus explicite
> sur ce que vous faites et là où cela ne marche pas. À priori, je ne vois
> pas pourquoi cela ne serait pas possible, au contraire. Mais je me vois
> mal vous répondre sans plus de détails.
> 
> Le Sunday 01 May 2011 à 12:55:07 (+0200), redfire a écrit :
> > Salut Basile,
> > 
> > Je compile un sous ensemble de Scheme vers la ZAM. La machine virtuelle
> > d'Ocaml n'étant pas typée pour Scheme, je dois implémenter un mécanisme
> > qui va me permettre de tester les types à l'exécution.
> > 
> > D'après ce que j'ai compris, la machine virtuelle ne prend en compte que
> > les entiers de base. Le reste est géré par l'intermédiaire de primitives
> > C. Donc par exemple, si dans le programme source Scheme il est écrit
> > (display 5), je voulais stocker dans l'environnement global un couple
> > (2, 5). Le 2 représentant le type integer ici. Comme ça à l'exécution,
> > je sais que je  dois convertir cet entier en une chaîne de caractères à
> > l'aide de la primitive C correspondante.
> > Donc ici, je souhaitais sérialiser (2, 5) dans la zone data (avec le
> > module Marshall) en espérant récupérer un bloc composé d'au moins deux
> > champs dont deux d'entre eux seraient, le type et la valeur.
> > Malheureusement, je ne parviens pas à ce résultat. Je ne récupère que le
> > 5.
> 
> C'est ici que j'aimerais plus de détails.

J'ai choisi de représenter l'ensemble des valeurs manipulées par des
couples (type, valeur). Donc par exemple, si je travaille sur le code
Scheme suivant :

(display 5)

J'ai donc l'entier 5 et la primitive d'affichage de Scheme. Pour
représenter l'entier sur la VM, je le considère comme un couple (2, 5).
Maintenant à l'exécution, je veux que le code généré réalise les actions
suivantes :

- test du type de la valeur
- suivant le type de cette dernière, conversion à l'aide d'une des
primitives d'ocaml (caml_format_int, caml_format_*).
- puis appel de la primitive caml_ml_output.
- on pourrait imaginer un flush.

Pour cela, j'ai choisi d'adopter la stratégie suivante, je place
l'ensemble de mes couples dans l'environnement global (peut-être pas la
meilleure solution mais déjà j'aimerais faire fonctionner quelque
chose). Donc à la compilation, je crée un tableau contenant un ensemble
de couples (type, valeur) que je sérialise à l'aide du module Marshall
directement dans la zone data du fichier contenant le byte code.

Maintenant à l'exécution, imaginons que le couples (2, 5) soit à l'index
18 de l'environnement global. Je réalise un GETGLOBAL 18. Et pour tester
le type j'enchaîne avec un GETFIELD 0, PUSH, CONSTINT <montype>, suivi
d'un EQ. Or la valeur obtenue à l'aide du GETFIELD 0 est un 5 et non un
2.

La façon actuelle de créer ce tableau de couples est la suivante :

table.(18) <- Obj.repr (2, 5) par exemple pour l'exemple ci-dessus
(exemple de code que j'ai trouvé sur Internet sans garantie).

Ce tableau est ensuite écrit à l'aide de output_value de Pervasives.

Est-ce que ceci doit fonctionner et donc je m'y prends mal ailleurs. Ou
ce n'est pas la bonne façon de faire ceci ?

> 
> > En écrivant ce mail, je pense à une autre technique qui consisterait
> > plutôt à sérialiser seulement la valeur (vu que je ne parviens qu'à
> > récupérer celle-ci) et à générer le bloc à l'aide de MAKEBLOCK. Mais ça
> > me ferait modifier pas mal de choses.
> > 
> > Donc mon principal problème concerne la mise en place de ces couples
> > dans la zone data et leur récupération. Dans le mail précédent,
> > j'expliquais que j'ai trouvé un exemple sur internet qui sérialisait les
> > données dans un tableau à l'aide de Obj.repr pour mettre des données de
> > types différents dans un même tableau. Ensuite il fait un output value
> > et ça fonctionne. Sauf que ce morceau de code ne travaille que sur des
> > données de types primitifs et non pas de couples ou autres.
> > 
> > Je souhaite simplement pouvoir stocker un couple et récupérer chacun des
> > champs. Mais je n'ai pas trouvé de documentation qui explique clairement
> > et dans le détail comment tout ceci peut-être effectué.
> > 
> > J'espère avoir été un peu plus clair.
> > 
> > Il y a peut-être un moyen beaucoup plus simple de réaliser ceci mais je
> > ne le connais pas.
> > 
> > Merci à toi ;-)
> > 
> > Amicalement.
> > 
> > --
> > Jérémie Salvucci
> > 
> > Le dimanche 01 mai 2011 à 12:30 +0200, Basile Starynkevitch a écrit :
> > > On Sun, 01 May 2011 12:10:54 +0200
> > > redfire <jeremie.salvucci@free.fr> wrote:
> > > 
> > > > Hello all,
> > > > 
> > > > I'm currently doing a student project where I have to generate bytecode
> > > > for the caml virtual machine. I convert a subset of the Scheme language.
> > > > My main issue concerns the dynamic typing mechanism. My idea is to store
> > > > every values I manipulate like this (type, value).
> > > 
> > > Salut Jérémie, 
> > > 
> > > je suis très heureux de te lire. Par contre, je n'ai pas compris ton message (alors que je connais bien Ocaml et bien son bytecode). C'est quoi ton but exact? Coder un Scheme en Ocaml?
> > > 
> > > Amicalement
> > > 
> > > 
> > > 
> > 
> > 
> > 
> > -- 
> > Caml-list mailing list.  Subscription management and archives:
> > https://sympa-roc.inria.fr/wws/info/caml-list
> > Beginner's list: http://groups.yahoo.com/group/ocaml_beginners
> > Bug reports: http://caml.inria.fr/bin/caml-bugs
> > 
> > 
> 

Merci à vous.

--
Jérémie Salvucci



  parent reply	other threads:[~2011-05-01 13:26 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-05-01 10:10 redfire
2011-05-01 10:30 ` Basile Starynkevitch
2011-05-01 10:55   ` redfire
     [not found]     ` <20110501130102.GX17796@localhost>
2011-05-01 13:24       ` redfire [this message]
2011-05-01 14:15     ` Guillaume Yziquel

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1304256274.4147.70.camel@localhost.localdomain \
    --to=jeremie.salvucci@free.fr \
    --cc=caml-list@inria.fr \
    --cc=guillaume.yziquel@citycable.ch \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).