root/usr/src/cmd/sgs/liblddbg/common/unused.c
/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License (the "License").
 * You may not use this file except in compliance with the License.
 *
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 * or http://www.opensolaris.org/os/licensing.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information: Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 */

/*
 * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
 * Use is subject to license terms.
 */

#include        "msg.h"
#include        "_debug.h"
#include        "libld.h"

void
Dbg_unused_unref(Rt_map *lmp, const char *depend)
{
        if (DBG_NOTCLASS(DBG_C_UNUSED))
                return;
        if (DBG_NOTDETAIL())
                return;

        dbg_print(LIST(lmp), MSG_INTL(MSG_USD_UNREF), NAME(lmp), depend);
}

void
Dbg_unused_sec(Lm_list *lml, Is_desc *isp)
{
        dbg_isec_name_buf_t     buf;
        char                    *alloc_mem;
        const char              *str;

        if (DBG_NOTCLASS(DBG_C_UNUSED))
                return;
        if (DBG_NOTDETAIL())
                return;

        /*
         * If the file from which this section originates hasn't been referenced
         * at all, skip this diagnostic, as it would have been covered under
         * Dbg_unused_file() called from ignore_section_processing().
         */
        if (isp->is_file &&
            ((isp->is_file->ifl_flags & FLG_IF_FILEREF) == 0))
                return;

        if (isp->is_flags & FLG_IS_DISCARD)
                str = MSG_INTL(MSG_USD_SECDISCARD);
        else
                str = MSG_ORIG(MSG_STR_EMPTY);

        dbg_print(lml, MSG_INTL(MSG_USD_SEC),
            dbg_fmt_isec_name(isp, buf, &alloc_mem),
            EC_XWORD(isp->is_shdr->sh_size), isp->is_file->ifl_name, str);
        if (alloc_mem != NULL)
                free(alloc_mem);
}

void
Dbg_unused_file(Lm_list *lml, const char *name, int needstr, uint_t cycle)
{
        if (DBG_NOTCLASS(DBG_C_UNUSED))
                return;

        if (needstr)
                dbg_print(lml, MSG_INTL(MSG_USD_NEEDSTR), name);
        else if (cycle)
                dbg_print(lml, MSG_INTL(MSG_USD_FILECYCLIC), name, cycle);
        else
                dbg_print(lml, MSG_INTL(MSG_USD_FILE), name);
}

void
Dbg_unused_path(Lm_list *lml, const char *path, uint_t orig, uint_t dup,
    const char *obj)
{
        const char      *fmt;

        if (DBG_NOTCLASS(DBG_C_UNUSED))
                return;
        if (DBG_NOTDETAIL())
                return;

        if (orig & LA_SER_LIBPATH) {
                if (orig & LA_SER_CONFIG) {
                        if (dup)
                                fmt = MSG_INTL(MSG_DUP_LDLIBPATHC);
                        else
                                fmt = MSG_INTL(MSG_USD_LDLIBPATHC);
                } else {
                        if (dup)
                                fmt = MSG_INTL(MSG_DUP_LDLIBPATH);
                        else
                                fmt = MSG_INTL(MSG_USD_LDLIBPATH);
                }
        } else if (orig & LA_SER_RUNPATH) {
                fmt = MSG_INTL(MSG_USD_RUNPATH);
        } else
                return;

        dbg_print(lml, fmt, path, obj);
}