O argv, argv, wherefore art thou argv?


 
Thread Tools Search this Thread
Top Forums UNIX for Advanced & Expert Users O argv, argv, wherefore art thou argv?
# 1  
Old 05-08-2013
O argv, argv, wherefore art thou argv?

All of my machines (various open source derivatives on x86 and amd64) store argv above the stack (at a higher memory address). I am curious to learn if any systems store argv below the stack (at a lower memory address).

I am particularly interested in proprietary Unices, such as Solaris, HP-UX, AIX, etc, although any reports are welcome. Please don't neglect to mention your operating system and cpu architecture in your post.

If you are inclined to help, please compile and execute the following small program:
Code:
#include <stdio.h>
#include <unistd.h>

int
main(int argc, char **argv)
{
    int x;

    printf("heap: %p\n", sbrk(0));
    printf("stack: %p\n", (void *) &x);
    printf("argv: %p\n", (void *) &argv);
    return 0;
}

The "stack: " line is just an approximation to the top of the stack, but it's good enough for my purposes.

A typical result from a 32-bit x86 Linux system:
Code:
heap: 0x804a000
stack: 0xbf9023ac
argv: 0xbf9023d4

Thank you in advance,
Alister

Last edited by alister; 05-08-2013 at 04:24 PM..
# 2  
Old 05-08-2013
Hi Alister, here are some results, all 64-bit systems:
Code:
OSX 10.8 (INTEL)
--------------------
heap: 0x105a19000
stack: 0x7fff5a21ab84
argv: 0x7fff5a21ab90

Code:
Solaris 10 (SPARC)
--------------------
heap: 20e30
stack: ffbffc28
argv: ffbffc78

Code:
HPUX11v1 (PA-RISC)
--------------------
heap: 400010ec
stack: 7f7f0668
argv: 7f7f0638

Code:
AIX 7 (Power4)
-------------
heap: 200006ec
stack: 2ff22bf8
argv: 2ff22c3c

Code:
Irix 6.5 (MIPS)
--------------------
heap: 10014000
stack: 7fff2f28
argv: 7fff2f24

Code:
Tru64 5.1 (Alpha)
--------------------
heap: 14000e180
stack: 11fffbfe0
argv: 11fffbff8


Last edited by Scrutinizer; 05-09-2013 at 03:33 PM..
This User Gave Thanks to Scrutinizer For This Post:
# 3  
Old 05-08-2013
Wow. Thank you very much for that post, Scrutinizer. I appreciate it.

It seems that HPUX and IRIX are the odd ones out (stack grows to higher memory addresses).

If it were not vulgar, I would express my multi-UNIX access envy, but I always try to keep my posts chaste.

Regards,
Alister
# 4  
Old 05-08-2013
Solaris 10 SPARC, 32bit:
heap: 20de0
stack: ffbfe930
argv: ffbfe980

Solaris 10 SPARC, 64bit:
heap: 100100d10
stack: ffffffff7fffe6d8
argv: ffffffff7fffe6e0

Solaris 10 x68, 32bit:
heap: 8060890
stack: 8047de4
argv: 8047df4

HP-UX 11 PA-RISC2.0, 32bit:
heap: 400010e4
stack: 7a000f98
argv: 7a000f68

HP-UX 11 Itanium, 32bit:
heap: 40010048
stack: 7ffff3c0
argv: 7ffff3dc

I guess that PA-RISC is the exotic hardware. And MIPS.

Last edited by MadeInGermany; 05-08-2013 at 07:54 PM..
This User Gave Thanks to MadeInGermany For This Post:
# 5  
Old 05-08-2013
Thank you, MadeInGermany, for illuminating the distinction between HP-UX PA-RISC and Itanium. Much appreciated.

Regards,
Alister
# 6  
Old 05-09-2013
Output:
heap: 20dd8
stack: ffbffc84
argv: ffbffcd0

System Configuration: Oracle Corporation sun4v SPARC T4-2

Hope that helps.
Regards
Peasant.
This User Gave Thanks to Peasant For This Post:
# 7  
Old 05-09-2013
I have a vague recollection of the address space layout shifting a few times with changes in CPU architectures. First there was the IBM 360 architecture, then the 16-bit address space PDP-11, then the 17-bit address space PDP-11, then the VAX, then the 3B20, 3B2, 3B5, M68K, SPARC, PA RISC, etc., and the segmented address space of the various x86 and similar processors. The people that did the ports to each new architecture decided at that time where code, text, heap, and stack would be placed for that architecture. For various reasons, they were not all in the same order. But, once an order was chosen for a particular processor type, ABI considerations tended to use the same layout for all systems based on that architecture. (Some companies (e.g., Intel) caused some unnecessary incompatibilities by not letting various contractors working on different OSes for the same architecture talk to each other and giving different answers to trivial questions like whether some numbers were presented in decimal or octal in tables that Intel created and then shared with the contractors.)
These 3 Users Gave Thanks to Don Cragun For This Post:
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. UNIX for Dummies Questions & Answers

ARGV how to use it?

So i am trying to read in file readFile <GivenFile> modFile looking for a regular file under the directories in the GivenFile and print them out is my over all goal. basically I am looking for anything that looks like a directory in the given file and printing it out. Since I am trying to do... (2 Replies)
Discussion started by: squidGreen
2 Replies

2. Homework & Coursework Questions

Help using argc/argv in assignment

Use and complete the template provided. The entire template must be completed. If you don't, your post may be deleted! 1. The problem statement, all variables and given/known data: First, create a "hello world" program that prints "Hello World". But NOW, instead use argc to verify that a... (9 Replies)
Discussion started by: miniviking10
9 Replies

3. Programming

How do I copy or rewind *argv[]

I'm working on my own pow function and I need to make a copy of *argv but I think that I am having trouble with the size of *argv and the size of any array that I make. The code below isn't working for me. and I want to accept any number no matter the size with pow -f 2 2. I was working out... (16 Replies)
Discussion started by: Errigour
16 Replies

4. Programming

help with C, argv

when i run my program, i have a parameter, that i want to set the value to another string i am using int main(int argc, char **argv) { char my_str=argv; printf("%s",my_str); return 0; } and i get Segmentation fault ran using ./my_prog /usr/share/dict/words hello1 ... (2 Replies)
Discussion started by: omega666
2 Replies

5. Programming

ARGV help in C

Hi, Can somehelp help how to list file in a dir? (5 Replies)
Discussion started by: Learnerabc
5 Replies

6. Shell Programming and Scripting

$#Argv in Csh

Hello all, Had a quick question: In a typical csh script should inputting via stdin (i.e. set i = $< ) increase the value of $#argv ? echo enter an value: set val= "$<" if($#argv == 0) then echo No args else echo The arg is $argv so if a value is inputted #argv... (1 Reply)
Discussion started by: new2C
1 Replies

7. Shell Programming and Scripting

if #argv = (this OR that) then...

this is in one of my scripts... if ($#argv == 0) then echo 'blah bla' exit 0 endif I want it to be something like this... if ($#argv == 0 OR $argv >=3) echo 'blah bla' exit 0 endif so when the arguments are none, or greater than three I want this "if then" to take over. how? I... (5 Replies)
Discussion started by: ajp7701
5 Replies

8. Programming

help for argv argc

Hi C experts, I have the following code for adding command line option for a program int main (argc, argv) int argc; char *argv; { char *mem_type; //memory type char *name; //name of the memory int addr; //address bits int data; ... (5 Replies)
Discussion started by: return_user
5 Replies

9. Programming

Using argv argc

I searched on the forums. No advises. I am using a previous source code. I changed the main function main(int argc, char **argv) in a function misc(int argc, char **argv). How do you use the argc and argv parameters? This is how I am calling the function : char param; strcat(param,"wgrib ");... (4 Replies)
Discussion started by: Akeson Chihiro
4 Replies

10. Programming

argv

I have a program which I wish to modify. It used to be run from the command line, but now I wish to change this so it can be used as a function. The program has complex argument processing so I want to pass my paramters to as if it were being called by the OS as a program. I have tried to... (2 Replies)
Discussion started by: mbb
2 Replies
Login or Register to Ask a Question