caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
From: Bob Zhang <bobzhang1988@gmail.com>
To: Gabriel Scherer <gabriel.scherer@gmail.com>
Cc: Caml List <caml-list@inria.fr>, Xavier Leroy <Xavier.Leroy@inria.fr>
Subject: Re: [Caml-list] Questions about changing lambda IR
Date: Sun, 9 Aug 2015 22:45:33 -0400	[thread overview]
Message-ID: <CANcqPu4WBryHMFT4agUvi5CPrk=Tsn3QgE3xfq084Q7JOWjViA@mail.gmail.com> (raw)
In-Reply-To: <CAPFanBGm+OyC9rrBhSKBwF9FwrxSnqrhuAMgCaECLnt8UzHndA@mail.gmail.com>

[-- Attachment #1: Type: text/plain, Size: 3280 bytes --]

Indeed, it works now, thank for your time!

On Sat, Aug 8, 2015 at 10:13 AM, Gabriel Scherer <gabriel.scherer@gmail.com>
wrote:

> Attached to this email is the patch I tried. It's exactly your proposed
> change, with necessary dummy changes to make it compile. The following
> process works reliably on my trunk:
>
> - make world
> - apply the patch
> - make bootstrap
> - make world
>
> On Sat, Aug 8, 2015 at 1:28 PM, Bob Zhang <bobzhang1988@gmail.com> wrote:
>
>> Before I changed Lambda.lambda, and it works, it might be that we
>> serialized structured_constant somewhere in the bootstrapping process?
>>
>> On Sat, Aug 8, 2015 at 7:25 AM, Bob Zhang <bobzhang1988@gmail.com> wrote:
>>
>>> It does not work for me. Since it fails to compile, I pushed it to
>>> another branch https://github.com/bobzhang/ocaml/tree/fails (sorry for
>>> the misinformation)
>>>
>>> I did `git clean -fxd` and try configure, make world, it failed in the
>>> same place.
>>> Thank you for your time!
>>>
>>> On Sat, Aug 8, 2015 at 3:37 AM, Gabriel Scherer <
>>> gabriel.scherer@gmail.com> wrote:
>>>
>>>> You need to run "make bootstrap" to avoid having part of the definition
>>>> compiled against the stale definition of lambda.cmi. (I just checked that
>>>> it works on your change: after a bootrsap, "make world", "make opt", "make
>>>> opt.opt" work.)
>>>>
>>>> On Sat, Aug 8, 2015 at 5:50 AM, Bob Zhang <bobzhang1988@gmail.com>
>>>> wrote:
>>>>
>>>>>
>>>>> Dear caml develpers,
>>>>>
>>>>>    I am working on an experimental branch to pass more information
>>>>> from typedtree to lambda to enable ocaml generate user readable javascript
>>>>> code(https://github.com/bobzhang/ocaml/tree/master) (online-demo:
>>>>> http://zhanghongbo.me/js-demo/)
>>>>>
>>>>>    Here I get a segfault, after I change const_block:
>>>>>    Below is my minimal change:
>>>>>
>>>>> ```
>>>>> type pointer_info =
>>>>>   | NullConstructor of string
>>>>>   | NullVariant of string
>>>>>   | NAPointer
>>>>>
>>>>> type tag_info =
>>>>>   | Constructor of string
>>>>>   | Tuple
>>>>>   | Variant of string
>>>>>   | Record
>>>>>   | NA
>>>>>
>>>>> type structured_constant =
>>>>>     Const_base of constant
>>>>>   | Const_pointer of int * pointer_info
>>>>>   | Const_block of int * tag_info * structured_constant list
>>>>>   | Const_float_array of string list
>>>>>   | Const_immstring of string
>>>>> ```
>>>>> Note that the enriched info is not used in ``emitcode``, now I get a
>>>>> segfault in make world:
>>>>>
>>>>> ```
>>>>> ../../boot/ocamlrun ../../ocamlc -nostdlib -I ../../stdlib -c -w
>>>>> +33..39 -warn-error A -bin-annot -g -safe-string -I ../../stdlib -I
>>>>> ../../utils -I ../../typing -I ../../bytecomp -I ../../asmcomp
>>>>> extract_crc.ml
>>>>> ../../boot/ocamlrun ../../ocamlc -nostdlib -I ../../stdlib -o
>>>>> extract_crc dynlink.cma extract_crc.cmo
>>>>> make[3]: *** [extract_crc] Segmentation fault: 11
>>>>> make[3]: *** Deleting file `extract_crc'
>>>>> make[2]: *** [otherlibraries] Error 2
>>>>> make[1]: *** [all] Error 2
>>>>> ```
>>>>>
>>>>> Any help is appreciated : )
>>>>>
>>>>> --
>>>>> Regards
>>>>> -- Hongbo Zhang
>>>>>
>>>>
>>>>
>>>
>>>
>>> --
>>> Regards
>>> -- Hongbo Zhang
>>>
>>
>>
>>
>> --
>> Regards
>> -- Hongbo Zhang
>>
>
>


-- 
Regards
-- Hongbo Zhang

[-- Attachment #2: Type: text/html, Size: 5561 bytes --]

      reply	other threads:[~2015-08-10  2:45 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-08-08  3:50 Bob Zhang
2015-08-08  7:37 ` Gabriel Scherer
2015-08-08 11:25   ` Bob Zhang
2015-08-08 11:28     ` Bob Zhang
2015-08-08 14:13       ` Gabriel Scherer
2015-08-10  2:45         ` Bob Zhang [this message]

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='CANcqPu4WBryHMFT4agUvi5CPrk=Tsn3QgE3xfq084Q7JOWjViA@mail.gmail.com' \
    --to=bobzhang1988@gmail.com \
    --cc=Xavier.Leroy@inria.fr \
    --cc=caml-list@inria.fr \
    --cc=gabriel.scherer@gmail.com \
    /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).