Beberapa bantuan generik: gdb memulai GDB, tanpa program debugging les gdb memulai program debug program program inti gdb core core coredump yang dihasilkan oleh program gdb --help untuk menjelaskan opsi baris perintah 1- Pertama-tama temukan direktori tempat pembuatan corefile. 2 - Kemudian gunakan perintah ls - ltr di direktori untuk menemukan corefile yang dihasilkan terbaru. 3 - Untuk memuat corefile menggunakan gdb binary path dari corefile Ini akan memuat corefile. 4 - Kemudian Anda bisa mendapatkan informasi menggunakan perintah bt. Untuk detail backtrace gunakan bt full. 5 - Untuk mencetak variabel menggunakan nama variabel cetak atau p variabel-nama 6- Untuk mendapat bantuan tentang opsi bantuan penggunaan gdb atau gunakan topik pencarian apropos 7 - Gunakan frame frame-number untuk menuju ke nomor frame yang diinginkan. 8 - Gunakan perintah n dan turun n untuk memilih bingkai n frame ke atas dan pilih frame n frame ke bawah masing-masing. 9- Untuk berhenti menggunakan gdb berhenti atau q .8. Memeriksa Data Cara yang biasa untuk memeriksa data dalam program Anda adalah dengan perintah cetak (disingkat p), atau pemeriksaan sinonimnya. Ini mengevaluasi dan mencetak nilai dari ekspresi bahasa yang ditulis oleh program Anda (lihat bagian Menggunakan GDB dengan Bahasa yang Berbeda). Print expr print f expr expr adalah ekspresi (dalam bahasa sumber). Secara default nilai expr dicetak dalam format yang sesuai dengan tipe datanya Anda dapat memilih format yang berbeda dengan menentukan f. Dimana f adalah huruf yang menentukan format lihat format Output. Cetak cetak f Jika Anda menghilangkan expr. GDB menampilkan nilai terakhir lagi (dari riwayat nilai lihat bagian Riwayat nilai). Ini memungkinkan Anda untuk dengan mudah memeriksa nilai yang sama dalam format alternatif. Cara yang lebih rendah untuk memeriksa data adalah dengan perintah x. Ini memeriksa data dalam memori pada alamat tertentu dan mencetaknya dalam format yang ditentukan. Lihat bagian Memeriksa memori. Jika Anda tertarik dengan informasi tentang jenis, atau tentang bagaimana bidang struct atau kelas dideklarasikan, gunakan perintah ptype exp daripada mencetak. Lihat bagian Memeriksa Tabel Simbol. 8.1 Ekspresi dicetak dan banyak perintah GDB lainnya menerima sebuah ekspresi dan menghitung nilainya. Setiap jenis variabel konstan, variabel atau operator yang didefinisikan oleh bahasa pemrograman yang Anda gunakan valid dalam ungkapan di GDB. Ini termasuk ekspresi kondisional, pemanggilan fungsi, gips dan konstanta string. Ini sayangnya tidak termasuk simbol yang didefinisikan oleh perintah define preprocessor. GDB mendukung konstanta array dalam input ekspresi oleh pengguna. Sintaksnya . Misalnya, Anda bisa menggunakan perintah print untuk membangun array di memori yang malloc ed pada program target. Karena C begitu luas, sebagian besar ungkapan yang ditunjukkan dalam contoh dalam manual ini ada di C. Lihat bagian Menggunakan GDB dengan Bahasa yang Berbeda. Untuk informasi bagaimana menggunakan ungkapan dalam bahasa lain. Pada bagian ini, kita membahas operator yang dapat Anda gunakan dalam ekspresi GDB terlepas dari bahasa pemrograman Anda. Pemain didukung dalam semua bahasa, tidak hanya di C, karena sangat berguna untuk memasukkan nomor ke dalam penunjuk untuk memeriksa struktur pada alamat itu di memori. GDB mendukung operator ini, selain yang umum untuk bahasa pemrograman: adalah operator biner untuk merawat bagian memori sebagai array. Lihat bagian Array buatan. untuk informasi lebih lanjut. :: memungkinkan Anda untuk menentukan variabel dalam hal file atau fungsi di mana ia didefinisikan. Lihat bagian Variabel program. Addr Mengacu pada objek tipe tipe yang tersimpan pada alamat addr di memori. Addr mungkin merupakan ekspresi yang nilainya integer atau pointer (tapi tanda kurung dibutuhkan di sekitar operator biner, sama seperti pada pemeran). Konstruksi ini diperbolehkan terlepas dari jenis data yang biasanya seharusnya berada pada addr. 8.2 Variabel Program Jenis ekspresi yang paling umum digunakan adalah nama variabel dalam program Anda. Variabel dalam ekspresi dipahami dalam kerangka stack yang dipilih (lihat bagian Memilih bingkai) mereka harus berupa: global (atau file-static) terlihat sesuai dengan aturan lingkup bahasa pemrograman dari titik eksekusi dalam frame tersebut. Ini berarti bahwa Dalam fungsi Anda dapat memeriksa dan menggunakan variabel a setiap kali program Anda dijalankan dalam fungsi foo. Tapi Anda hanya bisa menggunakan atau memeriksa variabel b saat program Anda dijalankan di dalam blok di mana b dinyatakan. Ada pengecualian: Anda dapat merujuk ke variabel atau fungsi yang ruang lingkupnya adalah file sumber tunggal meskipun titik eksekusi saat ini tidak ada dalam file ini. Tapi ada kemungkinan untuk memiliki lebih dari satu variabel atau fungsi seperti itu dengan nama yang sama (dalam file sumber yang berbeda). Jika itu terjadi, mengacu pada nama itu memiliki efek yang tidak terduga. Jika Anda mau, Anda dapat menentukan variabel statis dalam fungsi atau file tertentu, dengan menggunakan notasi kolon-kolon: Berikut file atau fungsi adalah nama konteks untuk variabel statis. Dalam kasus nama file, Anda dapat menggunakan tanda kutip untuk memastikan GDB mem-parsing nama file sebagai satu kata - misalnya, untuk mencetak nilai global x yang didefinisikan dalam f2.c. Penggunaan :: sangat jarang bertentangan dengan penggunaan notasi yang sama di C. GDB juga mendukung penggunaan operator resolusi lingkup C dalam ekspresi GDB. Peringatan: Terkadang, variabel lokal mungkin nampaknya memiliki nilai yang salah pada titik-titik tertentu dalam suatu fungsi - tepat setelah masuk ke lingkup baru, dan tepat sebelum keluar. Anda mungkin melihat masalah ini saat Anda melangkah dengan instruksi mesin. Ini karena, pada kebanyakan mesin, dibutuhkan lebih dari satu instruksi untuk membuat kerangka tumpukan (termasuk definisi variabel lokal) jika Anda melangkah dengan instruksi mesin, variabel mungkin tampak memiliki nilai yang salah sampai kerangka tumpukan benar-benar dibangun. Saat keluar, biasanya juga dibutuhkan lebih dari satu instruksi mesin untuk menghancurkan bingkai tumpukan setelah Anda mulai melangkah melalui kelompok instruksi tersebut, definisi variabel lokal mungkin akan hilang. Ini mungkin juga terjadi ketika compiler melakukan pengoptimalan yang signifikan. Untuk memastikan selalu melihat nilai yang akurat, matikan semua optimasi saat kompilasi. Efek lain yang mungkin dari optimasi kompilator adalah mengoptimalkan variabel yang tidak digunakan dari keberadaan, atau menetapkan variabel ke register (berlawanan dengan alamat memori). Bergantung pada dukungan untuk kasus-kasus seperti yang ditawarkan oleh format info debug yang digunakan oleh kompilator, GDB mungkin tidak dapat menampilkan nilai untuk variabel lokal tersebut. Jika itu terjadi, GDB akan mencetak pesan seperti ini: Untuk mengatasi masalah tersebut, kompilasi ulang tanpa pengoptimalan, atau gunakan format info debug yang berbeda, jika kompilator mendukung beberapa format seperti itu. Sebagai contoh, GCC, kompiler GNU CC biasanya mendukung opsi - gstabs. - gstabs menghasilkan info debug dalam format yang lebih unggul dari format seperti COFF. Anda mungkin bisa menggunakan DWARF2 (-gdwarf-2), yang juga merupakan bentuk yang efektif untuk info debug. Lihat bagian Pilihan untuk Debugging Your Programme atau GNU CC dalam Menggunakan GNU CC. untuk informasi lebih lanjut. Operan kiri harus berada dalam memori. Nilai Array yang dibuat dengan cara ini berperilaku seperti array lain dalam hal subscripting, dan dipaksakan ke pointer saat digunakan dalam ekspresi. Array buatan paling sering muncul dalam ekspresi melalui nilai sejarah (lihat bagian Riwayat nilai), setelah mencetak satu. Cara lain untuk membuat array buatan adalah dengan menggunakan pemeran. Ini menafsirkan ulang sebuah nilai seolah-olah itu adalah sebuah array. Nilai tidak perlu di memori: Sebagai kenyamanan, jika Anda membiarkan panjang array keluar (seperti pada nilai (tipe)) GDB menghitung ukuran untuk mengisi nilai (sebagai sizeof (nilai) sizeof (tipe). Terkadang array buatan Mekanisme tidak cukup cukup dalam struktur data yang cukup kompleks, unsur-unsur yang menarik mungkin tidak benar-benar berdekatan - misalnya, jika Anda tertarik dengan nilai pointer dalam array. Salah satu pekerjaan yang berguna - sekitar dalam situasi ini adalah menggunakan Variabel kenyamanan (lihat bagian Variabel Kenyamanan) sebagai penghitung dalam sebuah ekspresi yang mencetak nilai menarik pertama, lalu ulangi ungkapan itu melalui RET. Misalnya, Anda memiliki array dtab dari pointer ke struktur, dan Anda tertarik dengan nilai Dari bidang fv di setiap struktur Berikut adalah contoh dari jenis yang mungkin Anda ketik: 8.4 Format output Secara default, GDB mencetak nilai sesuai dengan tipe datanya. Terkadang ini bukan yang Anda inginkan. Misalnya, Anda mungkin ingin mencetak Nomor di hex, atau po Antar dalam desimal Atau Anda mungkin ingin melihat data di memori pada alamat tertentu sebagai string karakter atau sebagai instruksi. Untuk melakukan hal-hal ini, tentukan format output saat Anda mencetak sebuah nilai. Penggunaan format output yang paling sederhana adalah mengatakan bagaimana mencetak nilai yang sudah dihitung. Hal ini dilakukan dengan memulai argumen perintah cetak dengan garis miring dan format huruf. Format huruf yang didukung adalah: x Anggap bit nilai sebagai bilangan bulat, dan cetak bilangan bulat dalam heksadesimal. D Cetak sebagai bilangan bulat dalam desimal yang ditandatangani U Cetak sebagai bilangan bulat dalam desimal unsigned. O Cetak sebagai bilangan bulat dalam oktal. T Cetak sebagai bilangan bulat dalam biner. Huruf t berarti dua huruf. (2) Print sebagai alamat, keduanya mutlak dalam heksadesimal dan sebagai offset dari simbol terdekat sebelumnya. Anda dapat menggunakan format ini yang digunakan untuk menemukan di mana (dalam fungsi apa) alamat yang tidak diketahui berada: simbol info perintah 0x54320 menghasilkan hasil yang serupa. Lihat simbol info bagian. C Perhatikan sebagai integer dan cetak sebagai karakter konstan. F Perhatikan bit nilai sebagai floating point number dan print menggunakan syntax floating point biasa. Misalnya, untuk mencetak program counter di hex (lihat bagian 8.10 Registers), ketik Perhatikan bahwa tidak ada ruang yang diperlukan sebelum garis miring ini karena nama perintah di GDB tidak dapat berisi garis miring. Untuk mencetak ulang nilai terakhir dalam nilai sejarah dengan format yang berbeda, Anda dapat menggunakan perintah cetak hanya dengan format dan tanpa ekspresi. Misalnya, px mencetak ulang nilai terakhir dalam hex. 8.5 Memeriksa memori Anda dapat menggunakan perintah x (untuk diperiksa) untuk memeriksa memori dalam beberapa format, terlepas dari jenis data program Anda. X nfu addr x addr x Gunakan perintah x untuk memeriksa memori. N. F. Dan u adalah semua parameter opsional yang menentukan berapa banyak memori yang akan ditampilkan dan bagaimana memformatnya addr adalah ekspresi yang memberi alamat di mana Anda ingin mulai menampilkan memori. Jika Anda menggunakan default untuk nfu. Anda tidak perlu mengetikkan garis miring. Beberapa perintah mengatur default yang mudah digunakan untuk addr. N. Jumlah pengulangan Jumlah pengulangan adalah bilangan bulat desimal yang defaultnya adalah 1. Ini menentukan jumlah memori (dihitung oleh unit u) yang akan ditampilkan. F. Format tampilan Format tampilan adalah salah satu format yang digunakan oleh cetak. S (null-terminated string), atau i (instruksi mesin). Defaultnya adalah x (heksadesimal) pada awalnya. Perubahan standar setiap kali Anda menggunakan x atau cetak. Kamu Ukuran unit Ukuran unit adalah salah satu b Bytes. H Halfwords (dua byte). W Kata-kata (empat byte). Ini adalah default awal. G Kata-kata raksasa (delapan byte). Setiap kali Anda menentukan ukuran unit dengan x. Ukuran itu menjadi unit default saat Anda menggunakan x. (Untuk format s dan i, ukuran unit diabaikan dan biasanya tidak ditulis.) Addr. Mulai tampilan alamat addr adalah alamat dimana anda ingin GDB mulai menampilkan memori. Ekspresi tidak perlu memiliki nilai pointer (meskipun mungkin) selalu ditafsirkan sebagai alamat integer dari byte memori. Lihat bagian Ekspresi. Untuk informasi lebih lanjut tentang ekspresi. Default untuk addr biasanya hanya setelah alamat terakhir diperiksa - namun beberapa perintah lainnya juga mengatur alamat default: info breakpoints (ke alamat breakpoint terakhir yang terdaftar), info line (ke alamat awal dari sebuah baris), dan Cetak (jika Anda menggunakannya untuk menampilkan nilai dari memori). Sebagai contoh, x3uh 0x54320 adalah permintaan untuk menampilkan tiga halfwords (h) memori, diformat sebagai unsigned decimal integers (u), dimulai dari alamat 0x54320. X4xw sp mencetak empat kata (w) memori di atas stack pointer (sini, sp lihat bagian register) dalam heksadesimal (x). Karena huruf yang menunjukkan ukuran unit semuanya berbeda dari huruf yang menentukan format output, Anda tidak perlu mengingat apakah ukuran atau format unit tampil lebih dulu baik pesanan. Spesifikasi output 4xw dan 4wx berarti hal yang persis sama. (Namun, hitungan n harus diawali wx4 pertama tidak bekerja.) Meskipun ukuran unit u diabaikan untuk format s dan i. Anda mungkin masih ingin menggunakan hitungan n misalnya, 3i menentukan bahwa Anda ingin melihat tiga petunjuk mesin, termasuk operan apapun. Perintah pembongkaran memberikan cara alternatif untuk memeriksa instruksi mesin lihat Source dan kode mesin. Semua default untuk argumen ke x dirancang agar mudah untuk terus memindai memori dengan spesifikasi minimal setiap kali Anda menggunakan x. Sebagai contoh, setelah Anda memeriksa tiga instruksi mesin dengan x3i addr. Anda bisa memeriksa tujuh berikutnya hanya dengan x7. Jika Anda menggunakan RET untuk mengulangi perintah x, jumlah ulang n digunakan lagi argumen argumen lainnya untuk penggunaan x yang berurutan. Alamat dan isi yang dicetak oleh perintah x tidak disimpan dalam nilai sejarah karena seringkali terlalu banyak dan akan menghalangi jalannya. Sebagai gantinya, GDB membuat nilai ini tersedia untuk penggunaan selanjutnya dalam ekspresi sebagai nilai variabel kenyamanan dan. Setelah perintah x, alamat terakhir yang diperiksa tersedia untuk digunakan dalam ekspresi dalam variabel kenyamanan. Isi alamat itu, seperti yang diteliti, tersedia dalam variabel kenyamanan. Jika perintah x memiliki jumlah ulang, alamat dan isi yang tersimpan berasal dari unit memori terakhir yang dicetak ini tidak sama dengan alamat terakhir yang dicetak jika beberapa unit dicetak pada baris terakhir output. 8.6 Tampilan otomatis Jika Anda mendapati bahwa Anda sering mencetak nilai ekspresi (untuk melihat bagaimana perubahannya), Anda mungkin ingin menambahkannya ke daftar tampilan otomatis sehingga GDB mencetak nilainya setiap kali program Anda berhenti. Setiap ekspresi yang ditambahkan ke daftar diberi nomor untuk mengidentifikasinya untuk menghapus ekspresi dari daftar, Anda menentukan nomor itu. Tampilan otomatis terlihat seperti ini: Tampilan ini menunjukkan nomor item, ekspresi dan nilai saat ini. Seperti pada display yang anda minta secara manual menggunakan x atau print. Anda dapat menentukan format output yang Anda inginkan sebenarnya, display menentukan apakah akan menggunakan cetak atau x tergantung pada seberapa rumit spesifikasi format Anda - menggunakan x jika Anda menentukan ukuran unit, atau salah satu dari dua format (i dan s) Yang hanya didukung oleh x jika tidak ia menggunakan print. Tampilkan expr Tambahkan expr ekspresi ke daftar ekspresi untuk ditampilkan setiap kali program Anda berhenti. Lihat bagian Ekspresi. Layar tidak berulang jika Anda menekan RET lagi setelah menggunakannya. Tampilkan fmt expr Untuk fmt hanya menentukan format tampilan dan bukan ukuran atau hitungan, tambahkan expr ekspresi ke daftar tampilan otomatis tapi atur untuk menampilkannya setiap kali dalam format yang ditentukan fmt. Lihat bagian Format output. Tampilkan fmt addr Untuk fmt i atau s. Atau termasuk ukuran unit atau sejumlah unit, tambahkan atribut addr sebagai alamat memori yang akan diperiksa setiap kali program Anda berhenti. Memeriksa sarana yang berlaku melakukan x fmt addr. Lihat bagian Memeriksa memori. Sebagai contoh, displayi pc bisa sangat membantu, untuk melihat instruksi mesin yang akan dieksekusi setiap kali eksekusi berhenti (pc adalah nama yang umum untuk program counter lihat section Register). Undi dnums undisplay Hapus dnums display Hapus nomor item dnums dari daftar ekspresi yang akan ditampilkan. Undisplay tidak terulang jika Anda menekan RET setelah menggunakannya. (Jika tidak, Anda hanya akan mendapatkan kesalahan Tidak ada nomor tampilan ...) menonaktifkan tampilan dnums. Nonaktifkan tampilan nomor item dnums. Item tampilan cacat tidak dicetak secara otomatis, namun tidak dilupakan. Ini bisa diaktifkan lagi nanti. Aktifkan dnums display Aktifkan tampilan nomor item dnums. Ini menjadi efektif sekali lagi dalam tampilan otomatis ekspresinya, sampai Anda menentukan sebaliknya. Tampilkan Tampilkan nilai ekspresi saat ini pada daftar, sama seperti saat program berhenti. Tampilan info Cetak daftar ungkapan yang sebelumnya disiapkan untuk ditampilkan secara otomatis, masing-masing dengan nomor itemnya, namun tanpa menunjukkan nilainya. Ini termasuk ungkapan-ungkapan yang cacat, yang ditandai seperti itu. Ini juga mencakup ekspresi yang tidak akan ditampilkan sekarang karena mereka mengacu pada variabel otomatis yang saat ini tidak tersedia. Jika ekspresi tampilan mengacu pada variabel lokal, maka tidak masuk akal di luar konteks leksikal yang disiapkannya. Ekspresi seperti itu dinonaktifkan saat eksekusi memasuki konteks di mana salah satu variabelnya tidak didefinisikan. Misalnya, jika Anda memberi perintah menampilkan lastchar saat berada di dalam fungsi dengan argumen lastchar. GDB menampilkan argumen ini saat program Anda terus berhenti di dalam fungsi itu. Ketika berhenti di tempat lain - di mana tidak ada variabel lastchar --- layar dinonaktifkan secara otomatis. Lain kali program Anda berhenti dimana lastchar bermakna, Anda dapat mengaktifkan ekspresi tampilan sekali lagi. Anda dapat menggunakan alamat cetak yang ditetapkan untuk menghilangkan semua display yang bergantung pada mesin dari antarmuka GDB. Misalnya, dengan alamat cetak mati. Anda harus mendapatkan teks yang sama untuk menandai kembali semua mesin - apakah melibatkan argumen pointer atau tidak. Tampilkan alamat cetak Tampilkan apakah alamat yang akan dicetak atau tidak. Ketika GDB mencetak alamat simbolis, biasanya mencetak simbol terdekat terdekat ditambah offset. Jika simbol itu tidak mengidentifikasi alamatnya secara unik (misalnya, ini adalah nama yang ruang lingkupnya adalah file sumber tunggal), Anda mungkin perlu mengklarifikasi. Salah satu cara untuk melakukannya adalah dengan info line. Misalnya info line 0x4537. Sebagai alternatif, Anda dapat mengatur GDB untuk mencetak file sumber dan nomor baris saat mencetak alamat simbolis: set print symbol-filename pada Tell GDB untuk mencetak nama file sumber dan nomor baris simbol dalam bentuk simbolis dari sebuah alamat. Set print symbol-filename off Jangan mencetak nama file sumber dan nomor baris simbol. Ini adalah defaultnya. Tampilkan print symbol-filename Tunjukkan apakah GDB akan mencetak nama file sumber dan nomor baris simbol dalam bentuk simbolis dari sebuah alamat. Situasi lain di mana sangat membantu untuk menunjukkan nama file simbol dan nomor baris adalah ketika pembongkaran kode GDB menunjukkan nomor baris dan file sumber yang sesuai dengan setiap instruksi. Juga, Anda mungkin ingin melihat bentuk simbolis hanya jika alamat yang dicetak cukup dekat dengan simbol terdekat terdekat: atur max-symbolic-offset max-offset kirim GDB untuk hanya menampilkan bentuk simbolis dari sebuah alamat jika offset antara Simbol terdekat terdekat dan alamatnya kurang dari max-offset. Defaultnya adalah 0, yang memberitahu GDB untuk selalu mencetak bentuk simbolis dari sebuah alamat jika ada simbol yang mendahuluinya. Tampilkan cetak max-symbolic-offset Tanyakan seberapa besar offset maksimum yang dicetak GDB dalam alamat simbolis. Jika Anda memiliki pointer dan Anda tidak yakin di mana titik itu, coba atur simbol cetak-nama filename. Kemudian Anda bisa menentukan nama dan lokasi file sumber dari variabel dimana titik itu menunjuk, menggunakan pa pointer. Ini menafsirkan alamat dalam bentuk simbolis. Sebagai contoh, di sini GDB menunjukkan bahwa variabel ptt poin pada variabel lain t. Didefinisikan dalam hi2.c. Peringatan: Untuk petunjuk yang menunjuk ke variabel lokal, pa tidak menunjukkan nama simbol dan nama file dari rujukan, bahkan dengan opsi cetak set yang sesuai telah diaktifkan. Pengaturan lain mengontrol bagaimana berbagai jenis benda dicetak: atur array cetak atur print array pada print print Pretty. Format ini lebih mudah dibaca, namun menggunakan lebih banyak ruang. Standarnya dimatikan. Atur print array off Kembali ke format terkompresi untuk array. Tampilkan print array Tunjukkan apakah format terkompres atau cantik dipilih untuk menampilkan array. Atur elemen cetak elemen jumlah elemen Tetapkan batas pada berapa banyak elemen dari array yang akan dicetak GDB. Jika GDB mencetak array besar, printer akan berhenti mencetak setelah mencetak jumlah elemen yang ditetapkan oleh perintah elemen cetak yang ditetapkan. Batas ini juga berlaku untuk tampilan string. Saat GDB dimulai, batas ini diatur ke 200. Menetapkan jumlah elemen menjadi nol berarti pencetakan tidak terbatas. Tampilkan elemen cetak Tampilkan jumlah elemen dari array besar yang akan dicetak GDB. Jika jumlahnya 0, maka pencetakannya tidak terbatas. Setel cetak null-stop Penyebab GDB berhenti mencetak karakter dari sebuah array saat NULL pertama ditemukan. Ini berguna bila array besar sebenarnya hanya berisi string pendek. Standarnya dimatikan. Atur cetak dengan cantik pada Penyebab GDB untuk mencetak struktur dalam format indentasi dengan satu anggota per baris, seperti ini: cukup cetak Mencetak GDB untuk mencetak struktur dalam format yang kompak, seperti ini: Ini adalah format defaultnya. Tampilkan cetak cantik Tunjukkan format GDB yang digunakan untuk mencetak struktur. Set print sevenbit-string pada Print hanya menggunakan karakter tujuh bit jika opsi ini diset, GDB menampilkan karakter delapan bit (dalam string atau nilai karakter) dengan menggunakan notasi nnn. Pengaturan ini paling baik jika Anda bekerja dalam bahasa Inggris (ASCII) dan Anda menggunakan bit karakter orde tinggi sebagai penanda atau meta bit. Set print sevenbit-string off Print full eight-bit characters. Hal ini memungkinkan penggunaan set karakter yang lebih internasional, dan merupakan default. Tampilkan print sevenbit-string Tunjukkan apakah GDB hanya mencetak karakter tujuh-bit atau tidak. Atur serikat cetak pada Tell GDB untuk mencetak serikat pekerja yang terkandung dalam struktur. Ini adalah pengaturan default. Atur serikat cetak dari Tell GDB untuk tidak mencetak serikat pekerja yang terkandung dalam struktur. Tampilkan serikat cetak Tanya GDB apakah akan mencetak serikat pekerja yang terkandung dalam struktur. Sebagai contoh, mengingat deklarasi Pengaturan ini menarik saat melakukan debug pada program C: atur pencetak gambar cetak yang dipasang pada tulisan Print C di formulir sumbernya dan bukan pada bentuk yang dikodekan (dirusak) diteruskan ke assembler dan penghubung untuk hubungan tipe-aman . Defaultnya adalah on. Tunjukkan kilau cetak Tunjukkan apakah nama C dicetak dalam bentuk hancur atau berdarah. Atur cetak asm-demangle set print asm-demangle pada nama C C dalam bentuk sumbernya daripada bentuknya yang hancur, bahkan dalam cetakan kode assembler seperti pembongkaran instruksi. Standarnya dimatikan. Tunjukkan cetak asm-demangle Tampilkan apakah nama C dalam daftar rakitan dicetak dalam bentuk hancur atau dirusak. Atur gaya gaya gantung Pilih di antara beberapa skema pengkodean yang digunakan oleh kompiler yang berbeda untuk mewakili nama C. Pilihan untuk gaya saat ini: otomatis Izinkan GDB memilih gaya decoding dengan memeriksa program Anda. Gnu Decode berdasarkan algoritma pengkodean GNU C compiler (g). Ini adalah defaultnya. Hp Decode berdasarkan algoritma pengkodean HP ANSI C (aCC). Decode jernih berdasarkan algoritma pengkodean kompiler Lucid C (lcc). Lengan Decode menggunakan algoritma di C Annotated Reference Manual. Peringatan: setting ini saja tidak cukup untuk memungkinkan debugging cfront - generated executables. GDB akan membutuhkan peningkatan lebih lanjut untuk mengizinkannya. Jika Anda menghilangkan gaya. Anda akan melihat daftar format yang mungkin. Tampilkan gaya gantung Tampilan gaya pengkodean yang saat ini digunakan untuk mendekode simbol C. Atur objek cetak Atur objek cetak pada saat menampilkan pointer ke objek, identifikasikan tipe objek yang sebenarnya (diturunkan) daripada tipe yang dideklarasikan, dengan menggunakan tabel fungsi virtual. Setel objek cetak dari Display hanya tipe objek yang dideklarasikan, tanpa mengacu ke tabel fungsi virtual. Ini adalah pengaturan default. Tampilkan objek cetak Tunjukkan apakah sebenarnya, atau dideklarasikan, jenis objek akan ditampilkan. Set print static-member mengatur print static-members pada Print static members saat menampilkan objek C. Defaultnya adalah on. Atur print static-members off Jangan mencetak anggota statis saat menampilkan objek C. Tampilkan print static-members Tampilkan apakah anggota C static tercetak, atau tidak. Set print vtbl set print vtbl on Pretty print C tabel fungsi virtual. Standarnya dimatikan. (Perintah vtbl tidak bekerja pada program yang dikompilasi dengan kompiler ANSI C HP (aCC).) Atur cetak vtbl off Jangan mencetak dengan mudah tabel fungsi virtual C. Tampilkan cetak vtbl Tunjukkan apakah tabel fungsi virtual C cukup dicetak, atau tidak. 8.9 Variabel Kenyamanan GDB menyediakan variabel kenyamanan yang dapat Anda gunakan dalam GDB untuk berpegang pada nilai dan merujuknya nanti. Variabel ini ada sepenuhnya di dalam GDB, bukan bagian dari program Anda, dan menetapkan variabel kenyamanan tidak berpengaruh langsung pada pelaksanaan program Anda lebih lanjut. Itu sebabnya anda bisa menggunakannya secara bebas. Variabel kenyamanan diawali dengan. Setiap nama yang didahului oleh dapat digunakan untuk variabel kenyamanan, kecuali jika itu adalah salah satu nama register khusus mesin yang telah ditentukan sebelumnya (lihat bagian Register). (Nilai referensi sejarah, sebaliknya, adalah angka yang didahului oleh. Lihat bagian Riwayat nilai.) Anda dapat menyimpan sebuah nilai dalam variabel kenyamanan dengan ekspresi tugas, sama seperti Anda akan menetapkan variabel dalam program Anda. Sebagai contoh: akan menghemat nilai yang terkandung dalam objek yang ditunjukkan oleh objectptr. Menggunakan variabel kenyamanan untuk pertama kalinya menciptakannya, namun nilainya kosong sampai Anda menetapkan nilai baru. Anda dapat mengubah nilainya dengan tugas lain kapan saja. Variabel kenyamanan tidak memiliki tipe tetap. Anda dapat menetapkan variabel kenyamanan semua jenis nilai, termasuk struktur dan array, bahkan jika variabel itu sudah memiliki nilai dari tipe yang berbeda. Variabel kenyamanan, bila digunakan sebagai ungkapan, memiliki jenis nilai saat ini. Tunjukkan kenyamanan Mencetak daftar variabel kenyamanan yang digunakan sejauh ini, dan nilainya. Disingkat menunjukkan konv. Salah satu cara untuk menggunakan variabel kenyamanan adalah sebagai penghitung untuk bertambah atau pointer menjadi maju. Misalnya, untuk mencetak bidang dari elemen berturut-turut dari susunan struktur: Ulangi perintah itu dengan mengetikkan RET. Beberapa variabel kenyamanan dibuat secara otomatis oleh GDB dan nilai yang diberikan mungkin berguna. Variabel ini secara otomatis diatur oleh perintah x ke alamat terakhir yang diperiksa (lihat bagian Memeriksa memori). Perintah lain yang menyediakan alamat default untuk x untuk memeriksa juga diatur ke alamat perintah ini termasuk info line dan info breakpoint. Tipe ini batal kecuali bila ditetapkan oleh perintah x, dalam hal ini adalah pointer ke tipe. Variabel tersebut secara otomatis ditetapkan oleh perintah x ke nilai yang ditemukan di alamat terakhir yang diteliti. Jenisnya dipilih agar sesuai dengan format data yang dicetak. Exitcode Kode keluar variabel secara otomatis diatur ke kode keluar saat program sedang debugged berakhir. Pada sistem HP-UX, jika Anda merujuk ke sebuah nama fungsi atau variabel yang dimulai dengan tanda dolar, GDB mencari nama pengguna atau sistem terlebih dahulu, sebelum mencari variabel kenyamanan. 8.12 Atribut daerah memori Atribut daerah memori memungkinkan Anda untuk menggambarkan penanganan khusus yang diperlukan oleh daerah dari memori target Anda. GDB menggunakan atribut untuk menentukan apakah mengizinkan jenis memori tertentu mengakses apakah menggunakan akses lebar tertentu dan apakah akan menyimpan memori target. Daerah memori yang ditetapkan dapat diaktifkan dan dinonaktifkan secara individual. Bila area memori dinonaktifkan, GDB menggunakan atribut default saat mengakses memori di wilayah tersebut. Demikian pula, jika tidak ada daerah memori yang ditetapkan, GDB menggunakan atribut default saat mengakses semua memori. Bila wilayah memori ditentukan, diberi nomor untuk mengidentifikasinya untuk mengaktifkan, menonaktifkan, atau menghapus wilayah memori, Anda menentukan nomor itu. Alamat address1 address2 Tentukan daerah memori yang dibatasi oleh address1 dan address2 dengan atribut atribut. . Hapus mem nums Hapus daerah memori nums. . Nonaktifkan mem nums Nonaktifkan daerah memori nums. . Area memori yang cacat tidak dilupakan. Ini bisa diaktifkan lagi nanti. Mengaktifkan mem nums Aktifkan daerah memori nums. . Info mem Mencetak tabel semua area memori yang ditentukan, dengan kolom berikut untuk masing-masing wilayah. Nomor Daerah Memori Diaktifkan atau Dinonaktifkan. Daerah memori yang diaktifkan ditandai dengan y. Daerah memori yang dinonaktifkan ditandai dengan n. Alamat Lo Alamat yang menentukan batas bawah inklusif wilayah memori. Hai Alamat Alamat yang menentukan batas atas eksklusif wilayah memori. Atribut Daftar atribut yang ditetapkan untuk wilayah memori ini. 8.13 Salin antara memori dan file Perintah dump. menambahkan. Dan restore digunakan untuk menyalin data antara memori target dan file. Data ditulis ke dalam file menggunakan dump atau append. Dan dipulihkan dari file ke memori dengan menggunakan restore. File mungkin biner, srec, intel hex, atau tekhex (tapi hanya file biner yang bisa ditambahkan). Dump binary memory filename startaddr endaddr Dump isi memori dari startaddr ke endaddr ke dalam file format file biner mentah. Tambahkan binary memory filename startaddr endaddr Tambahkan isi memori dari startaddr ke endaddr ke filename file format biner mentah. Dump nilai biner filename ekspresi Dump nilai ekspresi menjadi baku biner format file filename. Tambahkan ekspresi filename memori biner Tambahkan nilai ekspresi ke file format biner mentah. Dump ihex memory filename startaddr endaddr Dump isi memori dari startaddr ke endaddr ke file format file hex hex. Dump ihex value filename expression Dump nilai ekspresi ke dalam file format file hex hex. Dump srec memory filename startaddr endaddr Dump isi memori dari startaddr ke endaddr ke dalam file format file srec. Dump srec value filename expression Dump nilai ekspresi menjadi file format file srec. Dump tekhex memory filename startaddr endaddr Dump isi memori dari startaddr ke endaddr ke format file format tekhex. Dump tekhex value filename expression Dump nilai ekspresi ke dalam format file format tekhex. Restore filename binary bias start end Kembalikan isi file filename ke dalam memori. Perintah restore secara otomatis dapat mengenali format file bfd yang diketahui, kecuali untuk biner mentah. Untuk mengembalikan file biner mentah Anda harus menggunakan binari argumen opsional setelah nama file. Jika bias tidak nol, nilainya akan ditambahkan ke alamat yang terdapat dalam file. File biner selalu dimulai pada alamat nol, jadi akan dikembalikan pada alamat bias. File bfd lainnya memiliki lokasi built-in yang akan dikembalikan pada bias offset dari lokasi tersebut. Jika start andor berakhir adalah non-zero, maka hanya data antara file offset start dan file offset end yang akan dipulihkan. Offset ini relatif terhadap alamat dalam file, sebelum argumen bias diterapkan.18.1 Perintah untuk Menentukan File Anda mungkin ingin menentukan nama file executable dan core dump. Cara yang biasa dilakukan pada saat start-up, menggunakan argumen untuk perintah start up gdb (lihat Getting In and Out dari gdb). Terkadang perlu diubah ke file yang berbeda selama sesi gdb. Atau Anda bisa menjalankan gdb dan lupa menentukan file yang ingin Anda gunakan. Atau Anda melakukan debug pada target jarak jauh melalui gdbserver (lihat file). Dalam situasi ini perintah gdb untuk menentukan file baru berguna. File filename Gunakan nama file sebagai program yang akan di-debugged. Ini dibaca untuk simbol dan untuk isi memori murni. Ini juga program dijalankan saat Anda menggunakan perintah run. If you do not specify a directory and the file is not found in the gdb working directory, gdb uses the environment variable PATH as a list of directories to search, just as the shell does when looking for a program to run. You can change the value of this variable, for both gdb and your program, using the path command. You can load unlinked object. o files into gdb using the file command. You will not be able to ldquorunrdquo an object file, but you can disassemble functions and inspect variables. Also, if the underlying BFD functionality supports it, you could use gdb - write to patch object files using this technique. Note that gdb can neither interpret nor modify relocations in this case, so branches and some initialized variables will appear to go to the wrong place. But this feature is still handy from time to time. file file with no argument makes gdb discard any information it has on both executable file and the symbol table. exec-file filename Specify that the program to be run (but not the symbol table) is found in filename. gdb searches the environment variable PATH if necessary to locate your program. Omitting filename means to discard information on the executable file. symbol-file filename Read symbol table information from file filename. PATH is searched when necessary. Use the file command to get both symbol table and program to run from the same file. symbol-file with no argument clears out gdb information on your programs symbol table. The symbol-file command causes gdb to forget the contents of some breakpoints and auto-display expressions. This is because they may contain pointers to the internal data recording symbols and data types, which are part of the old symbol table data being discarded inside gdb. symbol-file does not repeat if you press ltRETgt again after executing it once. When gdb is configured for a particular environment, it understands debugging information in whatever format is the standard generated for that environment you may use either a gnu compiler, or other compilers that adhere to the local conventions. Best results are usually obtained from gnu compilers for example, using gcc you can generate debugging information for optimized code. For most kinds of object files, with the exception of old SVR3 systems using COFF, the symbol-file command does not normally read the symbol table in full right away. Instead, it scans the symbol table quickly to find which source files and which symbols are present. The details are read later, one source file at a time, as they are needed. The purpose of this two-stage reading strategy is to make gdb start up faster. For the most part, it is invisible except for occasional pauses while the symbol table details for a particular source file are being read. (The set verbose command can turn these pauses into messages if desired. See Optional Warnings and Messages .) We have not implemented the two-stage strategy for COFF yet. When the symbol table is stored in COFF format, symbol-file reads the symbol table data in full right away. Note that ldquostabs-in-COFFrdquo still does the two-stage strategy, since the debug info is actually in stabs format. symbol-file - readnow filename file - readnow filename You can override the gdb two-stage strategy for reading symbol tables by using the lsquo - readnow rsquo option with any of the commands that load symbol table information, if you want to be sure gdb has the entire symbol table available. core-file filename core Specify the whereabouts of a core dump file to be used as the ldquocontents of memoryrdquo. Traditionally, core files contain only some parts of the address space of the process that generated them gdb can access the executable file itself for other parts. core-file with no argument specifies that no core file is to be used. Note that the core file is ignored when your program is actually running under gdb. So, if you have been running your program and you wish to debug a core file instead, you must kill the subprocess in which the program is running. To do this, use the kill command (see Killing the Child Process ). add-symbol-file filename address add-symbol-file filename address - readnow add-symbol-file filename address - s section address. The add-symbol-file command reads additional symbol table information from the file filename. You would use this command when filename has been dynamically loaded (by some other means) into the program that is running. The address should give the memory address at which the file has been loaded gdb cannot figure this out for itself. You can additionally specify an arbitrary number of lsquo - s section address rsquo pairs, to give an explicit section name and base address for that section. You can specify any address as an expression. The symbol table of the file filename is added to the symbol table originally read with the symbol-file command. You can use the add-symbol-file command any number of times the new symbol data thus read is kept in addition to the old. Changes can be reverted using the command remove-symbol-file. Although filename is typically a shared library file, an executable file, or some other object file which has been fully relocated for loading into a process, you can also load symbolic information from relocatable. o files, as long as: the files symbolic information refers only to linker symbols defined in that file, not to symbols defined by other object files, every section the files symbolic information refers to has actually been loaded into the inferior, as it appears in the file, and you can determine the address at which every section was loaded, and provide these to the add-symbol-file command. Some embedded operating systems, like Sun Chorus and VxWorks, can load relocatable files into an already running program such systems typically make the requirements above easy to meet. However, its important to recognize that many native systems use complex link procedures (.linkonce section factoring and C constructor table assembly, for example) that make the requirements difficult to meet. In general, one cannot assume that using add-symbol-file to read a relocatable object files symbolic information will have the same effect as linking the relocatable object file into the program in the normal way. add-symbol-file does not repeat if you press ltRETgt after using it. remove-symbol-file filename remove-symbol-file - a address Remove a symbol file added via the add-symbol-file command. The file to remove can be identified by its filename or by an address that lies within the boundaries of this symbol file in memory. Example: remove-symbol-file does not repeat if you press ltRETgt after using it. add-symbol-file-from-memory address Load symbols from the given address in a dynamically loaded object file whose image is mapped directly into the inferiors memory. For example, the Linux kernel maps a syscall DSO into each processs address space this DSO provides kernel-specific code for some system calls. The argument can be any expression whose evaluation yields the address of the files shared object file header. For this command to work, you must have used symbol-file or exec-file commands in advance. section section addr The section command changes the base address of the named section of the exec file to addr. This can be used if the exec file does not contain section addresses, (such as in the a. out format), or when the addresses specified in the file itself are wrong. Each section must be changed separately. The info files command, described below, lists all the sections and their addresses. info files info target info files and info target are synonymous both print the current target (see Specifying a Debugging Target ), including the names of the executable and core dump files currently in use by gdb. and the files from which symbols were loaded. The command help target lists all possible targets rather than current ones. maint info sections Another command that can give you extra information about program sections is maint info sections. In addition to the section information displayed by info files. this command displays the flags and file offset of each section in the executable and core dump files. In addition, maint info sections provides the following command options (which may be arbitrarily combined): ALLOBJ Display sections for all loaded object files, including shared libraries. sections Display info only for named sections. section-flags Display info only for sections for which section-flags are true. The section flags that gdb currently knows about are: ALLOC Section will have space allocated in the process when loaded. Set for all sections except those containing debug information. LOAD Section will be loaded from the file into the child process memory. Set for pre-initialized code and data, clear for. bss sections. RELOC Section needs to be relocated before loading. READONLY Section cannot be modified by the child process. CODE Section contains executable code only. DATA Section contains data only (no executable code). ROM Section will reside in ROM. CONSTRUCTOR Section contains data for constructordestructor lists. HASCONTENTS Section is not empty. NEVERLOAD An instruction to the linker to not output the section. COFFSHAREDLIBRARY A notification to the linker that the section contains COFF shared library information. ISCOMMON Section contains common symbols. set trust-readonly-sections on Tell gdb that readonly sections in your object file really are read-only (i. e. that their contents will not change). In that case, gdb can fetch values from these sections out of the object file, rather than from the target program. For some targets (notably embedded ones), this can be a significant enhancement to debugging performance. The default is off. set trust-readonly-sections off Tell gdb not to trust readonly sections. This means that the contents of the section might change while the program is running, and must therefore be fetched from the target when needed. show trust-readonly-sections Show the current setting of trusting readonly sections. All file-specifying commands allow both absolute and relative file names as arguments. gdb always converts the file name to an absolute file name and remembers it that way. gdb supports gnu Linux, MS-Windows, SunOS, DarwinMach-O, SVr4, IBM RS6000 AIX, QNX Neutrino, FDPIC (FR-V), and DSBT (TIC6X) shared libraries. On MS-Windows gdb must be linked with the Expat library to support shared libraries. See Expat. gdb automatically loads symbol definitions from shared libraries when you use the run command, or when you examine a core file. (Before you issue the run command, gdb does not understand references to a function in a shared library, howevermdashunless you are debugging a core file). There are times, however, when you may wish to not automatically load symbol definitions from shared libraries, such as when they are particularly large or there are many of them. To control the automatic loading of shared library symbols, use the commands: set auto-solib-add mode If mode is on. symbols from all shared object libraries will be loaded automatically when the inferior begins execution, you attach to an independently started inferior, or when the dynamic linker informs gdb that a new library has been loaded. If mode is off. symbols must be loaded manually, using the sharedlibrary command. The default value is on. If your program uses lots of shared libraries with debug info that takes large amounts of memory, you can decrease the gdb memory footprint by preventing it from automatically loading the symbols from shared libraries. To that end, type set auto-solib-add off before running the inferior, then load each library whose debug symbols you do need with sharedlibrary regexp. where regexp is a regular expression that matches the libraries whose symbols you want to be loaded. show auto-solib-add Display the current autoloading mode. To explicitly load shared library symbols, use the sharedlibrary command: info share regex info sharedlibrary regex Print the names of the shared libraries which are currently loaded that match regex. If regex is omitted then print all shared libraries that are loaded. info dll regex This is an alias of info sharedlibrary. sharedlibrary regex share regex Load shared object library symbols for files matching a Unix regular expression. As with files loaded automatically, it only loads shared libraries required by your program for a core file or after typing run. If regex is omitted all shared libraries required by your program are loaded. nosharedlibrary Unload all shared object library symbols. This discards all symbols that have been loaded from all shared libraries. Symbols from shared libraries that were loaded by explicit user requests are not discarded. Sometimes you may wish that gdb stops and gives you control when any of shared library events happen. The best way to do this is to use catch load and catch unload (see Set Catchpoints ). gdb also supports the the set stop-on-solib-events command for this. This command exists for historical reasons. It is less useful than setting a catchpoint, because it does not allow for conditions or commands as a catchpoint does. set stop-on-solib-events This command controls whether gdb should give you control when the dynamic linker notifies it about some shared library event. The most common event of interest is loading or unloading of a new shared library. show stop-on-solib-events Show whether gdb stops and gives you control when shared library events happen. Shared libraries are also supported in many cross or remote debugging configurations. gdb needs to have access to the targets libraries this can be accomplished either by providing copies of the libraries on the host system, or by asking gdb to automatically retrieve the libraries from the target. If copies of the target libraries are provided, they need to be the same as the target libraries, although the copies on the target can be stripped as long as the copies on the host are not. For remote debugging, you need to tell gdb where the target libraries are, so that it can load the correct copiesmdashotherwise, it may try to load the hosts libraries. gdb has two variables to specify the search directories for target libraries. set sysroot path Use path as the system root for the program being debugged. Any absolute shared library paths will be prefixed with path many runtime loaders store the absolute paths to the shared library in the target programs memory. When starting processes remotely, and when attaching to already-running processes (local or remote), their executable filenames will be prefixed with path if reported to gdb as absolute by the operating system. If you use set sysroot to find executables and shared libraries, they need to be laid out in the same way that they are on the target, with e. g. a bin. lib and usrlib hierarchy under path. If path starts with the sequence target: and the target system is remote then gdb will retrieve the target binaries from the remote system. This is only supported when using a remote target that supports the remote get command (see Sending files to a remote system ). The part of path following the initial target: (if present) is used as system root prefix on the remote file system. If path starts with the sequence remote: this is converted to the sequence target: by set sysroot 1. If you want to specify a local system root using a directory that happens to be named target: or remote. you need to use some equivalent variant of the name like. target. For targets with an MS-DOS based filesystem, such as MS-Windows and SymbianOS, gdb tries prefixing a few variants of the target absolute file name with path. But first, on Unix hosts, gdb converts all backslash directory separators into forward slashes, because the backslash is not a directory separator on Unix: Then, gdb attempts prefixing the target file name with path. and looks for the resulting file name in the host file system: If that does not find the binary, gdb tries removing the lsquo. rsquo character from the drive spec, both for convenience, and, for the case of the host file system not supporting file names with colons: This makes it possible to have a system root that mirrors a target with more than one drive. Misalnya. you may want to setup your local copies of the target system shared libraries like so (note lsquo c rsquo vs lsquo z rsquo): and point the system root at pathtosysroot. so that gdb can find the correct copies of both c:sysbinfoo. dll. and z:sysbinbar. dll. If that still does not find the binary, gdb tries removing the whole drive spec from the target file name: This last lookup makes it possible to not care about the drive name, if you dont want or need to. The set solib-absolute-prefix command is an alias for set sysroot. You can set the default system root by using the configure-time lsquo --with-sysroot rsquo option. If the system root is inside gdb s configured binary prefix (set with lsquo --prefix rsquo or lsquo --exec-prefix rsquo), then the default system root will be updated automatically if the installed gdb is moved to a new location. show sysroot Display the current executable and shared library prefix. set solib-search-path path If this variable is set, path is a colon-separated list of directories to search for shared libraries. lsquo solib-search-path rsquo is used after lsquo sysroot rsquo fails to locate the library, or if the path to the library is relative instead of absolute. If you want to use lsquo solib-search-path rsquo instead of lsquo sysroot rsquo, be sure to set lsquo sysroot rsquo to a nonexistent directory to prevent gdb from finding your hosts libraries. lsquo sysroot rsquo is preferred setting it to a nonexistent directory may interfere with automatic loading of shared library symbols. show solib-search-path Display the current shared library search path. set target-file-system-kind kind Set assumed file system kind for target reported file names. Shared library file names as reported by the target system may not make sense as is on the system gdb is running on. For example, when remote debugging a target that has MS-DOS based file system semantics, from a Unix host, the target may be reporting to gdb a list of loaded shared libraries with file names such as c:Windowskernel32.dll. On Unix hosts, theres no concept of drive letters, so the lsquo c: rsquo prefix is not normally understood as indicating an absolute file name, and neither is the backslash normally considered a directory separator character. In that case, the native file system would interpret this whole absolute file name as a relative file name with no directory components. This would make it impossible to point gdb at a copy of the remote targets shared libraries on the host using set sysroot. and impractical with set solib-search-path. Setting target-file-system-kind to dos-based tells gdb to interpret such file names similarly to how the target would, and to map them to file names valid on gdb s native file system semantics. The value of kind can be auto. in addition to one of the supported file system kinds. In that case, gdb tries to determine the appropriate file system variant based on the current targets operating system (see Configuring the Current ABI ). The supported file system settings are: unix Instruct gdb to assume the target file system is of Unix kind. Only file names starting the forward slash (lsquo rsquo) character are considered absolute, and the directory separator character is also the forward slash. dos-based Instruct gdb to assume the target file system is DOS based. File names starting with either a forward slash, or a drive letter followed by a colon (e. g. lsquo c: rsquo), are considered absolute, and both the slash (lsquo rsquo) and the backslash (lsquo rsquo) characters are considered directory separators. auto Instruct gdb to use the file system kind associated with the target operating system (see Configuring the Current ABI ). Ini adalah defaultnya. When processing file names provided by the user, gdb frequently needs to compare them to the file names recorded in the programs debug info. Normally, gdb compares just the base names of the files as strings, which is reasonably fast even for very large programs. (The base name of a file is the last portion of its name, after stripping all the leading directories.) This shortcut in comparison is based upon the assumption that files cannot have more than one base name. This is usually true, but references to files that use symlinks or similar filesystem facilities violate that assumption. If your program records files using such facilities, or if you provide file names to gdb using symlinks etc. you can set basenames-may-differ to true to instruct gdb to completely canonicalize each pair of file names it needs to compare. This will make file-name comparisons accurate, but at a price of a significant slowdown. set basenames-may-differ Set whether a source file may have multiple base names. show basenames-may-differ Show whether a source file may have multiple base names. 1 Historically the functionality to retrieve binaries from the remote system was provided by prefixing path with remote:GNU GDB Debugger Command Cheat Sheet Compile with the - g option (for most GNU and Intel compilers) which generates added information in the object code so the debugger can match a line of source code with the step of execution. Jangan menggunakan petunjuk pengoptimalan kompilator seperti - O atau - O2 yang mengatur ulang operasi komputasi untuk mendapatkan kecepatan karena penataan ulang ini tidak sesuai dengan urutan eksekusi dalam kode sumber dan mungkin tidak mungkin untuk mengikuti. Controlc: Hentikan eksekusi. Ini bisa menghentikan program di manapun, di sumber Anda atau perpustakaan C atau di mana saja. Untuk menjalankan perintah shell: perintah perintah perintah shell atau perintah GDB: Gunakan TAB key info bre TAB akan menyelesaikan perintah yang menghasilkan info breakpoints Tekan TAB dua kali untuk melihat semua opsi yang tersedia jika lebih dari satu pilihan tersedia atau ketik M-RETURN. GDB perintah abreviation: info bre RETURN akan bekerja sebagai bre adalah abreviation yang valid untuk breakpoints De-Referencing STL Containers: Menampilkan kelas kontainer STL menggunakan nama variabel GDB p menghasilkan tampilan definisi template dan pointer yang samar. Gunakan yang berikut. File gdbinit (V1.03 091508). Sekarang bekerja dengan GDB 4.3. (Versi yang diarsipkan: hanya V1.01 GDB 6.4) Terima kasih kepada Dr. Eng. Dan C. Marinescu atas izin untuk memposting naskah ini. Use the following commands provided by the script:
No comments:
Post a Comment