1*5ac3bc71Schristos /* $NetBSD: dwarf_pro_lineno.c,v 1.5 2024/03/03 17:37:32 christos Exp $ */
2e81373b4Schristos
39dd9d0cfSchristos /*-
49dd9d0cfSchristos * Copyright (c) 2010 Kai Wang
59dd9d0cfSchristos * All rights reserved.
69dd9d0cfSchristos *
79dd9d0cfSchristos * Redistribution and use in source and binary forms, with or without
89dd9d0cfSchristos * modification, are permitted provided that the following conditions
99dd9d0cfSchristos * are met:
109dd9d0cfSchristos * 1. Redistributions of source code must retain the above copyright
119dd9d0cfSchristos * notice, this list of conditions and the following disclaimer.
129dd9d0cfSchristos * 2. Redistributions in binary form must reproduce the above copyright
139dd9d0cfSchristos * notice, this list of conditions and the following disclaimer in the
149dd9d0cfSchristos * documentation and/or other materials provided with the distribution.
159dd9d0cfSchristos *
169dd9d0cfSchristos * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
179dd9d0cfSchristos * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
189dd9d0cfSchristos * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
199dd9d0cfSchristos * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
209dd9d0cfSchristos * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
219dd9d0cfSchristos * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
229dd9d0cfSchristos * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
239dd9d0cfSchristos * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
249dd9d0cfSchristos * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
259dd9d0cfSchristos * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
269dd9d0cfSchristos * SUCH DAMAGE.
279dd9d0cfSchristos */
289dd9d0cfSchristos
299dd9d0cfSchristos #include "_libdwarf.h"
309dd9d0cfSchristos
31*5ac3bc71Schristos __RCSID("$NetBSD: dwarf_pro_lineno.c,v 1.5 2024/03/03 17:37:32 christos Exp $");
329dd9d0cfSchristos ELFTC_VCSID("Id: dwarf_pro_lineno.c 2973 2013-12-23 06:46:16Z kaiwang27");
339dd9d0cfSchristos
349dd9d0cfSchristos Dwarf_Unsigned
dwarf_add_line_entry(Dwarf_P_Debug dbg,Dwarf_Unsigned file,Dwarf_Addr off,Dwarf_Unsigned lineno,Dwarf_Signed column,Dwarf_Bool is_stmt,Dwarf_Bool basic_block,Dwarf_Error * error)359dd9d0cfSchristos dwarf_add_line_entry(Dwarf_P_Debug dbg, Dwarf_Unsigned file,
369dd9d0cfSchristos Dwarf_Addr off, Dwarf_Unsigned lineno, Dwarf_Signed column,
379dd9d0cfSchristos Dwarf_Bool is_stmt, Dwarf_Bool basic_block, Dwarf_Error *error)
389dd9d0cfSchristos {
399dd9d0cfSchristos Dwarf_LineInfo li;
409dd9d0cfSchristos Dwarf_Line ln;
419dd9d0cfSchristos
429dd9d0cfSchristos if (dbg == NULL) {
439dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_ARGUMENT);
449dd9d0cfSchristos return (DW_DLV_NOCOUNT);
459dd9d0cfSchristos }
469dd9d0cfSchristos
479dd9d0cfSchristos li = dbg->dbgp_lineinfo;
489dd9d0cfSchristos
499dd9d0cfSchristos ln = STAILQ_LAST(&li->li_lnlist, _Dwarf_Line, ln_next);
509dd9d0cfSchristos
519dd9d0cfSchristos if (ln == NULL || ln->ln_addr > off) {
529dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_ARGUMENT);
539dd9d0cfSchristos return (DW_DLV_NOCOUNT);
549dd9d0cfSchristos }
559dd9d0cfSchristos
569dd9d0cfSchristos if ((ln = calloc(1, sizeof(struct _Dwarf_Line))) == NULL) {
579dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY);
589dd9d0cfSchristos return (DW_DLV_NOCOUNT);
599dd9d0cfSchristos }
609dd9d0cfSchristos ln->ln_li = li;
619dd9d0cfSchristos ln->ln_addr = off;
629dd9d0cfSchristos ln->ln_symndx = 0;
639dd9d0cfSchristos ln->ln_fileno = file;
649dd9d0cfSchristos ln->ln_lineno = lineno;
659dd9d0cfSchristos ln->ln_column = column;
669dd9d0cfSchristos ln->ln_bblock = basic_block != 0;
679dd9d0cfSchristos ln->ln_stmt = is_stmt != 0;
689dd9d0cfSchristos ln->ln_endseq = 0;
699dd9d0cfSchristos STAILQ_INSERT_TAIL(&li->li_lnlist, ln, ln_next);
709dd9d0cfSchristos li->li_lnlen++;
719dd9d0cfSchristos
729dd9d0cfSchristos return (DW_DLV_OK);
739dd9d0cfSchristos }
749dd9d0cfSchristos
759dd9d0cfSchristos Dwarf_Unsigned
dwarf_lne_set_address(Dwarf_P_Debug dbg,Dwarf_Addr offs,Dwarf_Unsigned symndx,Dwarf_Error * error)769dd9d0cfSchristos dwarf_lne_set_address(Dwarf_P_Debug dbg, Dwarf_Addr offs, Dwarf_Unsigned symndx,
779dd9d0cfSchristos Dwarf_Error *error)
789dd9d0cfSchristos {
799dd9d0cfSchristos Dwarf_LineInfo li;
809dd9d0cfSchristos Dwarf_Line ln;
819dd9d0cfSchristos
829dd9d0cfSchristos if (dbg == NULL || symndx == 0) {
839dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_ARGUMENT);
849dd9d0cfSchristos return (DW_DLV_NOCOUNT);
859dd9d0cfSchristos }
869dd9d0cfSchristos
879dd9d0cfSchristos li = dbg->dbgp_lineinfo;
889dd9d0cfSchristos
899dd9d0cfSchristos if ((ln = calloc(1, sizeof(struct _Dwarf_Line))) == NULL) {
909dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY);
919dd9d0cfSchristos return (DW_DLV_NOCOUNT);
929dd9d0cfSchristos }
939dd9d0cfSchristos ln->ln_li = li;
949dd9d0cfSchristos ln->ln_addr = offs;
959dd9d0cfSchristos ln->ln_symndx = symndx;
969dd9d0cfSchristos STAILQ_INSERT_TAIL(&li->li_lnlist, ln, ln_next);
979dd9d0cfSchristos li->li_lnlen++;
989dd9d0cfSchristos
999dd9d0cfSchristos return (DW_DLV_OK);
1009dd9d0cfSchristos }
1019dd9d0cfSchristos
1029dd9d0cfSchristos Dwarf_Unsigned
dwarf_lne_end_sequence(Dwarf_P_Debug dbg,Dwarf_Addr addr,Dwarf_Error * error)1039dd9d0cfSchristos dwarf_lne_end_sequence(Dwarf_P_Debug dbg, Dwarf_Addr addr, Dwarf_Error *error)
1049dd9d0cfSchristos {
1059dd9d0cfSchristos Dwarf_LineInfo li;
1069dd9d0cfSchristos Dwarf_Line ln;
1079dd9d0cfSchristos
1089dd9d0cfSchristos if (dbg == NULL) {
1099dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_ARGUMENT);
1109dd9d0cfSchristos return (DW_DLV_NOCOUNT);
1119dd9d0cfSchristos }
1129dd9d0cfSchristos
1139dd9d0cfSchristos li = dbg->dbgp_lineinfo;
1149dd9d0cfSchristos
1159dd9d0cfSchristos ln = STAILQ_LAST(&li->li_lnlist, _Dwarf_Line, ln_next);
1169dd9d0cfSchristos if (ln && ln->ln_addr >= addr) {
1179dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_ARGUMENT);
1189dd9d0cfSchristos return (DW_DLV_NOCOUNT);
1199dd9d0cfSchristos }
1209dd9d0cfSchristos
1219dd9d0cfSchristos if ((ln = calloc(1, sizeof(struct _Dwarf_Line))) == NULL) {
1229dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY);
1239dd9d0cfSchristos return (DW_DLV_NOCOUNT);
1249dd9d0cfSchristos }
1259dd9d0cfSchristos ln->ln_li = li;
1269dd9d0cfSchristos ln->ln_addr = addr;
1279dd9d0cfSchristos ln->ln_endseq = 1;
1289dd9d0cfSchristos STAILQ_INSERT_TAIL(&li->li_lnlist, ln, ln_next);
1299dd9d0cfSchristos li->li_lnlen++;
1309dd9d0cfSchristos
1319dd9d0cfSchristos return (DW_DLV_OK);
1329dd9d0cfSchristos }
1339dd9d0cfSchristos
1349dd9d0cfSchristos Dwarf_Unsigned
dwarf_add_directory_decl(Dwarf_P_Debug dbg,char * name,Dwarf_Error * error)1359dd9d0cfSchristos dwarf_add_directory_decl(Dwarf_P_Debug dbg, char *name, Dwarf_Error *error)
1369dd9d0cfSchristos {
1379dd9d0cfSchristos Dwarf_LineInfo li;
1389dd9d0cfSchristos
1399dd9d0cfSchristos if (dbg == NULL || name == NULL || strlen(name) == 0) {
1409dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_ARGUMENT);
1419dd9d0cfSchristos return (DW_DLV_NOCOUNT);
1429dd9d0cfSchristos }
1439dd9d0cfSchristos
1449dd9d0cfSchristos li = dbg->dbgp_lineinfo;
1459dd9d0cfSchristos
1469dd9d0cfSchristos li->li_incdirs = realloc(li->li_incdirs, (li->li_inclen + 1) *
1479dd9d0cfSchristos sizeof(char *));
1489dd9d0cfSchristos if (li->li_incdirs == NULL) {
1499dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY);
1509dd9d0cfSchristos return (DW_DLV_NOCOUNT);
1519dd9d0cfSchristos }
1529dd9d0cfSchristos if ((li->li_incdirs[li->li_inclen] = strdup(name)) == NULL) {
1539dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY);
1549dd9d0cfSchristos return (DW_DLV_NOCOUNT);
1559dd9d0cfSchristos }
1569dd9d0cfSchristos
1579dd9d0cfSchristos return (++li->li_inclen);
1589dd9d0cfSchristos }
1599dd9d0cfSchristos
1609dd9d0cfSchristos Dwarf_Unsigned
dwarf_add_file_decl(Dwarf_P_Debug dbg,char * name,Dwarf_Unsigned dirndx,Dwarf_Unsigned mtime,Dwarf_Unsigned size,Dwarf_Error * error)1619dd9d0cfSchristos dwarf_add_file_decl(Dwarf_P_Debug dbg, char *name, Dwarf_Unsigned dirndx,
1629dd9d0cfSchristos Dwarf_Unsigned mtime, Dwarf_Unsigned size, Dwarf_Error *error)
1639dd9d0cfSchristos {
1649dd9d0cfSchristos Dwarf_LineInfo li;
1659dd9d0cfSchristos Dwarf_LineFile lf;
1669dd9d0cfSchristos
1679dd9d0cfSchristos if (dbg == NULL || name == NULL || strlen(name) == 0) {
1689dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_ARGUMENT);
1699dd9d0cfSchristos return (DW_DLV_NOCOUNT);
1709dd9d0cfSchristos }
1719dd9d0cfSchristos
1729dd9d0cfSchristos li = dbg->dbgp_lineinfo;
1739dd9d0cfSchristos
1749dd9d0cfSchristos if ((lf = malloc(sizeof(struct _Dwarf_LineFile))) == NULL) {
1759dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY);
1769dd9d0cfSchristos return (DW_DLE_MEMORY);
1779dd9d0cfSchristos }
1789dd9d0cfSchristos
1799dd9d0cfSchristos if ((lf->lf_fname = strdup(name)) == NULL) {
1809dd9d0cfSchristos free(lf);
1819dd9d0cfSchristos DWARF_SET_ERROR(dbg, error, DW_DLE_MEMORY);
1829dd9d0cfSchristos return (DW_DLE_MEMORY);
1839dd9d0cfSchristos }
1849dd9d0cfSchristos lf->lf_dirndx = dirndx;
1859dd9d0cfSchristos lf->lf_mtime = mtime;
1869dd9d0cfSchristos lf->lf_size = size;
1879dd9d0cfSchristos STAILQ_INSERT_TAIL(&li->li_lflist, lf, lf_next);
1889dd9d0cfSchristos
1899dd9d0cfSchristos return (++li->li_lflen);
1909dd9d0cfSchristos }
191