Solved

AMD64 and malloc()

Posted on 2004-04-12
5
329 Views
Last Modified: 2010-10-05
I'm having lots of trouble finding info on the web about how memory will be allocated on a 64 bit processor in c++.  So far all I've found is compiler-specific this and compiler-specific that.  Can anyone tell me how to be prepared to manage 64 bit memory in a cross-platform manner?  will malloc crash if I try to malloc more than 0x7fffffff bytes on an AMD64?  Is there going to be a commandline-switch for different compilers?  hope this question is not dumb :)

thanx!

PS I am presently using VC++ 6.0 command line.
0
Comment
Question by:madhtrr
  • 2
  • 2
5 Comments
 
LVL 22

Expert Comment

by:grg99
ID: 10809403
Just guessing, but it would probably work out okay if malloc() remained as-is for a while, accepting a 32-bit parameter.  All existing programs and 98% of mallocs() in the next 10 years will still be serviceable by malloc();

 For really big allocs, there could be an malloc64() that would accept and return a 48 or 64-bit pointer and length.

0
 
LVL 2

Accepted Solution

by:
guntherothk earned 250 total points
ID: 10814661
Your chief cross-platform problem will be that a void* is not necessarily the same size as an int or a long on a 64 bit architecture. A lot of programs blithely cast between void* and types like int.

malloc() ought to work on a 64 bit architecture. The argument of malloc() should be of type size_t, which is unsigned long on 32 bit architectures, but will be something like unsigned long long on 64 bit architectures.

Yes, this is compiler-specific. You need a compiler that understands you are coding for a 64 bit architecture. The whole point of architectures like the AMD is that they understand and correctly run old 32 bit applications compiled by compilers which don't understand 64 bit issues. MSVC 7 has a whole suite of warning messages specifically designed to report potential 64 bit incompatibilities in 32 bit code.

There are switches in MSVC 7 to compile for 64 bit architectures, and there will have to be 64 bit specific versions of library functions like malloc(). For most applications, it's still appropriate to compile for a 32 bit model.
0
 

Author Comment

by:madhtrr
ID: 10818695
k, thanx :)

Man.  I feel like I'm getting pushed to the shore of an island of running out of practical cross-platform development environments.  whenever I get rich and have lots of time, I guess I'll have to spend all of it in assembly, hehe :)
0
 
LVL 2

Expert Comment

by:guntherothk
ID: 10824097
Children these days don't know how hard we had it. You've grown up your whole lives with a family of computers all having 32 bit addresses and data words that were 8, 16, or 32 bits wide. You don't remember the bad old days of 18 bit addresses and 36 bit data words (or worse). Six bit bytes, octal, 1's complement arithmetic with two zeros! Ha. You probably don't even remember long and short (and compact, and...) pointers and memory models.

Seriously, we've been pretty lucky for the last 20 years in the common assumptions we could make about hardware architectures. Innovation in processor design is good, but it will sharpen your coding skills.
0
 

Author Comment

by:madhtrr
ID: 10824398
yep, I just got into this about 10 years ago. started with foxpro and various dbase stuff.  I remembered when I was in high school and I had to write my own program for anything I wanted to do on my 386 when there was no GUI (admittedly, on basica:).  I kinda began to feel like I was getting dumbed down, which is why I began on c++, which actually taught me something about my machine.  I am presently reading a textbook on assembly for intel processors, and learning all kinds of fascinating stuff.  (some of the crazy things you mentioned are discussed in that book, and man, I DO have it easy comapred to all that!) This board and you guys are my prime source of hard to find information and insight that will get me to my ultimate goal which is becoming one with the metal, instead of just memorizing a bunch of proprietary syntax ...  do not dispair, There is hope for us!

:)
0

Featured Post

Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
C Language combined operators 28 109
Unable to start eclipse ? 17 141
How can i compile this github project?? 2 82
Embarcadero C++ builder XE10.1 Berlin TRegistry declaration 1 27
When writing generic code, using template meta-programming techniques, it is sometimes useful to know if a type is convertible to another type. A good example of when this might be is if you are writing diagnostic instrumentation for code to generat…
What is C++ STL?: STL stands for Standard Template Library and is a part of standard C++ libraries. It contains many useful data structures (containers) and algorithms, which can spare you a lot of the time. Today we will look at the STL Vector. …
The viewer will learn how to use the return statement in functions in C++. The video will also teach the user how to pass data to a function and have the function return data back for further processing.
The viewer will be introduced to the member functions push_back and pop_back of the vector class. The video will teach the difference between the two as well as how to use each one along with its functionality.

785 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question