sbrk

brk and sbrk are basic memory management system calls used in Unix and Unix-like operating systems to control the amount of memory allocated to the data segment of the process. These calls are typically made from a higher-level memory management library such as malloc. In the original Unix system, brk and sbrk were the only ways in which applications could acquire additional data space; later versions allowed this to also be done using the mmap call.

Contents

Description

The brk and sbrk calls dynamically change the amount of space allocated for the data segment of the calling process. The change is made by resetting the program break of the process, which determines the maximum space that can be allocated. The program break is the address of the first location beyond the current end of the data region. The amount of available space increases as the break value increases. The available space is initialized to a value of zero. The break value can be automatically rounded up to a size appropriate for the memory management architecture.

Function signatures and behavior

#include <unistd.h>

int brk(void *end_data_segment);

void *sbrk(intptr_t increment);

The brk subroutine sets the program break value to the value of the end_data_segment parameter and changes the amount of available space accordingly.

The sbrk subroutine adds to the program break value the number of bytes contained in the increment parameter and changes the amount of available space accordingly. The increment parameter can be a negative number, in which case the amount of available space is decreased.

Upon successful completion, the brk subroutine returns a value of 0, and the sbrk subroutine returns a pointer to the start of the new area. If either subroutine is unsuccessful, a value of -1 is returned and the errno global variable is set to indicate the error.

The current Mac OSX implementation of sbrk is an emulation, and has a maximum allocation of 4 Megabytes[1]. When this limit is reached, -1 is returned and the errno is not set.

Error codes

The error ENOMEM is set and the allocated space remains unchanged if one or more of the following are true:

See also

References