Solved

AMD64 and malloc()

Posted on 2004-04-12
5
330 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

Active Directory Webinar

We all know we need to protect and secure our privileges, but where to start? Join Experts Exchange and ManageEngine on Tuesday, April 11, 2017 10:00 AM PDT to learn how to track and secure privileged users in Active Directory.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
C++ assignment question 7 237
Fully specialized class template function 21 142
Writing a parser for java language 4 87
GUI: DIalog Stacking and Popping in MS C++ 4 83
Templates For Beginners Or How To Encourage The Compiler To Work For You Introduction This tutorial is targeted at the reader who is, perhaps, familiar with the basics of C++ but would prefer a little slower introduction to the more ad…
This article shows you how to optimize memory allocations in C++ using placement new. Applicable especially to usecases dealing with creation of large number of objects. A brief on problem: Lets take example problem for simplicity: - I have a G…
The viewer will learn how to user default arguments when defining functions. This method of defining functions will be contrasted with the non-default-argument of defining functions.
The viewer will learn how to clear a vector as well as how to detect empty vectors in C++.

820 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