Use of alloca function


 
Thread Tools Search this Thread
Top Forums Programming Use of alloca function
# 8  
Old 10-26-2009
Quote:
Originally Posted by shamrock
I don't know of any platforms that don't support alloca apart from embedded OSes however as the manpages say it is system dependent. Personally I have never used alloca because it is really of no use when it cant be returned. Curious if you can come up with a scenario where it's use would be more befitting than malloc.
Any time you want a local buffer without predefining its size, for one thing. achenle also had a good point about it being threadsafe hence much faster than trying to synchronize malloc for multithreaded things.

It's interesting how each platform discourages the use of alloca because of how it might behave on some other unmentionable platform without confessing to being guilty themselves. This could stand some testing, I think. alloca's almost as old as UNIX itself, circa AT&T V32 1979, making me wonder how historical this complaint is and how relevant it actually remains.

---------- Post updated at 04:24 PM ---------- Previous update was at 03:57 PM ----------

I wonder if this fails on any of your machines. I'm trying to smash stack memory in the manner described by passing and assigning to large stack variables as well as deep recursion.
Code:
#include <stdio.h>
#include <string.h>
#include <alloca.h>

struct hulk {   char buf[1024]; };

struct hulk smash(struct hulk h, int n)
{
        memset(&h, 0xff, sizeof(h));
        if(n > 0) h=smash(h, n-1);
        return(h);
}

int main(void)
{
        int n=0;
        struct hulk h;
        char *mem=alloca(sizeof(h));

        memset(mem, 0x7f, sizeof(h));
        memset(&h, 0x00, sizeof(h));
        h=smash(h, 5);

        for(n=0; n<sizeof(h); n++)
        {
                if(mem[n] != 0x7f)
                {
                        fprintf(stderr, "hulk smashed\n");
                        return(1);
                }
        }

        return(0);
}

So far OSX on PPC, and Linux on x86-32, x86-64, and embedded-linux MIPS(with ulibc) do not accidentally overwrite memory returned by alloca.

Last edited by Corona688; 10-27-2009 at 12:33 PM..
# 9  
Old 10-27-2009
Thank You all for your replies.
# 10  
Old 10-27-2009
Quote:
It's interesting how each platform discourages the use of alloca because of how it might behave on some other unmentionable platform without confessing to being guilty themselves. This could stand some testing, I think. alloca's almost as old as UNIX itself, circa AT&T V32 1979, making me wonder how historical this complaint is and how relevant it actually remains.
alloca() is not part of any standard such as ISO C or POSIX for a very good reason. It is not fully portable across computing architectures and programming models. For example, how do you implement it on architectures which do not have a stack?
Quote:
achenle also had a good point about it being threadsafe hence much faster than trying to synchronize malloc for multithreaded things.
Since alloca() is not standardized you cannot rely on alloca() being threadsafe across implementations. It may or may not be.
# 11  
Old 10-27-2009
Quote:
Originally Posted by fpmurphy
alloca() is not part of any standard such as ISO C or POSIX for a very good reason. It is not fully portable across computing architectures and programming models. For example, how do you implement it on architectures which do not have a stack?
What stack-free architectures? I can't find any except the PIC16, an embedded processor line with more I/O ports than RAM. And even then they were forced to emulate a stack to write a C compiler for it. I would have expected PPC or MIPS to be the ones to fail on this, being more RISC-like architectures that play funny games with the stack, but they work fine.
Quote:
Since alloca() is not standardized you cannot rely on alloca() being threadsafe across implementations. It may or may not be.
It's a very low-level call that works by modifying the stack frame -- a thread-local property. It would take an extremely strange implementation of it to not be threadsafe.

It is worth testing, though. I'll see what I can come up with.

Last edited by Corona688; 10-27-2009 at 12:31 PM..
# 12  
Old 10-28-2009
A major problem with using alloca() is that it does not fail gracefully when it fails. Usually a SIGSEGV or SIGBUS occurs which is difficult to debug because the SIGSEGV or SIGBUS may not necessarily occur anywhere close to the alloca() call.

Such a crash may be reproducible in one specific environment but not in another. This is usually the result of different stacksizes. An application's default stacksize depends on the user environment and may have been modified via ulimit or some other mechanism. Furthermore, in a threaded application a thread stacksize may differ from the process stacksize and from another thread's stacksize.
# 13  
Old 10-28-2009
This is just standard memory behavior. C's inability to warn you of impending stack faults doesn't stop people from using recursion and local variables, fortunately. If alloca is actually broken on some platform, though, that would be very good to know...
# 14  
Old 10-28-2009
Quote:
Originally Posted by Corona688
Any time you want a local buffer without predefining its size, for one thing.
I get that but my question was more about how are you going to use a dynamically allocated stack buffer.
Quote:
Originally Posted by Corona688
achenle also had a good point about it being threadsafe hence much faster than trying to synchronize malloc for multithreaded things.
It's just as easy to do with malloc.
Quote:
Originally Posted by Corona688
It's interesting how each platform discourages the use of alloca because of how it might behave on some other unmentionable platform without confessing to being guilty themselves. This could stand some testing, I think.
I would be leary of using a C lib function that is non-portable and strongly discouraged by the vendors who make it as it goes against the very purpose for which C was created i.e. portability. Otherwise we would all be coding in assembly which would be very cumbersome given the number of different mpus in the market today.
Quote:
Originally Posted by Corona688
alloca's almost as old as UNIX itself, circa AT&T V32 1979, making me wonder how historical this complaint is and how relevant it actually remains.
I have a hard copy of the UNIX Programmer's Manual (7th ed. Vol. 1 Jan. 1979) and alloca is nowhere in it.
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Function - Make your function return an exit status

Hi All, Good Day, seeking for your assistance on how to not perform my 2nd, 3rd,4th etc.. function if my 1st function is in else condition. #Body function1() { if then echo "exist" else echo "not exist" } #if not exist in function1 my all other function will not proceed.... (4 Replies)
Discussion started by: meister29
4 Replies

2. Shell Programming and Scripting

How to pass variable from one function to another function?

updateEnvironmentField() { linewithoutquotes=`echo $LINE | tr -d '"'` b() } I want to pass variable named $linewithoutquotes to another method called b(), which is called from updateEnvironmentField() method. How to do the above requirement with shell script (1 Reply)
Discussion started by: pottic
1 Replies

3. Shell Programming and Scripting

Need help on awk for printing the function name inside each function

Hi, I am having script which contains many functions. Need to print each function name at the starting of the function. Like below, functionname() { echo "functionname" commands.... } I've tried like below, func=`grep "()" scriptname | cut -d "(" -f1` for i in $func do nawk -v... (4 Replies)
Discussion started by: Sumanthsv
4 Replies

4. Shell Programming and Scripting

Will files, creaetd in one function of the same script will be recognized in another function?

Dear All. I have a script, which process files one by one. In the script I have two functions. one sftp files to different server the other from existing file create file with different name. My question is: Will sftp function recognize files names , which are created in another... (1 Reply)
Discussion started by: digioleg54
1 Replies

5. Shell Programming and Scripting

Help to Modify File Name in each function before calling another function.

I have a script which does gunzip, zip and untar. Input to the script is file name and file directory (where file is located) I am reading the input parameters as follows: FILENAME=$1 FILEDIR=$2 I have created 3 functions that are as follows: 1) gunzip file 2) unzip file... (2 Replies)
Discussion started by: pinnacle
2 Replies

6. Programming

How to step in one function after the function be executed in gdb?

In gdb, I can call one function with command "call", but how can I step in the function? I don't want to restart the program, but the function had been executed, gdb will execute next statement, and I don't know how to recall the function. (4 Replies)
Discussion started by: 915086731
4 Replies

7. Shell Programming and Scripting

pass function as argument to a function

I have the following code : function1 () { print "January" } function2() { case $1 in January) print "Dzisiaj mamy styczen" ;; *) ;; } main() { (1 Reply)
Discussion started by: presul
1 Replies

8. Shell Programming and Scripting

SHELL SCRIPT Function Calling Another Function Please Help...

This is my function which is creating three variables based on counter & writing these variable to database by calling another function writeRecord but only one record is getting wrote in DB.... Please advise ASAP...:confused: function InsertFtg { FTGSTR="" echo "Saurabh is GREAT $#" let... (2 Replies)
Discussion started by: omkar.sonawane
2 Replies

9. Shell Programming and Scripting

Return a value from called function to the calling function

I have two scripts. script1.sh looks -------------------------------- #!/bin/bash display() { echo "Welcome to Unix" } display ----------------------------- Script2.sh #!/bin/bash sh script1.sh //simply calling script1.sh ------------------------------ (1 Reply)
Discussion started by: mvictorvijayan
1 Replies

10. Shell Programming and Scripting

Passing global variable to a function which is called by another function

Hi , I have three funcions f1, f2 and f3 . f1 calls f2 and f2 calls f3 . I have a global variable "period" which i want to pass to f3 . Can i pass the variable directly in the definition of f3 ? Pls help . sars (4 Replies)
Discussion started by: sars
4 Replies
Login or Register to Ask a Question