nkeynes@2 | 1 | #include <stdint.h>
|
nkeynes@2 | 2 | #include <gnome.h>
|
nkeynes@2 | 3 | #include "interface.h"
|
nkeynes@2 | 4 | #include "gui.h"
|
nkeynes@2 | 5 | #include "mem.h"
|
nkeynes@2 | 6 | #include "mmio.h"
|
nkeynes@2 | 7 |
|
nkeynes@2 | 8 | GtkWidget *mmr_win;
|
nkeynes@2 | 9 | GtkNotebook *mmr_book;
|
nkeynes@2 | 10 |
|
nkeynes@2 | 11 | static void printbits( char *out, int nbits, uint32_t value )
|
nkeynes@2 | 12 | {
|
nkeynes@2 | 13 | if( nbits < 32 ) {
|
nkeynes@2 | 14 | int i;
|
nkeynes@2 | 15 | for( i=32; i>nbits; i-- ) {
|
nkeynes@2 | 16 | if( !(i % 8) ) *out++ = ' ';
|
nkeynes@2 | 17 | *out++ = ' ';
|
nkeynes@2 | 18 | }
|
nkeynes@2 | 19 | }
|
nkeynes@2 | 20 | while( nbits > 0 ) {
|
nkeynes@2 | 21 | *out++ = (value&(1<<--nbits) ? '1' : '0');
|
nkeynes@2 | 22 | if( !(nbits % 8) ) *out++ = ' ';
|
nkeynes@2 | 23 | }
|
nkeynes@2 | 24 | *out = '\0';
|
nkeynes@2 | 25 | }
|
nkeynes@2 | 26 |
|
nkeynes@2 | 27 | static void printhex( char *out, int nbits, uint32_t value )
|
nkeynes@2 | 28 | {
|
nkeynes@2 | 29 | char tmp[10], *p = tmp;
|
nkeynes@2 | 30 | int i;
|
nkeynes@2 | 31 |
|
nkeynes@2 | 32 | sprintf( tmp, "%08X", value );
|
nkeynes@2 | 33 | for( i=32; i>0; i-=4, p++ ) {
|
nkeynes@2 | 34 | if( i <= nbits ) *out++ = *p;
|
nkeynes@2 | 35 | else *out++ = ' ';
|
nkeynes@2 | 36 | }
|
nkeynes@2 | 37 | *out = '\0';
|
nkeynes@2 | 38 | }
|
nkeynes@2 | 39 |
|
nkeynes@2 | 40 |
|
nkeynes@2 | 41 | static GtkCList *create_mmr_page( char *name )
|
nkeynes@2 | 42 | {
|
nkeynes@2 | 43 | GtkCList *list;
|
nkeynes@2 | 44 | GtkWidget *scroll;
|
nkeynes@2 | 45 | GtkWidget *tab;
|
nkeynes@2 | 46 |
|
nkeynes@2 | 47 | scroll = gtk_scrolled_window_new(NULL, NULL);
|
nkeynes@2 | 48 | gtk_widget_show( scroll );
|
nkeynes@2 | 49 | gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW(scroll),
|
nkeynes@2 | 50 | GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS );
|
nkeynes@2 | 51 | list = GTK_CLIST(gtk_clist_new(5));
|
nkeynes@2 | 52 | gtk_clist_set_column_width(list, 0, 60);
|
nkeynes@2 | 53 | gtk_clist_set_column_width(list, 1, 50);
|
nkeynes@2 | 54 | gtk_clist_set_column_width(list, 2, 60);
|
nkeynes@2 | 55 | gtk_clist_set_column_width(list, 3, 220);
|
nkeynes@2 | 56 | gtk_clist_set_column_width(list, 4, 160);
|
nkeynes@2 | 57 | gtk_clist_set_column_justification(list, 0, GTK_JUSTIFY_CENTER );
|
nkeynes@2 | 58 | gtk_clist_set_column_justification(list, 2, GTK_JUSTIFY_CENTER );
|
nkeynes@2 | 59 | gtk_clist_set_column_justification(list, 3, GTK_JUSTIFY_CENTER );
|
nkeynes@2 | 60 | gtk_clist_set_column_title(list, 0, "Address");
|
nkeynes@2 | 61 | gtk_clist_set_column_title(list, 1, "Register");
|
nkeynes@2 | 62 | gtk_clist_set_column_title(list, 2, "Value");
|
nkeynes@2 | 63 | gtk_clist_set_column_title(list, 3, "Bit Pattern");
|
nkeynes@2 | 64 | gtk_clist_set_column_title(list, 4, "Description");
|
nkeynes@2 | 65 | gtk_clist_column_titles_show(list);
|
nkeynes@2 | 66 | gtk_widget_modify_font( GTK_WIDGET(list), fixed_list_font );
|
nkeynes@2 | 67 | gtk_widget_show( GTK_WIDGET(list) );
|
nkeynes@2 | 68 | tab = gtk_label_new(_(name));
|
nkeynes@2 | 69 | gtk_widget_show( tab );
|
nkeynes@2 | 70 | gtk_container_add( GTK_CONTAINER(scroll), GTK_WIDGET(list) );
|
nkeynes@2 | 71 | gtk_notebook_append_page( mmr_book, scroll, tab );
|
nkeynes@2 | 72 | gtk_object_set_data( GTK_OBJECT(mmr_win), name, list );
|
nkeynes@2 | 73 | return list;
|
nkeynes@2 | 74 | }
|
nkeynes@2 | 75 |
|
nkeynes@2 | 76 | void update_mmr_win( void )
|
nkeynes@2 | 77 | {
|
nkeynes@2 | 78 | int i,j, count = 0;
|
nkeynes@2 | 79 | GtkCList *page, *all_page;
|
nkeynes@2 | 80 | char data[10], bits[40];
|
nkeynes@2 | 81 |
|
nkeynes@2 | 82 | all_page = GTK_CLIST(gtk_object_get_data( GTK_OBJECT(mmr_win), "All" ));
|
nkeynes@2 | 83 |
|
nkeynes@2 | 84 | for( i=1; i < num_io_rgns; i++ ) {
|
nkeynes@2 | 85 | page = GTK_CLIST(gtk_object_get_data( GTK_OBJECT(mmr_win),
|
nkeynes@2 | 86 | io_rgn[i]->id ));
|
nkeynes@2 | 87 | for( j=0; io_rgn[i]->ports[j].id != NULL; j++ ) {
|
nkeynes@2 | 88 | if( *io_rgn[i]->ports[j].val !=
|
nkeynes@2 | 89 | *(uint32_t *)(io_rgn[i]->save_mem+io_rgn[i]->ports[j].offset)){
|
nkeynes@2 | 90 | int sz = io_rgn[i]->ports[j].width;
|
nkeynes@2 | 91 | /* Changed */
|
nkeynes@2 | 92 | printhex( data, sz, *io_rgn[i]->ports[j].val );
|
nkeynes@2 | 93 | printbits( bits, sz, *io_rgn[i]->ports[j].val );
|
nkeynes@2 | 94 |
|
nkeynes@2 | 95 | gtk_clist_set_text( page, j, 2, data );
|
nkeynes@2 | 96 | gtk_clist_set_text( page, j, 3, bits );
|
nkeynes@2 | 97 | gtk_clist_set_foreground( page, j, &clrChanged );
|
nkeynes@2 | 98 |
|
nkeynes@2 | 99 | gtk_clist_set_text( all_page, count, 2, data );
|
nkeynes@2 | 100 | gtk_clist_set_text( all_page, count, 3, bits );
|
nkeynes@2 | 101 | gtk_clist_set_foreground( all_page, count, &clrChanged );
|
nkeynes@2 | 102 |
|
nkeynes@2 | 103 | } else {
|
nkeynes@2 | 104 | gtk_clist_set_foreground( page, j, &clrNormal );
|
nkeynes@2 | 105 | gtk_clist_set_foreground( all_page, count, &clrNormal );
|
nkeynes@2 | 106 | }
|
nkeynes@2 | 107 | count++;
|
nkeynes@2 | 108 | }
|
nkeynes@2 | 109 | memcpy( io_rgn[i]->save_mem, io_rgn[i]->mem, PAGE_SIZE );
|
nkeynes@2 | 110 | }
|
nkeynes@2 | 111 | }
|
nkeynes@2 | 112 |
|
nkeynes@2 | 113 | void init_mmr_win( void )
|
nkeynes@2 | 114 | {
|
nkeynes@2 | 115 | int i, j;
|
nkeynes@2 | 116 | GtkCList *all_list;
|
nkeynes@2 | 117 | mmr_win = create_mmr_win();
|
nkeynes@2 | 118 | mmr_book = GTK_NOTEBOOK( gtk_object_get_data( GTK_OBJECT(mmr_win), "mmr_notebook" ));
|
nkeynes@2 | 119 |
|
nkeynes@2 | 120 | /* kill the dummy page glade insists on adding */
|
nkeynes@2 | 121 | gtk_notebook_remove_page( mmr_book, 0 );
|
nkeynes@2 | 122 |
|
nkeynes@2 | 123 | all_list = create_mmr_page( "All" );
|
nkeynes@2 | 124 | for( i=1; i < num_io_rgns; i++ ) {
|
nkeynes@2 | 125 | GtkCList *list = create_mmr_page( io_rgn[i]->id );
|
nkeynes@2 | 126 |
|
nkeynes@2 | 127 | for( j=0; io_rgn[i]->ports[j].id != NULL; j++ ) {
|
nkeynes@2 | 128 | int sz = io_rgn[i]->ports[j].width;
|
nkeynes@2 | 129 | char addr[10], data[10], bits[40];
|
nkeynes@2 | 130 | char *arr[] = { addr, io_rgn[i]->ports[j].id, data, bits,
|
nkeynes@2 | 131 | io_rgn[i]->ports[j].desc };
|
nkeynes@2 | 132 | sprintf( addr, "%08X",
|
nkeynes@2 | 133 | io_rgn[i]->base + io_rgn[i]->ports[j].offset );
|
nkeynes@2 | 134 | printhex( data, sz, *io_rgn[i]->ports[j].val );
|
nkeynes@2 | 135 | printbits( bits, io_rgn[i]->ports[j].width,
|
nkeynes@2 | 136 | *io_rgn[i]->ports[j].val );
|
nkeynes@2 | 137 | gtk_clist_append( list, arr );
|
nkeynes@2 | 138 | gtk_clist_append( all_list, arr );
|
nkeynes@2 | 139 | }
|
nkeynes@2 | 140 | }
|
nkeynes@2 | 141 | }
|
nkeynes@2 | 142 |
|
nkeynes@2 | 143 | void mmr_open_win( void )
|
nkeynes@2 | 144 | {
|
nkeynes@2 | 145 | gtk_widget_show( mmr_win );
|
nkeynes@2 | 146 | }
|
nkeynes@2 | 147 |
|
nkeynes@2 | 148 | void mmr_close_win( void )
|
nkeynes@2 | 149 | {
|
nkeynes@2 | 150 | gtk_widget_hide( mmr_win );
|
nkeynes@2 | 151 | }
|