[Issue 5597] [64-bit] Illegal Instruction on Ancient Hardware

2011-08-12 Thread d-bugmail
http://d.puremagic.com/issues/show_bug.cgi?id=5597


David Simcha  changed:

   What|Removed |Added

 Status|NEW |RESOLVED
 Resolution||FIXED


--- Comment #7 from David Simcha  2011-08-12 20:31:10 PDT ---
This was fully fixed in 2.053.

-- 
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
--- You are receiving this mail because: ---


[Issue 5597] [64-bit] Illegal Instruction on Ancient Hardware

2011-02-17 Thread d-bugmail
http://d.puremagic.com/issues/show_bug.cgi?id=5597



--- Comment #6 from Walter Bright  2011-02-17 
11:00:16 PST ---
This is a partial fix. I'll pick up the rest for the next release. cg87.c has
more cases emitting SAHF, and Phobos1/Druntime/Phobos also use SAHF.

https://github.com/D-Programming-Language/dmd/commit/6b787c45193675ed40f91e1b2edbe9c004b18d99

https://github.com/D-Programming-Language/dmd/commit/705b4fe1d798164d42da252c88bad0f5af201ee6

-- 
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
--- You are receiving this mail because: ---


[Issue 5597] [64-bit] Illegal Instruction on Ancient Hardware

2011-02-16 Thread d-bugmail
http://d.puremagic.com/issues/show_bug.cgi?id=5597



--- Comment #5 from David Simcha  2011-02-16 14:38:42 PST ---
Looks like it does fail on sahf.  I had a somewhat painful time, though,
figuring this out.  GDB just puts (bad) in the disassembly at that point
(probably because the GDB on that machine is ancient).  Therefore, I had to
take the offset that the error was at and look for it in obj2asm.

-- 
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
--- You are receiving this mail because: ---


[Issue 5597] [64-bit] Illegal Instruction on Ancient Hardware

2011-02-16 Thread d-bugmail
http://d.puremagic.com/issues/show_bug.cgi?id=5597



--- Comment #4 from Walter Bright  2011-02-16 
13:25:06 PST ---
Neither dmd nor the runtime uses LAHF, but they do use SAHF which I think is
the same issue.

-- 
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
--- You are receiving this mail because: ---


[Issue 5597] [64-bit] Illegal Instruction on Ancient Hardware

2011-02-16 Thread d-bugmail
http://d.puremagic.com/issues/show_bug.cgi?id=5597


Walter Bright  changed:

   What|Removed |Added

 CC||bugzi...@digitalmars.com


--- Comment #3 from Walter Bright  2011-02-16 
13:09:53 PST ---
When running it under gdb, can you verify that it actually does fail on the
LAHF instruction?

-- 
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
--- You are receiving this mail because: ---


[Issue 5597] [64-bit] Illegal Instruction on Ancient Hardware

2011-02-16 Thread d-bugmail
http://d.puremagic.com/issues/show_bug.cgi?id=5597



--- Comment #2 from David Simcha  2011-02-16 11:00:45 PST ---
Argh there really needs to be a way to edit these posts.  I accidentally got
the wrong box.  The correct info for the oldest CPU it does work on is:

processor   : 0
vendor_id   : GenuineIntel
cpu family  : 6
model   : 15
model name  : Intel(R) Xeon(R) CPU   E7330  @ 2.40GHz
stepping: 11
cpu MHz : 2393.892
cache size  : 3072 KB
physical id : 0
siblings: 4
core id : 0
cpu cores   : 4
fpu : yes
fpu_exception   : yes
cpuid level : 10
wp  : yes
flags   : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov
pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm syscall nx lm pni monitor
ds_cpl est tm2 cx16 xtpr lahf_lm
bogomips: 4791.31
clflush size: 64
cache_alignment : 64
address sizes   : 40 bits physical, 48 bits virtual
power management:

-- 
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
--- You are receiving this mail because: ---


[Issue 5597] [64-bit] Illegal Instruction on Ancient Hardware

2011-02-16 Thread d-bugmail
http://d.puremagic.com/issues/show_bug.cgi?id=5597



--- Comment #1 from David Simcha  2011-02-16 10:59:07 PST ---
BTW, I think this is related to the lahf instruction because it's apparently
been a big problem in the past with old 64-bit CPUs not supporting it.  Here's
the cpuinfo for the oldest hardware this code does work on.  The only
difference in flags looks to be lahf.

processor   : 0
vendor_id   : GenuineIntel
cpu family  : 6
model   : 15
model name  : Intel(R) Xeon(R) CPU   E7330  @ 2.40GHz
stepping: 11
cpu MHz : 2394.055
cache size  : 3072 KB
physical id : 0
siblings: 4
core id : 0
cpu cores   : 4
apicid  : 0
initial apicid  : 0
fpu : yes
fpu_exception   : yes
cpuid level : 10
wp  : yes
flags   : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov
pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx lm
constant_tsc arch_perfmon pebs bts rep_good aperfmperf pni dtes64 monitor
ds_cpl vmx est tm2 ssse3 cx16 xtpr pdcm dca lahf_lm tpr_shadow vnmi
flexpriority
bogomips: 4788.11
clflush size: 64
cache_alignment : 64
address sizes   : 40 bits physical, 48 bits virtual
power management:

-- 
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
--- You are receiving this mail because: ---