blob: c1c8be3efc2d4d16a296f470d67b6b7c4b98f71e [file] [log] [blame]
/* Create new section group.
Copyright (C) 2002 Red Hat, Inc.
Written by Ulrich Drepper <drepper@redhat.com>, 2002.
This program is Open Source software; you can redistribute it and/or
modify it under the terms of the Open Software License version 1.0 as
published by the Open Source Initiative.
You should have received a copy of the Open Software License along
with this program; if not, you may obtain a copy of the Open Software
License version 1.0 from http://www.opensource.org/licenses/osl.php or
by writing the Open Source Initiative c/o Lawrence Rosen, Esq.,
3001 King Ranch Road, Ukiah, CA 95482. */
#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
#include <assert.h>
#include <stdlib.h>
#include <string.h>
#include "libasmP.h"
#include <system.h>
AsmScnGrp_t *
asm_newscngrp (ctx, grpname, signature, flags)
AsmCtx_t *ctx;
const char *grpname;
AsmSym_t *signature;
Elf32_Word flags;
{
AsmScnGrp_t *result;
size_t grpname_len = strlen (grpname) + 1;
if (ctx == NULL)
return NULL;
if ((flags & ~GRP_COMDAT) != 0)
{
/* This is not a supported flag. */
__libasm_seterrno (ASM_E_INVALID);
return NULL;
}
result = (AsmScnGrp_t *) malloc (sizeof (AsmScnGrp_t) + grpname_len);
if (result == NULL)
return NULL;
result->signature = signature;
result->members = NULL;
result->nmembers = 0;
result->flags = flags;
memcpy (result->name, grpname, grpname_len);
result->strent = ebl_strtabadd (ctx->section_strtab, result->name,
grpname_len);
if (unlikely (ctx->textp))
// XXX TBI. What is the format?
abort ();
else
{
result->scn = elf_newscn (ctx->out.elf);
if (result->scn == NULL)
{
/* Couldn't allocate a new section. */
__libasm_seterrno (ASM_E_LIBELF);
free (result);
return NULL;
}
}
/* Enqueue is the context data structure. */
if (ctx->ngroups == 0)
{
assert (ctx->groups == NULL);
ctx->groups = result->next = result;
}
else
{
result->next = ctx->groups->next;
ctx->groups = ctx->groups->next = result;
}
++ctx->ngroups;
return result;
}