'Programming'에 해당되는 글 58건

  1. 2007.06.17 MBR(?) 출력 하기 2
  2. 2007.06.14 윈도우 메니져 설정 무시하고 윈도우 만들기 2
  3. 2007.05.25 Mpd 싱크 가사....... 프로그램 8
  4. 2007.04.09 pointer 를 call by referance 하기 6
  5. 2007.03.30 g_signal_connect의 폐해? 4

MBR(?) 출력 하기

 
 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <sys/types.h>
 4 #include <unistd.h>
 5 #include <sys/stat.h>
 6 #include <fcntl.h>
 7
 8 #define MBR_SIZE 51
2
 9
10 void print_title(void)
11 {
12     printf("OFFSET    0  1  2  3  4  5  6  7  8  9  "
13             "A  B  C  D  E  F     ASCII CODE\n");
14 }
15
16 void print_hex(unsigned char *data)
17 {
18     int i;
19
20     for(i = 0;i < 16;i ++)
21         printf("%02x ",data[i]);
22 }
23
24 void print_offset(int i)
25 {
26     printf("%08x  ",i);
27 }
28
29 void print_charecter(unsigned char *data)
30 {
31     int i;
32
33     for(i = 0;i < 16;i ++){
34         if(data[i] > 32 && data[i] < 127)
35             printf("%c",data[i]);
36         else
37             printf(".");
38     }
39 }
40
41 int main(int argc,char *argv[])
42 {
43     int fd,i;
44     unsigned char data_sav[MBR_SIZE];
45
46     if(argc !=
2){
47         printf("Usage : %s /dev/hda \n",argv[0]);
48         exit(0);
49     }
50
51     if((fd = open(argv[1],O_RDONLY)) == -1){
52         perror("파일디스크립터 열기 실패");
53         exit(1);
54     }
55
56     if(read(fd,data_sav,MBR_SIZE) == -1){
57         perror("장치 읽기 실패");
58         exit(1);
59     }
60
61     print_title();
62
63     for(i = 0;i < MBR_SIZE;i +=16){
64         print_offset(i);
65         print_hex(&data_sav[i]);
66         print_charecter(&data_sav[i]);
67         puts("");
68     }
69
70     close(fd);
71     return 0;
72 }

임베디드 계발자를 위한 파일시스템의 원리와 실습
이란 책에서 MBR을 보여주는 젤처음 예제(아마도) 를 리눅이용으로 변신시켜본것입니다..

의외로 별루 안어렵고 쉽게 끝냈네여....
중간에 unsinged를 안써서 값이 이상하게 나와서 약간 고생했지만..
다행이도 값들이 ffff들이 친절히 나와주었기 때문에 쉽게 고칠수 있었습니다
(사실 거의 안써서 (...) 바로 감은 안오더라고요)
슈퍼유저만 장치에 읽기에 가능하니까 해서 따로 루트인지 검사하고 에러메세지를 따로 낼까
하다가 귀차나서 (어짜피 열다가 에러 먹을테니까) 방치.

실은 여름방학때 파워손님이 스터디를 제안해서.. 그거 따라 갈려고(...........)
하는거.......................입니다...
물론 디바이스프로그래밍이나 커널프로그래밍이니 아는건 거의 없습니다만 ;;
해서 손해볼건 없다 싶어서..... 방학때 같이 하는것도 괜찮을거 같고...

사실 어제 이거에 관련되서 약간 물어봤더랍니다..
각 섹터에 있는 값들을 어떻게 읽어 내느냐... 이렇게요..
그리고 책에서는 winapi로 하는데 리눅스에서는 어떻게.. 함수가 있나.. 이런식으로요
저는 뭐 어셈블러써서 어떻게 접근이 안될까 생각했는데
간단하게 대답해주시더군요

"그냥 /dev/hda 같은식으로 읽으면,........."

아!! 그랬죠,... 리눅스(유닉스계열) 은 시스템 장치들도 다 파일 처럼 사용하는 거였지 (.......;; )

그거 딱 생각하고서 그냥 만든겁니다..

잘 보시면 아시겠지만
핵심은 그냥 파일 읽는거랑 별반 다를거 없다는거.....

아마 저 크기가 아닐거 같은데... 뭐 대충 찍어요...
어짜피 숫자만 바꿔주면 되는데뭘...

'Programming > System' 카테고리의 다른 글

부트섹터에서 프로그램 실행시키기.  (14) 2007.07.21
압축플때 쓰는 쉘 스크립트  (4) 2007.06.18
screen attach dettach 구별법  (2) 2007.02.12
Beginning Linux Programming Part6-Curses  (2) 2006.06.25
ls -al  (0) 2006.06.21

윈도우 메니져 설정 무시하고 윈도우 만들기

 if(term_cfg -> all_workspace_view == TRUE)
       //모든 워크스페이스에 출력
        gtk_window_stick(GTK_WINDOW(term_widget -> window));

    if(term_cfg -> taskbar_view == FALSE)   //default TRUE
        //테스크바에 안보이게 하기
        gtk_window_set_skip_taskbar_hint(GTK_WINDOW(term_widget -> window), TRUE); 

    if(term_cfg -> layer == 1) 
        gtk_window_set_keep_above(GTK_WINDOW(term_widget -> window), TRUE);         //최상위 윈도우로 만들기 (단 윈도 매니져가 우선)
    else if(term_cfg -> layer==0){
        /* gdk_window_lower,gdk_window_set_override_redirect 함수와
         * gtk_window_new 함수 연결 같은거.. 하려고;;
         * (window -> window 내용 채우기 위해서 ㅋ*/
        gtk_widget_realize(term_widget -> window);
        if(term_widget -> window -> window == NULL){
            puts("NULL!!!");
            exit(1);
        }  

        //윈도우 메니져의 설정을 무시한닷!!!
        gdk_window_set_override_redirect(term_widget ->window ->window,TRUE);
           
        //윈도우를 최하위로 만든담에 (이거 안되는데; )
        //gdk_window_lower(term_widget -> window -> window);
    }  

kldp에다가 질문을 올렸었는데 뭐 갈켜주는 사람도 없고 해서 어쩔수 없이 혼자 찾은
구글링 해서 찾았는데.......
역시 제일 나은건 man페이지라는거.........
------------------------------------------------------------
기억 보존을 위해서 적어둠...

'Programming > GTK+' 카테고리의 다른 글

gtk할떄는 gtk_init의 인자를 제대로 넣자.  (2) 2010.08.06
외부 Thread에서 GTK 위젯 제어할시 동기화 문제 해결  (5) 2010.07.30
g_signal_connect의 폐해?  (4) 2007.03.30
xlib 에러 해결!  (2) 2007.02.28
gtk Thread  (2) 2007.02.27

Mpd 싱크 가사....... 프로그램

이딴거 올려봤자 별루 보는사람도 얼마 없겠지만뭐.........

두번째 프로젝트(?) 인 주2>MPD 용 싱크가사 프로그램을 대충~ 완성했다.........

일단 되는 기능은 잘 된다.... 내부적으로 고칠건 좀 있는데....... 안그래도 잘 작동하는데 고치기는

귀찮고 해서 현재 놀면서 방치중~~~ 귀차나~ 귀차나~ 어디 딴짓이나 해볼까~ 하고 있는.............

이거에 대해서 간단히 설명하자면 원래 랜덤여신님이 만든 주3>amarok-live-lyrics

가 있는데.. 그 프로그램에 서버로부터 가져오는 주소값만 살짝 내 프로그램으로 받게 해서 만든것!

사실 "구태여 이렇게 따로 프로그램을 만들지 않더라도"

저 amarok-live-lyrics의 내용만 약간 바꾸면 (주4>dcop 대신 주5>mpc를 써서 한다던가............)

mpd용으로 사용할수 있건만............ 만들어본,........

주6> conky에서 주7>파이썬 안써보고 프로그램 만들어보려고요...

 또.......어짜피 배우는 입장이기도 하고........ ,c언어 예/복습도 할겸................ )

대략 프로그램 구조가......

mp3파일을 읽어 망할놈의 태그 를 건너뛴 만큼 읽는 위치를 이동한다

-> 일정부분을 읽어서 md5 Hash(?) 한다

-> md5한 값을 바로슬 서버의 주소와 합쳐서  -> 주8>소켓써서 서버로부터 페이지를 받아온다

-> 새로운 가사 파일에 그 내용을 저장한다 -> 저장한 내용을 불러와서 메모리에 저장

-> 가사/시간 분리 -> 링크드리스트로 정리 -> 타이머써서 -> (시간에 맞춰) 출력하기.....

-> 에러있음 break -> 그리고 쭉~ 반복~.

아직 주9>터미널 전용(!) 프로그램이라 사용자 인터페이스는 정말 할말이 없다

(이부분에서만 보면 완존 쓰레기다 ; 그래서 주10>공개를 못하겠어용 ㅜ)

아직은 계획이 없지만... 뭐 필요하면 Gtk용 프로글햄으로 바꿀 생각도 있긴한데 귀차나서...

하지만! amarok-live-lyrics 보다 좋은건 딱 하나있다...... 주11> mutagen

을 쓰지않고 자체적으로 mp3파일을 분석해서 태그를 무시하기때문에.. 싱크가사 인식성공률이

amarok-live-lyrics보다 높다..........는거 정도...

(amarok-live-lyrics는 서버에 가사가 있는데도 불구하고 태그위치를 제대로  감지를 못해서

md5값을  잘못얻어오는 경우가 몇몇 mp3파일에서 발견되었었다........

모르겠다 요즘에 버젼업 되어서 고쳐졌는지...... )

주1>지워졌다 ㅋㅋ.

주2>MPD : Music Player Demon 일겁니다.. 내기억으로는.. 데몬이기때문에 재부팅을하거나
일부로 종료시키지 않은한 음악이 멈추질 않죠! 저는 가끔씩 X 를 재시작하는데 그때 음악이 끈겨서
참 안타까웠던차 이프로그램을 jazzbug님의 추천으로 사용하게 되었죠.......
괜찮네요.. 좋아요...근데 지원되는 파일 포맷이 mp3,ogg정도 밖에 없는게 단점..
망할 wma는 재생이 안돼ㅜㅜㅜㅜㅜㅜ

주3>amarok-live-lyrics 
랜덤여신님이 만든 live-lyrics 다음 링크를 참조해주세요.
http://barosl.com/blog/entry/amarok-live-lyrics

주4>dcop :amarok이 이거 쓰던데...... 이거쓰면 amarok이 플레이중인 시간,전체시간,곡이름등을 알수 있다
dcop amarok default 뭐시기.. 이런식으로 썻던거 같은데.. 지금 amarok을 실행시키고 있다면 함
해보시길어플의 상태를 알수 있게 해주는 뭐 그런 녀석인가부다......... 더이상은 모르겠삼..
gtk어플(?) 쪽에도 이런게 있던거 같긴함.

주5>mpc : Music Player Client 인가.. 그래요..

주7> conky
에서 주8>파이썬(python) 이가 메모리 젤많이 먹는거 보면 기분이 상당이 뭐하다(?) 그래서 파이썬
안쓰고 만들려다보니......

주8>소켓 : 이녀석도 기억이 안나서 혼자서 만들다가 몰라서 걍 소스 보고 몇줄 복사붙여넣기 했어요 ㅜㅜ

주9>터미널 전용(!) 프로그램 : 아시려나 모르겠지만 본인은 터미널 프로그램을 매우 사랑! 스러워한다..

주10>공개를 못하겠어용 ㅜ
그리고 우리나라에서 MPD를 쓰는 사람이 몇이나되겠으며( 아니 아는 사람이나 몇이나 될까! )
, 호좁한 인터페이스를 가진 이 터미널 프로그램을 쓸사람은 몇이나 되겠으며......
그래서 공개를 못하겠어욤...

주11> mutagen
파이썬 라이브러리라...물론 이 플그램은 C언어니까 쓸수 없기도 했고 또 c언어용 태그 라이브러리(id3lib인가?)가 존재는 하나 파일을 복사해놓고 거기서 다시 태그를 읽어오고 해야했기 때문에 비효울적인거 같기도 하고(mutagen을 쓴 amarok-live-lyrics도 그렇다..) 
사실 뻘짓할 시간이 아까우니 원래 이런 라이브러리를 쓰는게 이익이겠지만...
공부도 함 해볼겸해서  걍 내가 뻘짓해가면서 만듦

pointer 를 call by referance 하기

  1 #include<stdio.h>
  2 #include<malloc.h>
  3
  4 struct choco
  5 {
  6     int a;
  7     int b;
  8     int c;
  9 };
 10
 11 void me(struct choco* *fk)  //main에서 void(?) 넘긴걸 "struct choco *" 형으로 받는다
 12 {
 13     struct choco *abc;
 14     int i;
 15
 16     printf("func call value : %p\n",*fk);
 17     printf("func call momory address : %p \n",fk);
 18      //이 함수가 끝나더라고 malloc의 메모리는 해제되지 않는다..
 19     abc=(struct choco *)malloc(sizeof(struct choco)*3);
 20
 21     abc[0].a=1;
 22     abc[0].b=2;
 23     abc[0].c=3;
 24
 25     abc[1].a=11;
 26     abc[1].b=22;
 27     abc[1].c=33;
 28
 29     abc[2].a=111;
 30     abc[2].b=222;
 31     abc[2].c=333;
 32
 33     for(i=0;i<3;i++)
 34         printf("func pointer memory (struct) value %d : %d %d %d \n",i,abc[i].a,abc[i].b,abc[i].c);
 35
 36     puts("\n");
 37   
 38     *fk=abc; //이게좀 했갈렸다..
 39 }
 40
 41 int main(void)
 42 {
 43     struct choco *po;
 44     int i;
 45
 46     po=NULL;
 47
 48     printf("Before pointer value : %p \n",po);
 49     printf("Before pointer memory address : %p\n",&po);
 50     puts("\n");
 51    
 52     me(&po);    // void로 값을 넘긴다
 53    
 54     printf("After pointer value : %p \n",po); //요값은 아까 struct choco  *abc의 값!
 55
 56     for(i=0;i<3;i++) //당연히 free되지 않았으므로.. .가능 .. 값을 뿌려줌..
 57         printf("After pointer memory (struct) value %d : %d %d %d \n",i,po[i].a,po[i].b,po[i].c);
 58     puts("\n");
 59
 60     //free가 제대로 앙대 ㅜㅜ(일단 패스)
 61     free(po);
 62
 63     return 0;
 64 }

결과
Before pointer value : (nil)
Before pointer memory address : 0xbff28ac8


func call value : (nil)
func call momory address : 0xbff28ac8
func pointer memory (struct) value 0 : 1 2 3
func pointer memory (struct) value 1 : 11 22 33
func pointer memory (struct) value 2 : 111 222 333


After pointer value : 0x804a008
After pointer memory (struct) value 0 : 1 2 3
After pointer memory (struct) value 1 : 11 22 33
After pointer memory (struct) value 2 : 111 222 333



:cw
Press ENTER or type command to continue

더 간단 버전.. 즉 앞에한짓은 뻘짓이라는게 증명됨(??)
  1 #include<stdio.h>
  2 #include<malloc.h>
  3
  4 truct choco
  5 {
  6     int a;
  7     int b;
  8     int c;
  9 }; 
 10
 11 struct choco* me(void)
 12 {
 13     struct choco *abc;
 14     int i;
 15    
 16     abc=(struct choco *)malloc(sizeof(struct choco)*3);
 17    
 18     abc[0].a=1;
 19     abc[0].b=2;
 20     abc[0].c=3;
 21    
 22     abc[1].a=11;
 23     abc[1].b=22;
 24     abc[1].c=33;
 25
 26     abc[2].a=111;
 27     abc[2].b=222;
 28     abc[2].c=333;
 29
 30     for(i=0;i<3;i++)
 31         printf("func pointer memory (struct) value %d : %d %d %d \n",i,abc[i].a,abc[i].b,abc[i].c);
 32        
 33     puts("\n");
 34   
 35     return abc;
 36 }  
 37
 38 int main(void)
 39 {
 40     struct choco *po;
 41     int i;
 42    
 43     po=NULL;
 44    
 45     printf("Before pointer value : %p \n",po);
 46     printf("Before pointer memory address : %p\n",&po);
 47     puts("\n");
 48    
 49     po=me();
 50    
 51     printf("After pointer value : %p \n",po);
 52    
 53     for(i=0;i<3;i++)
 54         printf("After pointer memory (struct) value %d : %d %d %d \n",i,po[i].a,po[i].b,po[i].c);
 55     puts("\n");
 56    
 57     free(po);
 58 }  

어짜피 malloc은 static과 같이 값이 유지되므로 결론적으로
"값만 받아내면 된다" 그래서 사용하는것도 같이 사용..

내가 free를 많이 안해봐서 몰랐는데
구조체 포인터라고 할지라도 그냥 free하고 포인터네임만 쓰면 되는거 같다(위엔,1차원이므로)
그런데 신기하게도(?) free한다음 for문을 돌려서 안에 내용을 확인하면 포인터 네임 위치만 NULL
이 되어있고 나머지 값들은 다 유지한 상태로 되있다 -_-;
딴 프로그램에서도 이런식으로  free를 했길래 위에 free방법이 틀리지 않은거 같은데..
값은 아니네.. 이상함..;;

4,19일 수정

g_signal_connect의 폐해?

왜그런진 모르겠으나..

이상하게 gtk  signal을 연결해줄때 쓰는 함수

g_signal_connect 힘수 (또는 그 외에도 많지만은..)

이상하게 인자를 하나만 받아들이게 되어있어서

결국엔 구조체를 만든다음 한꺼번에 인자하나로 넘겨줄수 밖에 없는데

그러다보니...

/*header*/
59 struct st_quit
60 {
61     GtkWidget *window;
62     GtkWidget *terminal;
63     int terminal_number;
64     int *S_term;
65 };

/*main*/
 25     static struct st_quit Quit_Data[TERM_LIMIT];
30     static int terminal_onoff[TERM_LIMIT];  
51     Quit_Data[terminal_num].S_term=terminal_onoff;

/*func*/
  8     //혹시 함수 잘못 불러올까봐서 ...;                                                                
  9     if(G_st->S_term[G_st->terminal_number]==ON){                                               
 10         //받은 위젯 파괴, 그리고 플래그 OFF시킴
 11         gtk_widget_destroy(G_st->window);
 12         G_st->S_term[G_st->terminal_number]=OFF;    
 13     } 
                          
if(G_st->S_term[G_st->terminal_number]==ON)
라는 복잡한놈으로 변한다..

와 gtk 함수들은(일부?) 는 인자를 여러게 받게 안만들어 놨을까..?

(함수의 갯수가 유한하지만(8개였나??) 그래도 좀 많이 만들어 놓지 불편하잖아..)

이거...한 한달만 안보고 있다가 이거 보면 과연 내가 짜논거 제대로 이해나 할수 있을런지 모르겠다 -_-a

뭐 어쩔수 업지멀.. 호좁이라 이정도 밖에 머리를 못쓰겠는걸,.
(그렇다고 전역변수 쓰기도 그렇고........).
prev 1 ··· 6 7 8 9 10 11 12 next