KR20150141073A - 데이터 처리 방법 및 전자 장치 - Google Patents
데이터 처리 방법 및 전자 장치 Download PDFInfo
- Publication number
- KR20150141073A KR20150141073A KR1020140069617A KR20140069617A KR20150141073A KR 20150141073 A KR20150141073 A KR 20150141073A KR 1020140069617 A KR1020140069617 A KR 1020140069617A KR 20140069617 A KR20140069617 A KR 20140069617A KR 20150141073 A KR20150141073 A KR 20150141073A
- Authority
- KR
- South Korea
- Prior art keywords
- file
- data
- data processing
- size
- processing module
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/17—Details of further file system functions
- G06F16/178—Techniques for file synchronisation in file systems
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
다양한 실시 예에 따르면, 장치 운용에 따른 파일을 메모리에 저장하는 동작, 상기 메모리에 저장된 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드 또는 오더 모드 중 어느 하나로 결정하여 상기 파일을 스토리지에 저장 처리하는 동작을 포함하는 데이터 처리 방법 및 전자 장치를 개시한다. 또한 본 발명은 다른 다양한 실시예도 가능하다.
Description
다양한 실시 예는 데이터 처리에 관한 것이다.
스마트 폰(Smart Phone) 및 태블릿(Tablet) 등의 전자 기기는 여러 가지 다양한 애플리케이션들을 통해 사용자에게 여러 가지 유용한 기능을 제공하고 있다. 이러한 전자 기기는 기능 수행에 따라 다양한 데이터를 생성하거나 갱신할 수 있다.
생성된 데이터 또는 갱신된 데이터는 상황에 따라 실시간으로 화면에 적용되거나 또는 메모리에 저장될 수 있다. 그런데, 데이터의 크기가 큰 경우에는 메모리에 저장하는데 지연 시간이 발생할 수 있다. 따라서, 사용자는 전자 기기를 이용하는 중에 데이터 저장 처리에 따른 지연을 감수해야 하는 문제가 있다. 예컨대, 사용자 입력을 받아서 화면 처리를 수행하는 프로세스는 저장장치에서 데이터를 읽거나 신규 생성 및 갱신 작업을 수행하며, 이는 포그라운드(foreground) 작업으로 정의된다. 파일 탐색기를 통한 대용량 파일 복사나 웹 브라우저에서 파일을 다운로드 받을 경우는 화면 처리와는 무관하게 백그라운드(Background) 작업으로 실행된다. 통상적으로 저널링 파일 시스템은 트랜잭션 (Transaction) 단위로 파일을 저장하며, 따라서 포그라운드 작업에서 생성한 파일과 백그라운드의 대용량 파일 업데이트가 동일 트랜잭션을 통해 저장될 경우 포그라운드 작업이 지연이 발생할 수 있다.
따라서, 다양한 실시 예는 데이터 저장 처리에 따른 지연을 최소화할 수 있는 데이터 처리 방법 및 전자 장치를 제공한다.
또한, 다양한 실시 예는 데이터 저장 처리의 지연을 최소화하면서 저장된 데이터의 무결성을 일정 수준으로 제공할 수 있는 데이터 처리 방법 및 전자 장치를 제공한다.
다양한 실시 예에 따르면, 한 실시 예에 따른 전자 장치는 장치 운용에 따른 파일을 저장하는 메모리, 상기 메모리에 저장된 파일의 저널링을 지원하는 스토리지, 상기 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드 또는 오더 모드 중 어느 하나의 모드로 처리하는 데이터 처리 모듈을 포함할 수 있다.
한 실시 예에 따른 데이터 처리 방법은 장치 운용에 따른 파일을 메모리에 저장하는 동작, 상기 메모리에 저장된 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드(writeback mode) 또는 오더 모드(ordered mode) 중 어느 하나로 결정하여 상기 파일을 스토리지에 저장 처리하는 동작을 포함할 수 있다. 기입 모드 저널링은 파일시스템 메타데이터를 저널에 트랜잭션 단위로 커밋(commit) 하며, 커밋 완료 시점에 파일의 데이터 블록 업데이트 완료를 대기하지 않는 방식이다. 따라서, 파일 메타데이터와 데이터 블록간 정합성 (consistency)을 보장하지 않지만 빠른 커밋이 가능하다. 오더 모드 저널링 방식은 기입 모드처럼 메타데이터를 트랜잭션 단위로 커밋하며 트랜잭션에 포함된 파일 데이터 블록의 업데이트 완료를 대기한다. 따라서, 파일 메타데이터와 데이터 블록간 정합성 (consistency)를 보장하므로 대부분의 저널링 파일시스템에서 기본(default) 모드로 사용되는 방식이다.
한 실시 예에 따른 컴퓨터 기록 매체는 프로그래밍 모듈의 형태로 컴퓨터로 읽을 수 있는 저장매체(computer-readable storage media)에 저장된 명령어로서, 상기 명령어는, 장치 운용에 따른 파일을 메모리에 저장하는 동작, 상기 메모리에 저장된 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드 또는 오더 모드 중 어느 하나로 결정하여 상기 파일을 스토리지에 저장 처리하는 동작을 포함할 수 있다.
다양한 실시 예에서 개시되는 데이터 처리를 위한 방법 및 전자 장치는 데이터 저장 처리에 따른 지연을 최소화할 수 있다.
또한, 다양한 실시 예는 데이터 저장 처리에 따른 지연은 최소화하면서 데이터의 무결성을 일정 수준으로 제공하여, 전자 장치의 특정 상황(예: 배터리 분리 또는 배터리 전압 저하로 인한 전자 장치 턴-오프 상황)에서도 일정 수준의 데이터 복구를 가능하게 할 수 있다.
또한, 다양한 실시 예는 어플리케이션 기능 수행에서 데이터 속성(예: 저장과 관련한 데이터 또는 화면 갱신과 관련한 데이터) 처리를 적응적으로 수행하여 화면 지연을 최소화할 수 있다.
도 1은 다양한 실시 예에 따른 데이터 저장을 수행하는 전자 장치 관련 시스템을 도시한다.
도 2는 다양한 실시 예에 따른 스토리지와 메모리를 도시한다.
도 3은 다양한 실시 예에 따른 전자 장치의 데이터 처리 모듈을 도시한다.
도 4는 다양한 실시 예에 따른 데이터 처리 방법을 도시한다.
도 5는 다양한 실시 예에 따른 데이터 처리 방법 중 어플리케이션 실행 상태에 따른 데이터 처리를 도시한다.
도 6은 다양한 실시 예에 따른 데이터 처리 방법 중 파일 크기에 따른 처리를 도시한다.
도 7은 다양한 실시 예에 따른 데이터 저장 처리와 관련한 전자 장치의 인터페이스를 도시한다.
도 8은 다양한 실시 예에 따른 전자 장치의 블록도이다.
도 2는 다양한 실시 예에 따른 스토리지와 메모리를 도시한다.
도 3은 다양한 실시 예에 따른 전자 장치의 데이터 처리 모듈을 도시한다.
도 4는 다양한 실시 예에 따른 데이터 처리 방법을 도시한다.
도 5는 다양한 실시 예에 따른 데이터 처리 방법 중 어플리케이션 실행 상태에 따른 데이터 처리를 도시한다.
도 6은 다양한 실시 예에 따른 데이터 처리 방법 중 파일 크기에 따른 처리를 도시한다.
도 7은 다양한 실시 예에 따른 데이터 저장 처리와 관련한 전자 장치의 인터페이스를 도시한다.
도 8은 다양한 실시 예에 따른 전자 장치의 블록도이다.
이하, 본 발명의 다양한 실시 예가 첨부된 도면과 연관되어 기재된다. 본 발명의 다양한 실시 예는 다양한 변경을 가할 수 있고 여러 가지 실시 예를 가질 수 있는바, 특정 실시 예들이 도면에 예시되고 관련된 상세한 설명이 기재되어 있다. 그러나 이는 본 발명의 다양한 실시 예를 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 발명의 다양한 실시 예의 사상 및 기술 범위에 포함되는 모든 변경 및/또는 균등물 내지 대체물을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 구성요소에 대해서는 유사한 참조 부호가 사용되었다.
본 발명의 다양한 실시 예 가운데 사용될 수 있는 "포함한다" 또는 "포함할 수 있다" 등의 표현은 개시된 해당 기능, 동작 또는 구성요소 등의 존재를 가리키며, 추가적인 하나 이상의 기능, 동작 또는 구성요소 등을 제한하지 않는다. 또한 본 발명의 다양한 실시 예에서, "포함하다" 또는 "가지다" 등의 용어는 명세서상에 기재된 특징, 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것이 존재함을 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.
본 발명의 다양한 실시 예에서 "또는" 또는 "A 또는/및 B 중 적어도 하나" 등의 표현은 함께 나열된 단어들의 어떠한, 그리고 모든 조합을 포함한다. 예를 들어, "A 또는 B" 또는 "A 또는/및 B 중 적어도 하나" 각각은, A를 포함할 수도, B를 포함할 수도, 또는 A 와 B 모두를 포함할 수도 있다.
본 발명의 다양한 실시 예 가운데 "제1", "제2", "첫째", 또는 "둘째" 등의 표현들이 본 발명의 다양한 실시 예의 다양한 구성요소들을 수식할 수 있지만, 해당 구성요소들을 한정하지 않는다. 예를 들어, 상기 표현들은 해당 구성요소들의 순서 및/또는 중요도 등을 한정하지 않는다. 상기 표현들은 한 구성요소를 다른 구성요소와 구분 짓기 위해 사용될 수 있다. 예를 들어, 제1 사용자 기기와 제2 사용자 기기는 모두 사용자 기기이며, 서로 다른 사용자 기기를 나타낸다. 예를 들어, 본 발명의 다양한 실시 예의 권리 범위를 벗어나지 않으면서 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소도 제1 구성요소로 명명될 수 있다.
어떤 구성요소가 다른 구성요소에 "연결되어" 있다거나 "접속되어" 있다고 언급된 때에는, 그 다른 구성요소에 직접적으로 연결되어 있거나 또는 접속되어 있을 수도 있지만, 중간에 다른 구성요소가 존재할 수도 있다고 이해되어야 할 것이다. 반면에, 어떤 구성요소가 다른 구성요소에 "직접 연결되어" 있다거나 "직접 접속되어" 있다고 언급된 때에는, 중간에 다른 구성요소가 존재하지 않는 것으로 이해될 수 있어야 할 것이다.
본 발명의 다양한 실시 예에서 사용한 용어는 단지 특정한 실시 예를 설명하기 위해 사용된 것으로, 본 발명의 다양한 실시 예를 한정하려는 의도가 아니다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다.
다르게 정의되지 않는 한, 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 모든 용어들은 본 발명의 다양한 실시 예가 속하는 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가지고 있다. 일반적으로 사용되는 사전에 정의되어 있는 것과 같은 용어들은 관련 기술의 문맥 상 가지는 의미와 일치하는 의미를 가지는 것으로 해석되어야 하며, 본 발명의 다양한 실시 예에서 명백하게 정의하지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다.
본 발명의 다양한 실시 예에 따른 전자 장치는, 데이터 저장 기능을 지원하는 장치일 수 있다. 예를 들면, 전자 장치는 스마트 폰(smartphone), 태블릿 PC(tablet personal computer), 이동전화기(mobile phone), 화상전화기, 전자북 리더기(e-book reader), 데스크탑 PC(desktop personal computer), 랩탑 PC(laptop personal computer), 넷북 컴퓨터(netbook computer), PDA(personal digital assistant), PMP(portable multimedia player), MP3 플레이어, 모바일 의료기기, 카메라(camera), 또는 웨어러블 장치(wearable device)(예: 전자 안경과 같은 head-mounted-device(HMD), 전자 의복, 전자 팔찌, 전자 밴드, 전자 목걸이, 기타 전자 앱세서리(appcessory), 또는 스마트 와치(smartwatch))중 적어도 하나를 포함할 수 있다.
어떤 실시 예들에 따르면, 전자 장치는 데이터 저장 기능을 갖춘 스마트 가전 제품(smart home appliance)일 수 있다. 스마트 가전 제품은, 예를 들자면, 전자 장치는 텔레비전, DVD(digital video disk) 플레이어, 오디오, 냉장고, 에어컨, 청소기, 오븐, 전자레인지, 세탁기, 공기 청정기, 셋톱 박스(set-top box), TV 박스(예를 들면, 삼성 HomeSyncTM, 애플TVTM, 또는 구글 TVTM), 게임 콘솔(game consoles), 전자 사전, 전자 키, 캠코더(camcorder), 또는 전자 액자 중 적어도 하나를 포함할 수 있다.
어떤 실시 예들에 따르면, 전자 장치는 각종 의료기기(예: MRA(magnetic resonance angiography), MRI(magnetic resonance imaging), CT(computed tomography), 촬영기, 초음파기 등), 네비게이션(navigation) 장치, GPS 수신기(global positioning system receiver), EDR(event data recorder), FDR(flight data recorder), 자동차 인포테인먼트(infotainment) 장치, 선박용 전자 장비(예: 선박용 항법 장치 및 자이로 콤파스 등), 항공 전자기기(avionics), 보안 기기, 또는 산업용 또는 가정용 로봇 중 적어도 하나를 포함할 수 있다.
어떤 실시 예들에 따르면, 전자 장치는 데이터 저장 기능을 포함한 가구(furniture) 또는 건물/구조물의 일부, 전자 보드(electronic board), 전자 사인 입력장치(electronic signature receiving device), 프로젝터(projector), 또는 각종 계측기기(예: 수도, 전기, 가스, 또는 전파 등) 중 적어도 하나를 포함할 수 있다. 다양한 실시 예에 따른 전자 장치는 전술한 다양한 장치들 중 하나 또는 그 이상의 조합일 수 있다. 또한, 다양한 실시 예에 따른 전자 장치는 전술한 기기들에 한정되지 않음은 당업자에게 자명하다.
이하, 첨부된 도면을 참조하여 다양한 실시 예에 따른 전자 장치에 대해서 살펴본다. 다양한 실시 예에서 이용되는 사용자라는 용어는 전자 장치를 사용하는 사람 또는 전자 장치를 사용하는 장치(예: 인공지능 전자 장치)를 지칭할 수 있다.
도 1은 다양한 실시 예에 따른 데이터 저장을 수행하는 전자 장치 관련 시스템을 도시한다.
도 1을 참조하면, 한 실시 예에 따르면, 데이터 저장 처리 시스템 10은 전자 장치 100, 외부 전자 장치 102, 서버 장치 106, 네트워크 162를 포함할 수 있다.
상술한 데이터 저장 처리 시스템 10에서 네트워크 162는 전자 장치 100과 전자 장치 102 사이의 통신 채널을 형성할 수 있다. 네트워크 162는 예컨대 이동통신 채널 형성과 관련한 네트워크 장치 요소들을 포함할 수 있다. 또는 네트워크 162는 인터넷 통신 채널 형성과 관련한 네트워크 장치 요소들을 포함할 수 있다. 네트워크 162는 전자 장치 100과 전자 장치 102 간의 데이터 송수신을 지원할 수 있다. 또한 네트워크 162는 전자 장치 100과 서버 장치 106과의 데이터 송수신을 지원할 수 있다.
서버 장치 106은 네트워크 162를 통하여 전자 장치 100 또는 전자 장치 102와 통신 채널을 형성할 수 있다. 한 실시 예에 따르면, 서버 장치 106은 전자 장치 100의 특정 어플리케이션 운용과 관련한 데이터를 제공할 수 있다. 예컨대, 서버 장치 106은 서버 페이지(서버 장치 106 접속에 따라 서버 장치 106에서 전자 장치 100에 제공되는 가상의 웹 페이지)를 전자 장치 100 또는 외부 전자 장치 102 등에 제공할 수 있다. 서버 장치 106이 전자 장치 100에 제공한 데이터는 메모리 130 또는 스토리지 180 중 적어도 하나에 저장될 수 있다. 한 실시 예에 따르면, 서버 장치 106이 제공한 서버 페이지는 메모리 130에 일시적으로 저장될 수 있다. 또는 서버 장치 106이 제공한 서버 페이지는 스토리지 180에 저장될 수도 있다. 다양한 실시 예에 따르면, 서버 장치 106이 제공한 특정 데이터(예: 전자 장치 100이 다운로드를 요청한 데이터)는 메모리 130에 일시적으로 저장된 후 스토리지 180에 저장될 수 있다. 다양한 실시 예에 따르면, 서버 장치 106은 스트리밍 데이터를 전자 장치 100에 제공할 수도 있다.
전자 장치 102는 전자 장치 100의 통신 인터페이스 160과 통신 채널을 형성할 수 있다. 예컨대, 전자 장치 102는 통신 인터페이스 160과 근거리 통신 채널 또는 유선 통신 채널을 형성할 수 있다. 한 실시 예에 따르면, 전자 장치 102는 통신 인터페이스 160과 블루투스 통신 채널 또는 와이파이다이렉트 통신 채널 등을 형성할 수 있다. 또는 전자 장치 102는 네트워크 162를 통하여 전자 장치 100과 통신 채널을 형성할 수 있다. 예컨대, 전자 장치 102는 셀룰러 통신 모듈을 포함하고, 전자 장치 100과 이동통신 채널을 형성할 수 있다. 또는 전자 장치 102는 와이파이 통신 모듈을 포함하고, 전자 장치 100과 와이파이 통신 채널을 형성할 수 있다. 전자 장치 102는 스크롤 가능한 정보를 전자 장치 100에 전송할 수 있다. 다양한 실시 예에 따르면, 전자 장치 102는 전자 장치 100과 형성된 통신 채널을 통하여 다양한 데이터를 전송할 수 있다. 예컨대, 전자 장치 102는 채팅 메시지 데이터, 문자 메시지 데이터, 멀티미디어 데이터 등을 전자 장치 100에 전송할 수 있다. 또는 전자 장치 102는 특정 파일(예: 일정 크기 이상의 대용량 데이터, 예컨대 사진 파일, 문서 파일, 동영상 파일, 음악 파일 등)을 전자 장치 100에 전송할 수 있다.
전자 장치 100은 전자 장치 102, 서버 장치 106 중 적어도 하나와 통신 채널을 형성할 수 있다. 전자 장치 100은 통신 채널을 형성한 다른 장치들과 관련된 화면을 디스플레이에 표시할 수 있다. 전자 장치 100은 서버 장치 106 또는 외부 전자 장치 102 등으로부터 수신된 데이터를 메모리 130 또는 스토리지 180 중 적어도 하나에 저장할 수 있다. 또한, 전자 장치 100은 특정 어플리케이션 실행에 따라 생성되는 데이터를 메모리 130 또는 스토리지 180 중 적어도 하나에 저장할 수 있다.
다양한 실시 예에 따르면, 전자 장치 100은 데이터 저장 시 해당 어플리케이션 속성(예: 백그라운드 프로세싱(background processing) 또는 포어그라운드 프로세싱(foreground processing)), 어플리케이션과 관련된 파일 속성 또는 데이터의 속성(예: 파일 또는 데이터의 크기, 파일 또는 데이터가 저장되는 위치, 설정된 값) 등에 의하여 선택적 저널링을 수행할 수 있다. 예컨대, 전자 장치 100은 어플리케이션 실행 상태가 백그라운드 프로세싱으로 처리되는 경우 오더 모드(ordered mode)로 데이터를 저장할 수 있다. 어플리케이션 실행 상태가 포어그라운드 프로세싱으로 처리되는 경우 기입 모드(writeback mode)로 데이터를 저장할 수 있다.
상기 기입 모드는 파일 시스템 저장 영역의 메타 데이터를 저널링 장치에 트랜잭션 단위로 커밋(commit)하고, 파일 데이터를 파일 시스템 저장 영역에 직접 기록하는 모드이다. 기입 모드는 트랜잭션 커밋 동작(예: 메모리 130의 파일 시스템에서 러닝 트랜잭션이 설정된 시간 또는 크기가 될 경우 메모리 130에 저장된 데이터를 스토리지 180 영역의 저널링 장치에 이동)에서 파일 데이터 블록의 갱신(update) 완료를 대기하지 않는 모드이다. 이러한 기입 모드는 메타 데이터와 데이터 간 무결성을 보장하지 않으나, 메타 데이터 자체는 무결성이 보장될 수 있다.
오더 모드는 메타 데이터를 저널링 장치에 기록하고, 파일 데이터 블록 갱신 완료를 대기하는 모드이다. 오더 모드는 메타데이터 무결성 및 메타데이터와 데이터 간 무결성 보장할 수 있다.
도 1을 참조하면, 상기 전자 장치 100은 버스 110, 프로세서 120, 메모리 130, 입출력 인터페이스 140, 디스플레이 150, 통신 인터페이스 160, 데이터 처리 모듈 170 및 스토리지 180을 포함할 수 있다.
상기 버스 110은 전술한 구성요소들을 서로 연결하고, 전술한 구성요소들 간의 통신(예: 제어 메시지, 입력 이벤트, 데이터 등)을 전달하는 회로일 수 있다. 예컨대, 버스 110은 입출력 인터페이스 140에서 입력된 입력 신호를 프로세서 120 또는 데이터 처리 모듈 170 중 적어도 하나에 전달할 수 있다. 버스 110은 스크롤 가능 정보를 디스플레이 150, 프로세서 120, 또는 데이터 처리 모듈 170 중 적어도 하나에 전달할 수 있다. 예컨대, 버스 110은 메모리 130에 저장된 데이터를 스토리지 180에 전달할 수 있다. 버스 110은 데이터 처리 모듈 170의 제어 신호를 메모리 130 또는 스토리지 180 중 적어도 하나에 전달할 수 있다.
상기 프로세서 120은, 예를 들면, 상기 버스 110을 통해 전술한 다른 구성요소들(예: 상기 메모리 130, 상기 입출력 인터페이스 140, 상기 디스플레이 150, 상기 통신 인터페이스 160, 또는 상기 데이터 처리 모듈 170 등)로부터 명령을 수신하여, 수신된 명령을 해독하고, 해독된 명령에 따른 연산이나 데이터 처리를 실행할 수 있다. 이러한 프로세서 120은 데이터 처리 모듈 170을 포함하는 형태로 마련되거나 또는 데이터 처리 모듈 170과 독립적인 형태로 마련되고, 버스 110을 기반으로 또는 직접적으로 메모리 130과 스토리지 180을 제어하는 형태로 마련될 수 있다. 프로세서 120은 다양한 실시 예에 따른 오더 모드와 기입 모드 기반의 데이터 저장 처리를 지원할 수 있다.
상기 메모리 130은, 상기 프로세서 120 또는 다른 구성요소들(예: 상기 입출력 인터페이스 140, 상기 디스플레이 150, 상기 통신 인터페이스 160, 또는 상기 데이터 처리 모듈 170 등)로부터 수신되거나 상기 프로세서 120 또는 다른 구성요소들에 의해 생성된 명령 또는 데이터를 저장할 수 있다. 상기 메모리 130은, 예를 들면, 커널 131, 미들웨어 132, 어플리케이션 프로그래밍 인터페이스(API: application programming interface) 133 또는 어플리케이션 134 등의 프로그래밍 모듈들을 포함할 수 있다. 전술한 각각의 프로그래밍 모듈들은 소프트웨어, 펌웨어, 하드웨어 또는 이들 중 적어도 둘 이상의 조합으로 구성될 수 있다.
상기 커널 131은 나머지 다른 프로그래밍 모듈들, 예를 들면, 상기 미들웨어 132, 상기 API 133 또는 상기 어플리케이션 134에 구현된 동작 또는 기능을 실행하는데 사용되는 시스템 리소스들(예: 상기 버스 110, 상기 프로세서 120 또는 상기 메모리 130, 스토리지 180, 데이터 처리 모듈 170 등)을 제어 또는 관리할 수 있다. 또한, 상기 커널 131은 상기 미들웨어 132, 상기 API 133 또는 상기 어플리케이션 134에서 상기 전자 장치 100의 개별 구성요소에 접근하여 제어 또는 관리할 수 있는 인터페이스를 제공할 수 있다.
상기 미들웨어 132는 상기 API 133 또는 상기 어플리케이션 134가 상기 커널 131과 통신하여 데이터를 주고받을 수 있도록 중개 역할을 수행할 수 있다. 또한, 상기 미들웨어 132는 상기 어플리케이션 134로부터 수신된 작업 요청들과 관련하여, 예를 들면, 상기 어플리케이션 134 중 적어도 하나의 어플리케이션에 상기 전자 장치 100의 시스템 리소스(예: 상기 버스 110, 상기 프로세서 120 또는 상기 메모리 130, 상기 스토리지 180, 데이터 처리 모듈 170 등)를 사용할 수 있는 우선순위를 배정하는 등의 방법을 이용하여 작업 요청에 대한 제어(예: 스케쥴링 또는 로드 밸런싱)를 수행할 수 있다.
상기 API 133은 상기 어플리케이션 134가 상기 커널 131 또는 상기 미들웨어 132에서 제공되는 기능을 제어하기 위한 인터페이스일 수 있다. API 133은 예를 들면, 파일 제어, 창 제어, 화상 처리 또는 문자 제어 등을 위한 적어도 하나의 인터페이스 또는 함수(예: 명령어)를 포함할 수 있다.
다양한 실시 예에 따르면, 상기 어플리케이션 134는 SMS/MMS 어플리케이션, 이메일 어플리케이션, 달력 어플리케이션, 알람 어플리케이션, 건강 관리(health care) 어플리케이션(예: 운동량 또는 혈당 등을 측정하는 어플리케이션) 또는 환경 정보 어플리케이션(예: 기압, 습도 또는 온도 정보 등을 제공하는 어플리케이션) 등을 포함할 수 있다. 추가적으로 또는 대체적으로, 상기 어플리케이션 134는 상기 전자 장치 100과 외부 전자 장치(예: 전자 장치 102) 사이의 정보 교환과 관련된 어플리케이션일 수 있다. 상기 정보 교환과 관련된 어플리케이션은, 예를 들어, 상기 외부 전자 장치에 특정 정보를 전달하기 위한 알림 전달(notification relay) 어플리케이션, 또는 상기 외부 전자 장치를 관리하기 위한 장치 관리(device management) 어플리케이션을 포함할 수 있다.
예를 들면, 상기 알림 전달 어플리케이션은 상기 전자 장치 100 의 다른 어플리케이션(예: SMS/MMS 어플리케이션, 이메일 어플리케이션, 건강 관리 어플리케이션 또는 환경 정보 제공 어플리케이션 등)에서 발생한 알림 정보를 외부 전자 장치(예: 전자 장치 102)로 전달하는 기능을 포함할 수 있다. 추가적으로 또는 대체적으로, 상기 알림 전달 어플리케이션은, 예를 들면, 외부 전자 장치(예: 전자 장치 102)로부터 알림 정보를 수신하여 사용자에게 제공할 수 있다. 상기 장치 관리 어플리케이션은, 예를 들면, 상기 전자 장치 100과 통신하는 외부 전자 장치(예: 전자 장치 102)의 적어도 일부에 대한 기능(예: 외부 전자 장치 자체(또는, 일부 구성 부품)의 턴온/턴오프 또는 디스플레이의 밝기(또는, 해상도) 조절), 상기 외부 전자 장치에서 동작하는 어플리케이션 또는 상기 외부 전자 장치에서 제공되는 서비스(예: 통화 서비스 또는 메시지 서비스)를 관리(예: 설치, 삭제 또는 업데이트)할 수 있다. 다양한 실시 예에 따르면, 외부 전자 장치가 MP3 플레이어인 경우, 상기 어플리케이션 134는 음악 재생과 관련된 어플리케이션을 포함할 수 있다. 유사하게, 외부 전자 장치가 모바일 의료기기인 경우, 상기 어플리케이션 134는 건강 관리와 관련된 어플리케이션을 포함할 수 있다.
한 실시 예에 따르면, 상기 어플리케이션 134 속성 또는 종류에 따라 어플리케이션 134와 관련하여 생성된 데이터는 기입 모드 또는 오더 모드 중 어느 하나의 데이터 처리 방식으로 저장하도록 설정될 수 있다. 예를 들어, 웹 브라우저와 관련한 어플리케이션 134는 기입 모드를 기반으로 데이터를 저장하도록 설정될 수 있다. 음악 재생과 관련한 어플리케이션 134는 오더 모드를 기반으로 데이터를 저장하도록 설정될 수 있다. 동영상 재생과 관련한 어플리케이션 134는 오더 모드를 기반으로 데이터를 저장하도록 설정될 수 있다. 다른 예를 들어, 어플리케이션 134가 실시간성이 필요한 기능을 지원하는 경우 어플리케이션 134와 관련하여 생성된 데이터는 기입 모드를 기반으로 데이터를 저장하도록 설정될 수 있다. 또한 어플리케이션 134가 대용량 데이터 처리가 필요한 기능을 지원하는 경우 어플리케이션 134와 관련하여 생성된 데이터는 오더 모드를 기반으로 데이터를 저장하도록 설정될 수 있다. 어플리케이션 134의 종류별 데이터 처리 방식의 설정과 관련하여, 데이터 처리 모듈 170은 설정 화면을 제공할 수 있다. 어플리케이션 134의 속성(예: 실시간성 또는 대용량 데이터 저장 특성 등)은 전자 장치 100에서의 어플리케이션 134 실행 위치(예: 백그라운드 프로세싱 또는 포어그라운드 프로세싱), 데이터의 크기 확인 등을 통해 결정될 수 있다.
다양한 실시 예에 따르면, 메모리 130은 어플리케이션 134에 의해 생성된 또는 갱신된 디렉토리 또는 파일을 포함할 수 있다. 디렉토리는 어플리케이션 134 운용과 관련하여 생성되는 카테고리 또는 폴더 등을 포함할 수 있다. 디렉토리는 하부 디렉토리를 포함하거나, 또는 적어도 하나의 파일을 포함할 수 있다. 디렉토리는 데이터 처리 방식(예: 기입 모드 또는 오더 모드)이 데이터 처리 모듈 170 제어에 대응하여 설정될 수 있다. 디렉토리의 데이터 처리 방식이 설정되면, 디렉토리 내에 배치된 하부 디렉토리 또는 파일은 해당 데이터 처리 방식을 상속받아 처리될 수 있다. 파일은 어플리케이션 134 기능 실행과 관련하여 운용되는 일정 크기 또는 적어도 하나의 데이터 블록을 포함할 수 있다.
상기 입출력 인터페이스 140은, 입출력 장치(예: 센서, 키보드 또는 터치스크린)를 통하여 사용자로부터 입력된 명령 또는 데이터를, 예를 들면, 상기 버스 110을 통해 상기 프로세서 120, 상기 메모리 130, 상기 통신 인터페이스 160, 또는 상기 데이터 처리 모듈 170에 전달할 수 있다. 또한, 상기 입출력 인터페이스 140은, 예를 들면, 상기 버스 110을 통해 상기 프로세서 120, 상기 메모리 130, 상기 통신 인터페이스 160, 또는 상기 데이터 처리 모듈 170으로부터 수신된 명령 또는 데이터를 상기 입출력 장치(예: 스피커 또는 디스플레이)를 통하여 출력할 수 있다. 다양한 실시 예에 따르면, 입출력 인터페이스 140은 물리 키 버튼(예: 홈 키, 사이드 키, 전원 키 등), 죠그 키, 키패드 등을 포함할 수 있다. 입출력 인터페이스 140은 디스플레이 150에 출력되는 가상 키패드를 입력 장치로 포함할 수 있다. 입출력 인터페이스 140은 적어도 하나의 어플리케이션 실행과 관련한 입력 신호, 실행 중인 어플리케이션 제어와 관련한 입력 신호, 디렉토리 또는 파일 생성과 관련한 입력 신호 등을 생성할 수 있다.
다양한 실시 예에 따르면, 입출력 인터페이스 140은 오디오 처리와 관련한 기능을 수행할 수 있다. 이와 관련하여 입출력 인터페이스 140은 스피커 및 마이크 중 적어도 하나를 단수 개 또는 복수 개 포함할 수 있다. 입출력 인터페이스 140은 예를 들면, 상기 데이터 처리 모듈 170의 제어에 따라 특정 어플리케이션 실행과 관련한 오디오 데이터를 스피커를 통하여 출력할 수 있다.
상기 디스플레이 150은 각종 정보(예: 멀티미디어 데이터 또는 텍스트 데이터 등)를 표시할 수 있다. 예컨대, 디스플레이 150은 락 스크린, 대기 화면 등을 출력할 수 있다. 디스플레이 150은 특정 기능 수행 화면 예컨대 음원 재생 화면, 동영상 재생 화면, 방송 수신 화면 등을 기능 수행에 대응하여 출력할 수 있다. 한 실시 예에 따르면, 디스플레이 150은 어플리케이션의 데이터 처리 방식 설정과 관련한 화면을 출력할 수 있다. 또한 디스플레이 150은 디렉토리 또는 파일의 데이터 처리 방식 설정과 관련한 화면을 출력할 수 있다.
상기 통신 인터페이스 160은 상기 전자 장치 100과 외부 장치(예: 전자 장치 102, 서버 장치 106 중 적어도 하나) 간의 통신을 연결할 수 있다. 예를 들면, 상기 통신 인터페이스 160은 무선 통신 또는 유선 통신을 통해서 네트워크 162에 연결되어 상기 외부 장치와 통신할 수 있다. 상기 무선 통신은, 예를 들어, Wifi(wireless fidelity), BT(Bluetooth), NFC(near field communication), GPS(global positioning system) 또는 cellular 통신(예: LTE, LTE-A, CDMA, WCDMA, UMTS, WiBro 또는 GSM 등) 중 적어도 하나를 포함할 수 있다. 상기 유선 통신은, 예를 들어, USB(universal serial bus), HDMI(high definition multimedia interface), RS-232(recommended standard 232) 또는 POTS(plain old telephone service) 중 적어도 하나를 포함할 수 있다.
한 실시 예에 따르면, 상기 네트워크 162는 통신 네트워크(telecommunications network)일 수 있다. 상기 통신 네트워크는 컴퓨터 네트워크(computer network), 인터넷(internet), 사물 인터넷(internet of things) 또는 전화망(telephone network) 중 적어도 하나를 포함할 수 있다. 한 실시 예에 따르면, 상기 전자 장치 100과 외부 장치 간의 통신을 위한 프로토콜(예: transport layer protocol, data link layer protocol 또는 physical layer protocol))은 어플리케이션 134, 어플리케이션 프로그래밍 인터페이스 133, 상기 미들웨어 132, 커널 131 또는 통신 인터페이스 160 중 적어도 하나에서 지원될 수 있다.
통신 인터페이스 160은 전자 장치 100이 복수의 통신 방식들을 지원하는 경우 복수개의 통신 모듈들을 포함할 수 있다. 예컨대, 전자 장치 100은 전자 장치 102와 직접 통신 채널을 형성할 수 있는 통신 모듈 예컨대, 근거리 통신 모듈 또는 직접 통신 모듈을 포함할 수 있다. 근거리 통신 모듈 또는 직접 통신 모듈은 와이파이다이렉트 통신 모듈, 블루투스 통신 모듈, 지그비 통신 모듈 등 다양한 통신 모듈 중 적어도 하나를 포함할 수 있다. 또한 직접 통신 모듈은 케이블 등의 유선 통신 모듈을 포함할 수 있다.
한 실시 예에 따르면, 통신 인터페이스 160은 전자 장치 102 또는 서버 장치 106 중 적어도 하나로부터 특정 데이터(예: 이미지 파일, 문서 파일, 웹 페이지 등)를 수신할 수 있다. 수신된 데이터는 메모리 130에 임시 저장되고, 설정에 따라 스토리지 180에 저장될 수 있다. 이때, 수신된 데이터는 해당 어플리케이션의 실행 위치나 상태, 데이터의 크기에 따라 기입 모드 또는 오더 모드 방식 중 어느 하나의 방식으로 메모리 130에서 스토리지 180로 이동될 수 있다.
상기 데이터 처리 모듈 170은, 다른 구성요소들(예: 상기 프로세서 120, 상기 메모리 130, 상기 입출력 인터페이스 140, 또는 상기 통신 인터페이스 160 등)로부터 획득된 데이터를 처리할 수 있다. 예를 들면, 데이터 처리 모듈 170은 특정 어플리케이션 실행 또는 특정 기능 실행에 대응하여 생성된 데이터를 메모리 130에 저장하고, 메모리 130에 저장된 데이터를 기입 모드 또는 오더 모드 중 어느 하나의 방식에 따라 스토리지 180에 저장하도록 제어할 수 있다.
도 2는 다양한 실시 예에 따른 스토리지와 메모리를 도시한다.
도 2를 참조하면, 메모리 130은 파일 시스템을 포함하고, 리스트 영역 31, 러닝 트랜잭션 영역 33, 저널링 쓰레드 영역 35, 데이터 처리 쓰레드 영역 37을 포함할 수 있다. 스토리지 180은 저널링 장치 81, 데이터 영역 83을 포함할 수 있다. 데이터 영역 83은 메타 데이터 영역 82, 데이터 저장 영역 84를 포함할 수 있다.
데이터 처리 모듈 170은 전자 장치 100의 특정 기능 또는 어플리케이션 실행에 대응하여 특정 파일이 생성되면(또는 특정 파일의 갱신이 요청되면), 해당 파일과 관련한 정보 확인을 수행할 수 있다. 예컨대, 데이터 처리 모듈 170은 파일의 크기, 파일이 위치한 디렉토리의 속성, 또는 어플리케이션의 실행 상태를 확인할 수 있다. 확인 결과에 따라, 데이터 처리 모듈 170은 스토리지 180에 저장할 파일의 데이터 처리 방식을 결정할 수 있다. 예컨대, 데이터 처리 모듈 170은 백그라운드 프로세싱되는 어플리케이션과 관련한 파일의 데이터 처리가 요청되면, 해당 파일을 오더 모드로 처리하도록 결정할 수 있다.
한 실시 예에 따르면, 기입 모드와 관련한 데이터 처리 방식에 해당하는 백그라운드 프로세싱에 따른 파일처리가 요청되면, 데이터 처리 모듈 170은 리스트 영역 31에 별도의 파일 관련 노드 생성을 억제할 수 있다. 데이터 처리 모듈 170은 파일 관련 메타 데이터를 러닝 트랜잭션 영역 33에 저장되도록 제어할 수 있다. 데이터 처리 모듈 170은 설정된 시간 또는 크기에 기반하여 트랜잭션 커밋 시기가 도래하면, 러닝 트랜잭션 영역 33에 저장된 메타 데이터를 버스 110을 이용하여 저널링 장치 81의 일정 영역에 저장되도록 제어할 수 있다. 한 실시 예에 따르면, 러닝 트랜잭션 영역 33에는 복수의 메타 데이터 블록이 저장될 수 있으며, 하나의 러닝 트랜잭션 영역 33에 저장된 정보는 저널링 장치 81의 일정 영역에 저장될 수 있다. 데이터 처리 모듈 170은 러닝 트랜잭션 영역 33에 저장된 메타 데이터를 저널링 장치 81에 저장한 이후, 데이터 영역 83의 쓰기 동작 완료를 대기하지 않고 다른 파일 처리를 수행할 수 있다. 데이터 처리 모듈 170은 저널링 장치 81에 메타 데이터가 기입된 이후, 데이터 저장 영역 84에 데이터 블록들의 쓰기 동작을 제어할 수 있다. 이 동작에서 데이터 처리 모듈 170은 저널링 장치 81에 저장된 메타 데이터가 데이터 저장 영역 84와 연계하여 메타 데이터 영역 82에 저장되도록 제어할 수 있다. 이와 관련하여, 데이터 처리 모듈 170은 저널링 쓰레드와 데이터 처리 쓰레드를 각각 저널링 쓰레드 영역 35 및 데이터 처리 쓰레드 영역 37에 할당할 수 있다. 저널링 쓰레드 영역 35에 배치된 저널링 쓰레드는 파일 노드와 관련한 리스트 관리 동작, 메타 데이터의 저널링 장치 81 저장 동작, 메타 데이터의 메타 데이터 영역 82 저장 동작을 제어할 수 있다. 데이터 처리 쓰레드는 데이터 블록들을 데이터 저장 영역 84에 저장하는 동작을 제어할 수 있다. 여기서 데이터 블록들은 새로운 파일과 관련되거나 또는 이전 파일 갱신과 관련된 정보일 수 있다. 새로운 파일인 경우, 파일의 데이터 블록들은 해당 어플리케이션 운용과 관련하여 할당된 스토리지 180 영역 중에 새로운 영역을 할당 받아 저장될 수 있다. 기존 파일의 갱신된 파일인 경우 파일의 데이터 블록들은 기존 저장된 파일 영역에 덮어쓰기 형태로 저장될 수 있다.
다양한 실시 예에 따르면, 오더 모드와 관련한 데이터 처리 방식에 해당하는 포어그라운드 프로세싱에 따른 파일처리가 요청되면, 데이터 처리 모듈 170은 리스트 영역 31에 새로운 파일 노드를 생성할 수 있다. 데이터 처리 모듈 170은 파일 관련 메타 데이터를 러닝 트랜잭션 영역 33에 저장되도록 제어할 수 있다. 데이터 처리 모듈 170은 설정된 시간 또는 크기에 기반하여 트랜잭션 커밋 시기가 도래하면, 러닝 트랜잭션 영역 33에 저장된 메타 데이터를 저널링 장치 81의 일정 영역에 저장되도록 제어할 수 있다. 데이터 처리 모듈 170은 러닝 트랜잭션 영역 33에 저장된 메타 데이터를 저널링 장치 81에 저장한 이후, 데이터 저장 영역 84에 데이터 블록들의 쓰기 동작을 제어할 수 있다. 이 동작에서 데이터 처리 모듈 170은 저널링 장치 81에 저장된 메타 데이터가 데이터 저장 영역 84와 연계하여 메타 데이터 영역 82에 저장되도록 제어할 수 있다. 데이터 처리 모듈 170은 메타 데이터 영역 82 및 데이터 저장 영역 84에 각각 메타 데이터 및 데이터 블록 쓰기가 종료되면 다음 동작 진행을 제어할 수 있다. 상술한 동작에서 데이터 처리 모듈 170은 메타 데이터 쓰기와 관련하여 저널링 쓰레드 영역 35에 저널링 쓰레드 할당 및 운용을 제어할 수 있다. 또한 데이터 처리 모듈 170은 데이터 블록 쓰기와 관련하여 데이터 처리 쓰레드 영역 37에 데이터 처리 쓰레드 할당 및 운용을 제어할 수 있다.
도 3은 다양한 실시 예에 따른 전자 장치의 데이터 처리 모듈을 도시한다.
도 3을 참조하면, 데이터 처리 모듈 170은 메타 데이터 처리 모듈 171, 데이터 블록 처리 모듈 173, 리스트 관리 모듈 175를 포함할 수 있다.
메타 데이터 처리 모듈 171은 전자 장치 100 운용에 따라 생성된 데이터의 메타 데이터 처리를 수행할 수 있다. 예컨대, 메타 데이터 처리 모듈 171은 전자 장치 100 운용에 대응하여 특정 파일이 생성되거나 갱신과 관련한 파일이 생성되면 해당 파일과 관련된 메타 데이터 생성 동작, 메타 데이터의 메모리 130 저장 동작, 메모리 130에 저장된 메타 데이터의 스토리지 180 이동 동작 등을 제어할 수 있다. 메타 데이터는 파일과 관련한 메타 정보를 포함할 수 있다. 예컨대, 메타 데이터는 해당 파일과 관련한 어플리케이션의 종류 정보, 파일의 저장 위치(예: 파일 루트), 파일의 크기, 파일 생성 시기 등을 포함할 수 있다. 메타 데이터 처리 모듈 171은 메타 데이터가 생성되면, 생성된 메타 데이터를 메모리 130의 러닝 트랜잭션 영역에 저장되도록 제어할 수 있다. 메타 데이터 처리 모듈 171은 트랜잭션 커밋 시 스토리지 180의 저널링 장치에 메타 데이터가 저장되도록 제어할 수 있다. 이 동작에서 메타 데이터 처리 모듈 171은 해당 파일과 관련된 어플리케이션의 속성, 어플리케이션이 실행되는 위치나 상태, 파일 또는 파일이 위치한 디렉토리 속성 중 적어도 하나를 포함하는 데이터 처리 방식을 확인할 수 있다. 메타 데이터 처리 모듈 171은 확인된 데이터 처리 방식에 따라 기입 모드 또는 오더 모드 중 어느 하나의 모드로 메타 데이터의 스토리지 180 저장 동작을 제어할 수 있다.
예컨대, 메타 데이터 처리 모듈 171은 기입 모드 방식에 따라 메타 데이터가 스토리지 180에 저장되도록 제어하는 경우, 메모리 130에 저장된 메타 데이터(여기서, 메타 데이터는 복수개의 메타 데이터 블록을 포함할 수 있음)를 저널링 장치(예를 들어, 도 2의 저널링 장치 81)에 저장시키는 동작을 파일 관련 데이터 블록 저장 동작과 독립적으로 처리할 수 있다. 또는 메타 데이터 처리 모듈 171은 오더 모드 방식에 따라 메타 데이터가 스토리지 180에 저장되도록 제어하는 경우 메타 데이터 저장 동작을 데이터 블록 저장 동작과 연계하여 처리할 수 있다. 예컨대, 오더 모드 방식에서 메타 데이터 처리 모듈 171은 메모리 130에 저장된 메타 데이터를 스토리지 180의 저널링 장치에 저장한 이후, 스토리지 180의 데이터 영역 중 메타 데이터 영역에 메타 데이터를 저장하는 동작을 처리할 수 있다. 메타 데이터 처리 모듈 171은 메타 데이터 저장 동작과 연계하여 데이터 블록 저장 동작이 완료되면, 다른 메타 데이터 저장 동작을 수행할 수 있다.
데이터 블록 처리 모듈 173은 전자 장치 100 운용에 따라 생성된 데이터 처리를 수행할 수 있다. 예컨대, 데이터 블록 처리 모듈 173은 전자 장치 100 운용에 대응하여 특정 파일이 생성되거나 갱신과 관련한 파일이 생성되면 해당 파일 관련 데이터 블록의 메모리 130 저장 동작, 메모리 130에 저장된 데이터 블록의 스토리지 180 이동 동작 등을 제어할 수 있다. 이 동작에서 데이터 블록 처리 모듈 173은 데이터 처리 방식을 확인하고, 확인된 방식(예: 기입 모드 또는 오더 모드)에 따라 데이터 블록의 저장 동작을 처리할 수 있다.
리스트 관리 모듈 175는 메타 데이터 저장과 관련한 노드 리스트 관리를 처리할 수 있다. 예컨대, 리스트 관리 모듈 175는 특정 파일 저장 동작이 요청(예: 어플리케이션 실행에 대응하여 파일 저장과 관련한 입출력제어 시스템 호출(I/O control(ioctl) system call) 등에 의한 파일 시스템 명령 발생)되면, 노드 리스트 관리를 수행할 수 있다. 한 실시 예에 따르면, 리스트 관리 모듈 175는 오더 모드로 저장할 파일과 관련하여 새로운 노드(예: 리스트 항목)를 포함하는 리스트 갱신을 수행할 수 있다. 또한, 리스트 관리 모듈 175는 기입 모드로 저장할 파일과 관련하여 별도의 노드를 생성하지 않도록 제어할 수 있다.
한편, 상술한 설명에서는 메타 데이터 처리 모듈 171과 데이터 블록 처리 모듈 173, 리스트 관리 모듈 175를 역할별로 구분하여 설명하였으나, 다양한 실시 예들이 이에 한정되는 것은 아니다. 예컨대, 데이터 처리 모듈 170은 특정 파일 처리와 관련하여 기입 모드 또는 오더 모드에 따라 리스트 관리 동작, 메타 데이터의 저장 동작과 데이터 블록 저장 동작을 처리하는 하나의 처리 모듈을 할당할 수 있다. 할당된 하나의 처리 모듈은 기입 모드 또는 오더 모드에 따라 리스트 관리 동작, 메타 데이터의 저장 동작, 데이터 블록의 저장 동작을 하나의 프로세스로 처리할 수 있다. 또한 데이터 처리 모듈 170은 메타 데이터 저장 동작과 리스트 관리 동작을 함께 처리하는 프로세스 또는 프로세스 모듈을 할당할 수도 있다. 이 경우 하나의 처리 모듈은 리스트 관리 동작 및 메타 데이터의 저장 동작을 처리하고, 다른 하나의 처리 모듈은 데이터 블록의 저장 동작을 처리할 수 있다.
상술한 바와 같이, 다양한 실시 예에 따른 전자 장치는 장치 운용에 따른 파일을 저장하는 메모리, 상기 메모리에 저장된 파일의 저널링을 지원하는 스토리지, 상기 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드 또는 오더 모드 중 어느 하나의 모드로 처리하는 데이터 처리 모듈을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 어플리케이션 실행 위치가 포어그라운드인 경우 상기 파일을 기입 모드에 따라 저장되도록 제어할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일을 오더 모드에 따라 저장되도록 제어할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 파일의 크기에 따라 상기 파일을 기입 모드 또는 오더 모드 중 어느 하나의 모드로 저장 처리할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 파일의 크기가 지정된 크기 이상인 경우 상기 파일을 기입 모드로 처리할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 파일의 크기가 지정된 크기 미만인 경우 상기 파일을 오더 모드로 처리할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 어플리케이션 속성에 의해 기입 모드 처리가 결정되는 경우 파일 노드에 기입 모드 플래그 처리와 관련한 변수 정의 및 셋업을 수행할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 파일이 저장되는 위치의 디렉토리 속성을 확인하고, 상기 디렉토리 속성이 기입 모드 설정인 경우 이를 상속하여 상기 파일의 속성을 기입 모드 처리로 결정할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일의 크기를 확인하고, 상기 파일의 크기가 지정된 값보다 큰 경우 상기 파일을 기입 모드로 처리할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일의 크기를 확인하고, 상기 파일의 크기가 지정된 값보다 작은 경우 상기 파일을 오더 모드로 처리할 수 있다.
도 4는 다양한 실시 예에 따른 데이터 처리 방법을 도시한다.
도 4를 참조하면, 다양한 실시 예에 따른 데이터 처리 방법과 관련하여 동작 401에서 데이터 처리 모듈 170은 데이터 저장과 관련한 이벤트 발생이 있는지 확인할 수 있다. 예컨대, 데이터 처리 모듈 170은 특정 어플리케이션 수행에 따른 파일 생성 또는 파일 갱신 등이 있는지 확인할 수 있다. 상기 특정 어플리케이션 수행은 전자 장치 100이 지원하는 다양한 기능 예컨대, 메시지 기능, 메신저 기능, 스케줄 기능, 파일 편집 기능, 이미지 수집 기능, 데이터 송수신 기능 등을 포함할 수 있다. 동작 401에서 데이터 저장 관련 이벤트 발생이 없으면, 이하 과정을 생략하고, 동작 409 이전으로 분기할 수 있다.
동작 401에서 데이터 저장과 관련한 이벤트가 발생하면, 동작 403에서 데이터 처리 모듈 170은 어플리케이션 속성 또는 파일 속성 중 적어도 하나를 확인할 수 있다. 예컨대, 데이터 처리 모듈 170은 어플리케이션 실행이 백그라운드 프로세싱으로 수행되는지 여부, 포어그라운드 프로세싱으로 수행되는지 여부, 파일이 저장된 위치의 디렉토리 속성(예: 기입 모드 또는 오더 모드에 따라 데이터 처리가 수행되도록 설정된 속성), 파일의 크기(예: 지정된 크기 이상인지 여부) 확인을 수행할 수 있다. 또는 데이터 처리 모듈 170은 어플리케이션이 기입 모드 또는 오더 모드 중 어느 하나에 의해 데이터 처리가 되도록 설정된 속성이 있는지 확인할 수 있다. 또는 데이터 처리 모듈 170은 어플리케이션 속성과 관련하여, 어플리케이션 실행 중 특정 루틴의 속성(예: 어플리케이션 실행 중에 처리되는 태스크(Task)나 프로세스(Process), 또는 쓰레드(Thread))의 속성(예: 실시간 처리가 요청되는 프로토콜 운용과의 관련성-기입 모드 처리 방식으로 처리, 다운로드 방식의 프로토콜 운용과의 관련성-오더 모드 처리 방식으로 처리))을 확인할 수 있다.
동작 405에서, 데이터 처리 모듈 170은 확인 결과에 대응하여 해당 파일의 처리 방식을 오더 모드 또는 기입 모드 중 어느 하나로 결정할 수 있다. 동작 407에서 데이터 처리 모듈 170은 결정된 모드에 따라 데이터 저장 처리를 제어할 수 있다. 데이터 저장 처리 방식에서 데이터 처리 모듈 170은 저널링 방식을 운용할 수 있다. 저널링 방식은 파일 I/O(input-output) 중 파일 시스템 손상을 방지하는 방법으로, 파일 시스템을 업데이트 하기 전 저널 영역(예: 저널링 장치 81)에 변경될 메타 데이터를 트랜잭션(transaction) 단위로 커밋(commit) 하고(러닝 트랜잭션 영역 33에 메타 데이터 배치), 커밋이 완료되면 파일 시스템을 업데이트는 하는 방법이다. 트랜잭션 커밋은 트랜잭션에 포함된 파일의 동기화(sync) 시점 또는 지정된 트랜잭션 커밋 주기, 또는 지정된 크기 메타 데이터 양 배치 등에 따라 수행될 수 있다.
동작 409에서, 데이터 처리 모듈 170은 데이터 저장 관련 동작의 종료와 관련한 이벤트(예: 전자 장치 100의 턴-오프 이벤트 또는 전자 장치 100의 파일 처리와 관련한 어플리케이션의 종료 이벤트 등)가 발생하는지 확인할 수 있다. 데이터 처리 모듈 170은 동작 종료 관련 이벤트 발생이 없으면, 동작 401 이전으로 분기하여 이하 동작의 재수행을 제어할 수 있다.
다양한 실시 예에 따르면, 상술한 동작을 기반으로, 데이터 처리 모듈 170은 백그라운드 프로세싱 과정에서의 파일 입출력에 의해 포어그라운드 프로세싱의 파일 입출력이 지연되는 현상을 방지할 수 있다. 한 실시 예에 따르면, 데이터 처리 모듈 170은 파일시스템 저널링 장치 81이 오더 모드로 동작하고 있을 때, 러닝 트랜잭션 영역 33 운용과 관련하여 파일의 노드를 등록하고, 트랜잭션 커밋 시점에 파일 노드의 데이터 블록을 참조할 수 있도록 지원할 수 있다. 또한, 파일시스템 저널링 장치 81이 기입 모드로 동작하고 있을 때, 데이터 처리 모듈 170은 트랜잭션 커밋 시점에 파일 노드의 데이터 블록이 스토리지 180에 저장되는 것을 대기하지 않고 트랜잭션 커밋을 수행할 수 있다.
디렉토리 및 파일 속성 지정을 통한 선택적인 기입 모드 적용과 관련하여, 데이터 처리 모듈(은) 리스트의 파일 노드에 기입 모드 플래그 처리를 위한 변수 정의 및 셋업을 수행할 수 있다. 여기서 데이터 처리 모듈 170은 파일 노드에 기입 모드 수행과 관련한 플래그를 저장할 수 있는 영역을 할당할 수 있다. 어플리케이션에 의해 파일시스템 명령(ioctl system call 등)이 발생하면, 데이터 처리 모듈 170은 기입 모드가 필요한 디렉토리 또는 파일 노드에 플래그 셋업을 수행할 수 있다. 디렉토리(또는 디렉토리 아이노드(inode))에 기입 모드 플래그(writeback flag)가 셋업되면, 데이터 처리 모듈 170은 디렉토리 내에 신규로 생성되는 파일(또는 파일 아이노드)이 부모 디렉토리의 기입 모드 플래그를 상속하도록 셋업할 수 있다. 파일 노드의 변경 내용을 러닝 트랜잭션 영역 33에 등록하는 동작에서 노드에 기입 모드 플래그가 셋업되어 있을 경우, 데이터 처리 모듈 170은 변경된 메타 데이터 버퍼만 러닝 트랜잭션 영역 33에 기록하고, 노드 등록 과정(예: 리스트 관리 동작)을 생략하여 추후 트랜잭션 커밋 시점에 기입 모드 저널링이 수행되도록 처리할 수 있다.
도 5는 다양한 실시 예에 따른 데이터 처리 방법 중 어플리케이션 실행 상태에 따른 데이터 처리를 도시한다.
도 5를 참조하면, 데이터 처리 방법과 관련하여, 데이터 처리 모듈 170은 동작 501에서 데이터 저장과 관련한 이벤트 발생이 있는지 확인할 수 있다. 동작 501에서 데이터 저장과 관련한 이벤트 발생이 없으면, 데이터 처리 모듈 170은 이하 동작을 스킵하고, 동작 511 이전으로 분기하도록 제어할 수 있다. 동작 501에서 데이터 저장과 관련한 이벤트가 발생하면, 동작 503에서 어플리케이션 실행 상태 확인을 수행할 수 있다.
동작 505에서 데이터 처리 모듈 170은 어플리케이션 실행 상태가 지정된 상태 예컨대 메인 실행 상태(예: 해당 어플리케이션과 관련한 화면이 포어그라운드에 배치된 상태, 해당 어플리케이션에 정보 입력이 가능하도록 할당된 상태, 해당 어플리케이션의 오디오가 출력되도록 할당된 상태 등)인지 확인할 수 있다. 동작 505에서 어플리케이션 실행 상태가 지정된 상태이면, 동작 507에서 데이터 처리 모듈 170은 기입 모드에 따라 데이터 저장 처리를 수행할 수 있다. 동작 505에서 어플리케이션 실행 상태가 지정된 상태가 아닌 경우(예: 어플리케이션 실행이 백그라운드 프로세싱 상태, 복수의 실행 어플리케이션들 중 해당 어플리케이션 정보 입력이 할당되지 않은 상태, 복수의 실행 어플리케이션들 중 해당 어플리케이션의 오디오 출력이 할당되지 않은 상태 등), 동작 509에서 데이터 처리 모듈 170은 오더 모드에 따라 데이터 저장 처리를 제어할 수 있다.
데이터 저장 동작이 완료되면, 동작 511에서, 데이터 처리 모듈 170은 데이터 저장과 관련한 동작 종료 여부를 확인할 수 있다. 데이터 저장 동작 종료와 관련한 이벤트가 없으면, 데이터 처리 모듈 170은 동작 501 이전으로 분기하여 이하 과정을 재수행할 수 있다.
상술한 바와 같이, 프로세스 속성 지정을 통한 선택적인 기입 모드 적용과 관련하여, 데이터 처리 모듈 170은 프로세스 관리 구조체에 포어그라운드 또는 백그라운드 속성을 지정 할 수 있는 변수 지정을 처리할 수 있다. 예컨대, 데이터 처리 모듈 170은 프로세스 문맥에서 시스템 콜(System call)을 통해 파일 노드 또는 데이터 블록 변경 시, 시스템 콜을 수행하는 프로세스가 백그라운드 속성이면, 파일 노드에 기입 모드 플래그 셋업을 수행할 수 있다. 추가적으로 또는 대체적으로 데이터 처리 모듈 170은 파일 노드의 변경 내용을 러닝 트랜잭션 영역 33에 등록하는 동작에서 파일 노드의 기입 모드 플래그가 셋업되어 있고, 파일 노드의 데이터 크기가 지정된 값보다 클 경우 기입 모드에 따른 데이터 처리를 수행할 수 있다.
도 6은 다양한 실시 예에 따른 데이터 처리 방법 중 파일 크기에 따른 처리를 도시한다.
도 6을 참조하면, 데이터 처리 방법과 관련하여, 동작 601에서 데이터 처리 모듈 170은 데이터 저장 관련 이벤트가 있는지 확인할 수 있다. 동작 601에서 데이터 처리 모듈 170은 데이터 저장 관련 이벤트 발생이 없으면, 동작 609 이전으로 분기할 수 있다.
동작 601에서 데이터 저장 관련 이벤트가 발생하면, 동작 603에서 데이터 처리 모듈 170은 저장 처리할 파일의 크기가 지정 값 이상인지 확인할 수 있다. 저장 처리할 파일의 크기가 지정 값 이상인 경우 동작 605에서 데이터 처리 모듈 170은 파일이 기입 모드에 따라 저장 처리되도록 제어할 수 있다. 저장 처리할 파일의 크기가 지정 값 미만인 경우(또는 지정 값보다 작은 경우) 동작 607에서 데이터 처리 모듈 170은 파일이 오더 모드에 따라 저장 처리되도록 제어할 수 있다.
데이터 저장 처리가 완료되면 동작 609에서, 데이터 처리 모듈 170은 데이터 저장 종료와 관련한 이벤트가 발생하는지 확인할 수 있다. 데이터 저장 종료 관련 이벤트 발생이 없으면, 데이터 처리 모듈 170은 동작 601 이전으로 분기하여 이하 과정을 재수행할 수 있다.
상술한 바와 같이, 다양한 실시 예에 따른 데이터 처리 방법은 파일의 크기에 따라 기입 모드 또는 오더 모드를 수행함으로써, 파일 처리에 따른 지연이 발생하지 않도록 처리할 수 있다.
상술한 바와 같이, 다양한 실시 예에 따른 데이터 처리 방법은 장치 운용에 따른 파일을 메모리에 저장하는 동작, 상기 메모리에 저장된 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드 또는 오더 모드 중 어느 하나로 결정하여 상기 파일을 스토리지에 저장 처리하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 처리하는 동작은 상기 어플리케이션 실행 위치가 포어그라운드인 경우 상기 파일을 기입 모드에 따라 저장하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 처리하는 동작은 상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일을 오더 모드에 따라 저장하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 처리하는 동작은 상기 파일의 크기에 따라 상기 파일을 기입 모드 또는 오더 모드 중 어느 하나의 모드로 저장하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 저장하는 동작은 상기 파일의 크기가 지정된 크기 이상인 경우 상기 파일을 기입 모드로 처리하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 저장하는 동작은 상기 파일의 크기가 지정된 크기 이하인 경우 상기 파일을 오더 모드로 처리하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 처리하는 동작은 상기 어플리케이션 속성에 의해 기입 모드 처리가 결정되는 경우 파일 노드에 기입 모드 플래그 처리와 관련한 변수 정의 및 셋업을 수행하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 처리하는 동작은 상기 파일이 저장되는 위치의 디렉토리 속성을 확인하는 동작, 상기 디렉토리 속성이 기입 모드 설정인 경우 이를 상속하여 상기 파일의 속성을 기입 모드로 처리하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 처리하는 동작은 상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일의 크기를 확인하는 동작, 상기 파일의 크기가 지정된 값보다 큰 경우 상기 파일을 기입 모드로 처리하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 처리하는 동작은 상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일의 크기를 확인하는 동작, 상기 파일의 크기가 지정된 값보다 작은 경우 상기 파일을 오더 모드로 처리하는 동작을 포함할 수 있다.
도 7은 다양한 실시 예에 따른 데이터 저장 처리와 관련한 전자 장치의 인터페이스를 도시한다.
도 7을 참조하면, 전자 장치 100의 데이터 처리 모듈 170은 디스플레이 150에 데이터 저장 설정과 관련한 화면이 출력되도록 제어할 수 있다. 예컨대, 데이터 처리 모듈 170은 어플리케이션 별 데이터 저장 설정을 수행할 수 있는 메뉴 항목이나 아이콘, 데이터 크기 별 데이터 저장 설정을 수행할 수 있는 메뉴 항목이나 아이콘 중 적어도 하나를 제공할 수 있다. 데이터 처리 모듈 170은 어플리케이션 별 데이터 저장 설정과 관련한 입력 신호가 발생하면 상태 701에서와 같이 디스플레이 150에 어플리케이션 별 데이터 저장 설정이 가능한 화면을 제공할 수 있다. 데이터 처리 모듈 170은 전자 장치 100에 설치된 적어도 하나의 어플리케이션 항목들을 제공할 수 있다. 또는 데이터 처리 모듈 170은 특정 어플리케이션이 지원하는 데이터 생성 관련 루틴들을 항목들로 제공할 수 있다.
한 실시 예에 따르면, 데이터 처리 모듈 170은 특정 항목이 선택되면, 선택된 항목에 해당하는 어플리케이션에 의한 파일을 기입 모드 또는 오더 모드로 처리되도록 제어할 수 있다. 한 실시 예에 따르면, 데이터 처리 모듈 170은 선택된 항목의 어플리케이션이 백그라운드 프로세싱으로 동작하는 동안에 관련된 파일이 오더 모드로 처리되도록 제어하고, 포어그라운드 프로세싱으로 동작하는 동안에 관련된 파일이 기입 모드로 처리되도록 제어할 수 있다. 다양한 실시 예에 따르면, 데이터 처리 모듈 170은 선택된 항목의 어플리케이션이 백그라운드 프로세싱으로 동작하더라도 관련 파일을 기입 모드로 처리되도록 제어할 수도 있다. 데이터 처리 모듈 170은 상술한 처리 방식 설정과 관련하여, 항목 설정 시 안내 정보(예: 선택된 항목의 관련 파일이 기입 모드 또는 오더 모드로 처리되는 시점에 대한 정보)를 제공할 수 있다.
데이터 처리 모듈 170은 크기 별 데이터 저장 설정과 관련한 입력 신호가 발생하면 상태 703에서와 같이 디스플레이 150에 크기 별 데이터 저장 설정이 가능한 화면을 제공할 수 있다. 크기 별 데이터 저장 설정 가능 화면에서 해당 항목이 선택되면, 데이터 처리 모듈 170은 어플리케이션 관련 파일의 처리가 기입 모드로 처리되도록 제어할 수 있다. 다양한 실시 예에 따르면, 데이터 처리 모듈 170은 701 상태에서 특정 어플리케이션 항목이 선택되면 703 화면을 통해 데이터 크기 별 저장 처리에 대한 추가 설정이 가능하도록 지원할 수 있다.
도 8은 다양한 실시 예에 따른 전자 장치의 블록도이다.
도 8을 참조하면, 상기 전자 장치 800은, 예를 들면, 도 1에 도시된 전자 장치 100의 전체 또는 일부를 구성할 수 있다. 도 8을 참조하면, 상기 전자 장치 800은 하나 이상의 어플리케이션 프로세서(AP: application processor) 810(예: 상기 프로세서 120, 상기 데이터 처리 모듈 170 등), 통신 모듈 820(예: 상기 통신 인터페이스 160), SIM(subscriber identification module) 카드 824, 메모리 830(예: 상기 메모리 130, 상기 스토리지 180), 센서 모듈 840, 입력 장치 850(예: 상기 입출력 인터페이스 140), 디스플레이 860(상기 디스플레이 150), 인터페이스 870, 오디오 모듈 880(예: 상기 입출력 인터페이스 140), 카메라 모듈 891, 전력관리 모듈 895, 배터리 896, 인디케이터 897 및 모터 898을 포함할 수 있다.
상기 AP 810은 운영체제 또는 응용 프로그램을 구동하여 상기 AP 810에 연결된 다수의 하드웨어 또는 소프트웨어 구성요소들을 제어할 수 있고, 멀티미디어 데이터를 포함한 각종 데이터 처리 및 연산을 수행할 수 있다. 상기 AP 810는, 예를 들면, SoC(system on chip) 로 구현될 수 있다. 한 실시 예에 따르면, 상기 AP 810은 GPU(graphic processing unit, 미도시)를 더 포함할 수 있다.
상기 통신 모듈 820(예: 상기 통신 인터페이스 160)은 상기 전자 장치 800(예: 상기 전자 장치 100)과 네트워크를 통해 연결된 다른 전자 장치들(예: 전자 장치 102 또는 서버 106) 간의 통신에서 데이터 송수신을 수행할 수 있다. 한 실시 예에 따르면, 상기 통신 모듈 820은 셀룰러 모듈 821, Wifi 모듈 823, BT 모듈 825, GPS 모듈 827, NFC 모듈 828 및 RF(radio frequency) 모듈 829를 포함할 수 있다.
상기 셀룰러 모듈 821은 통신망(예: LTE, LTE-A, CDMA, WCDMA, UMTS, WiBro 또는 GSM 등)을 통해서 음성 통화, 영상 통화, 문자 서비스 또는 인터넷 서비스 등을 제공할 수 있다. 또한, 상기 셀룰러 모듈 821은, 예를 들면, 가입자 식별 모듈(예: SIM 카드 824)을 이용하여 통신 네트워크 내에서 전자 장치의 구별 및 인증을 수행할 수 있다. 한 실시 예에 따르면, 상기 셀룰러 모듈 821은 상기 AP 810이 제공할 수 있는 기능 중 적어도 일부 기능을 수행할 수 있다. 예를 들면, 상기 셀룰러 모듈 821은 멀티 미디어 제어 기능의 적어도 일부를 수행할 수 있다.
한 실시 예에 따르면, 상기 셀룰러 모듈 821은 커뮤니케이션 프로세서(CP: communication processor)를 포함할 수 있다. 또한, 상기 셀룰러 모듈 821은, 예를 들면, SoC로 구현될 수 있다. 도 8에서는 상기 셀룰러 모듈 821(예: 커뮤니케이션 프로세서), 상기 메모리 830 또는 상기 전력관리 모듈 895 등의 구성요소들이 상기 AP 810과 별개의 구성요소로 도시되어 있으나, 한 실시 예에 따르면, 상기 AP 810이 전술한 구성요소들의 적어도 일부(예: 셀룰러 모듈 821)를 포함하도록 구현될 수 있다.
한 실시 예에 따르면, 상기 AP 810 또는 상기 셀룰러 모듈 821(예: 커뮤니케이션 프로세서)은 각각에 연결된 비휘발성 메모리 또는 다른 구성요소 중 적어도 하나로부터 수신한 명령 또는 데이터를 휘발성 메모리에 로드(load)하여 처리할 수 있다. 또한, 상기 AP 810 또는 상기 셀룰러 모듈 821은 다른 구성요소 중 적어도 하나로부터 수신하거나 다른 구성요소 중 적어도 하나에 의해 생성된 데이터를 비휘발성 메모리에 저장(store)할 수 있다.
상기 Wifi 모듈 823, 상기 BT 모듈 825, 상기 GPS 모듈 827 또는 상기 NFC 모듈 828 각각은, 예를 들면, 해당하는 모듈을 통해서 송수신되는 데이터를 처리하기 위한 프로세서를 포함할 수 있다. 도 8에서는 셀룰러 모듈 821, Wifi 모듈 823, BT 모듈 825, GPS 모듈 827 또는 NFC 모듈 828이 각각 별개의 블록으로 도시되었으나, 한 실시 예에 따르면, 셀룰러 모듈 821, Wifi 모듈 823, BT 모듈 825, GPS 모듈 827 또는 NFC 모듈 828 중 적어도 일부(예: 두 개 이상)는 하나의 integrated chip(IC) 또는 IC 패키지 내에 포함될 수 있다. 예를 들면, 셀룰러 모듈 821, Wifi 모듈 823, BT 모듈 825, GPS 모듈 827 또는 NFC 모듈 828 각각에 대응하는 프로세서들 중 적어도 일부(예: 셀룰러 모듈 821에 대응하는 커뮤니케이션 프로세서 및 Wifi 모듈 823에 대응하는 Wifi 프로세서)는 하나의 SoC로 구현될 수 있다.
상기 RF 모듈 829는 데이터의 송수신, 예를 들면, RF 신호의 송수신을 할 수 있다. 상기 RF 모듈 829는, 도시되지는 않았으나, 예를 들면, 트랜시버(transceiver), PAM(power amp module), 주파수 필터(frequency filter) 또는 LNA(low noise amplifier) 등을 포함할 수 있다. 또한, 상기 RF 모듈 829는 무선 통신에서 자유 공간상의 전자파를 송수신하기 위한 부품, 예를 들면, 도체 또는 도선 등을 더 포함할 수 있다. 도 8에서는 셀룰러 모듈 821, Wifi 모듈 823, BT 모듈 825, GPS 모듈 827 및 NFC 모듈 828이 하나의 RF 모듈 829을 서로 공유하는 것으로 도시되어 있으나, 한 실시 예에 따르면, 셀룰러 모듈 821, Wifi 모듈 823, BT 모듈 825, GPS 모듈 827 또는 NFC 모듈 828 중 적어도 하나는 별개의 RF 모듈을 통하여 RF 신호의 송수신을 수행할 수 있다.
상기 SIM 카드 824는 가입자 식별 모듈을 포함하는 카드일 수 있으며, 전자 장치의 특정 위치에 형성된 슬롯에 삽입될 수 있다. 상기 SIM 카드 824는 고유한 식별 정보(예: ICCID(integrated circuit card identifier)) 또는 가입자 정보(예: IMSI(international mobile subscriber identity))를 포함할 수 있다. SIM 카드 824는 앞서 설명한 스토리지 180에 해당할 수 있다.
상기 메모리 830은 내장 메모리 832 또는 외장 메모리 834를 포함할 수 있다. 상기 내장 메모리 832는, 예를 들면, 휘발성 메모리(예를 들면, DRAM(dynamic RAM), SRAM(static RAM), SDRAM(synchronous dynamic RAM) 등) (예: 상기 메모리 130) 또는 비휘발성 메모리(non-volatile Memory, 예를 들면, OTPROM(one time programmable ROM), PROM(programmable ROM), EPROM(erasable and programmable ROM), EEPROM(electrically erasable and programmable ROM), mask ROM, flash ROM, NAND flash memory, NOR flash memory 등)(예: 상기 스토리지 180) 중 적어도 하나를 포함할 수 있다.
한 실시 예에 따르면, 상기 내장 메모리 832는 Solid State Drive (SSD)일 수 있다. 상기 외장 메모리 834는 flash drive, 예를 들면, CF(compact flash), SD(secure digital), Micro-SD(micro secure digital), Mini-SD(mini secure digital), xD(extreme digital) 또는 Memory Stick 등을 더 포함할 수 있다. 상기 외장 메모리 834는 다양한 인터페이스를 통하여 상기 전자 장치 800과 기능적으로 연결될 수 있다. 한 실시 예에 따르면, 상기 전자 장치 800은 하드 드라이브와 같은 저장 장치(또는 저장 매체)를 더 포함할 수 있다.
상기 센서 모듈 840은 물리량을 계측하거나 전자 장치 800의 작동 상태를 감지하여, 계측 또는 감지된 정보를 전기 신호로 변환할 수 있다. 상기 센서 모듈 840은, 예를 들면, 제스처 센서 840A, 자이로 센서 840B, 기압 센서 840C, 마그네틱 센서 840D, 가속도 센서 840E, 그립 센서 840F, 근접 센서 840G, color 센서 840H(예: RGB(red, green, blue) 센서), 생체 센서 840I, 온/습도 센서 840J, 조도 센서 840K 또는 UV(ultra violet) 센서 840M 중의 적어도 하나를 포함할 수 있다. 추가적으로 또는 대체적으로, 상기 센서 모듈 840은, 예를 들면, 후각 센서(E-nose sensor, 미도시), EMG 센서(electromyography sensor, 미도시), EEG 센서(electroencephalogram sensor, 미도시), ECG 센서(electrocardiogram sensor, 미도시), IR(infra-red) 센서(미도시), 홍채 센서(미도시) 또는 지문 센서(미도시) 등을 포함할 수 있다. 상기 센서 모듈 840은 그 안에 속한 적어도 하나 이상의 센서들을 제어하기 위한 제어 회로를 더 포함할 수 있다.
상기 입력 장치 850은 터치 패널(touch panel) 852, (디지털) 펜 센서(pen sensor) 854, 키(key) 856 또는 초음파(ultrasonic) 입력 장치 858을 포함할 수 있다. 상기 터치 패널 852은, 예를 들면, 정전식, 감압식, 적외선 방식 또는 초음파 방식 중 적어도 하나의 방식으로 터치 입력을 인식할 수 있다. 또한, 상기 터치 패널 852는 제어 회로를 더 포함할 수도 있다. 정전식의 경우, 물리적 접촉 또는 근접 인식이 가능하다. 상기 터치 패널 852는 택타일 레이어(tactile layer)를 더 포함할 수도 있다. 이 경우, 상기 터치 패널 852는 사용자에게 촉각 반응을 제공할 수 있다.
상기 (디지털) 펜 센서 854는, 예를 들면, 사용자의 터치 입력을 받는 것과 동일 또는 유사한 방법 또는 별도의 인식용 쉬트(sheet)를 이용하여 구현될 수 있다. 상기 키 856는, 예를 들면, 물리적인 버튼, 광학식 키 또는 키패드를 포함할 수 있다. 상기 초음파(ultrasonic) 입력 장치 858는 초음파 신호를 발생하는 입력 도구를 통해, 전자 장치 800에서 마이크(예: 마이크 888)로 음파를 감지하여 데이터를 확인할 수 있는 장치로서, 무선 인식이 가능하다. 한 실시 예에 따르면, 상기 전자 장치 800은 상기 통신 모듈 820을 이용하여 이와 연결된 외부 장치(예: 컴퓨터 또는 서버)로부터 사용자 입력을 수신할 수도 있다.
상기 디스플레이 860(예: 상기 디스플레이 150)은 패널 862, 홀로그램 장치 864 또는 프로젝터 866을 포함할 수 있다. 상기 패널 862은, 예를 들면, LCD(liquid-crystal display) 또는 AM-OLED(active-matrix organic light-emitting diode) 등일 수 있다. 상기 패널 862은, 예를 들면, 유연하게(flexible), 투명하게(transparent) 또는 착용할 수 있게(wearable) 구현될 수 있다. 상기 패널 862은 상기 터치 패널 852와 하나의 모듈로 구성될 수도 있다. 상기 홀로그램 장치 864는 빛의 간섭을 이용하여 입체 영상을 허공에 보여줄 수 있다. 상기 프로젝터 866은 스크린에 빛을 투사하여 영상을 표시할 수 있다. 상기 스크린은, 예를 들면, 상기 전자 장치 800의 내부 또는 외부에 위치할 수 있다. 한 실시 예에 따르면, 상기 디스플레이 860은 상기 패널 862, 상기 홀로그램 장치 864, 또는 프로젝터 866을 제어하기 위한 제어 회로를 더 포함할 수 있다.
상기 인터페이스 870은, 예를 들면, HDMI(high-definition multimedia interface) 872, USB(universal serial bus) 874, 광 인터페이스(optical interface) 876 또는 D-sub(D-subminiature) 878을 포함할 수 있다. 상기 인터페이스 870은, 예를 들면, 도 1에 도시된 통신 인터페이스 160에 포함될 수 있다. 추가적으로 또는 대체적으로, 상기 인터페이스 870은, 예를 들면, MHL(mobile high-definition link) 인터페이스, SD(secure Digital) 카드/MMC(multi-media card) 인터페이스 또는 IrDA(infrared data association) 규격 인터페이스를 포함할 수 있다.
상기 오디오 모듈 880은 소리(sound)와 전기신호를 쌍방향으로 변환시킬 수 있다. 상기 오디오 모듈 880의 적어도 일부 구성요소는, 예를 들면, 도 1 에 도시된 입출력 인터페이스 140에 포함될 수 있다. 상기 오디오 모듈 880은, 예를 들면, 스피커 882, 리시버 884, 이어폰 886 또는 마이크 888 등을 통해 입력 또는 출력되는 소리 정보를 처리할 수 있다.
상기 카메라 모듈 891은 정지 영상 및 동영상을 촬영할 수 있는 장치로서, 한 실시 예에 따르면, 하나 이상의 이미지 센서(예: 전면 센서 또는 후면 센서), 렌즈(미도시), ISP(image signal processor, 미도시) 또는 플래쉬 (flash, 미도시)(예: LED 또는 xenon lamp)를 포함할 수 있다.
상기 전력 관리 모듈 895는 상기 전자 장치 800의 전력을 관리할 수 있다. 도시하지는 않았으나, 상기 전력 관리 모듈 895는, 예를 들면, PMIC(power management integrated circuit), 충전 IC(charger integrated circuit) 또는 배터리 또는 연료 게이지(battery or fuel gauge)를 포함할 수 있다.
상기 PMIC는, 예를 들면, 집적회로 또는 SoC 반도체 내에 탑재될 수 있다. 충전 방식은 유선과 무선으로 구분될 수 있다. 상기 충전 IC는 배터리를 충전시킬 수 있으며, 충전기로부터의 과전압 또는 과전류 유입을 방지할 수 있다. 한 실시 예에 따르면, 상기 충전 IC는 유선 충전 방식 또는 무선 충전 방식 중 적어도 하나를 위한 충전 IC를 포함할 수 있다. 무선 충전 방식으로는, 예를 들면, 자기공명 방식, 자기유도 방식 또는 전자기파 방식 등이 있으며, 무선 충전을 위한 부가적인 회로, 예를 들면, 코일 루프, 공진 회로 또는 정류기 등의 회로가 추가될 수 있다.
상기 배터리 게이지는, 예를 들면, 상기 배터리 896의 잔량, 충전 중 전압, 전류 또는 온도를 측정할 수 있다. 상기 배터리 896는 전기를 저장 또는 생성할 수 있고, 그 저장 또는 생성된 전기를 이용하여 상기 전자 장치 800에 전원을 공급할 수 있다. 상기 배터리 896는, 예를 들면, 충전식 전지(rechargeable battery) 또는 태양 전지(solar battery)를 포함할 수 있다.
상기 인디케이터 897은 상기 전자 장치 800 혹은 그 일부(예: 상기 AP 810)의 특정 상태, 예를 들면, 부팅 상태, 메시지 상태 또는 충전 상태 등을 표시할 수 있다. 상기 모터 898은 전기적 신호를 기계적 진동으로 변환할 수 있다. 도시되지는 않았으나, 상기 전자 장치 800은 모바일 TV 지원을 위한 처리 장치(예: GPU)를 포함할 수 있다. 상기 모바일 TV지원을 위한 처리 장치는, 예를 들면, DMB(digital multimedia broadcasting), DVB(digital video broadcasting) 또는 미디어플로우(media flow) 등의 규격에 따른 미디어 데이터를 처리할 수 있다.
상술한 전자 장치 800은 휘발성 메모리에 저장된 데이터(예: 파일)와 관련한 어플리케이션의 속성 또는 파일 속성 중 적어도 하나에 대응하여 비휘발성 메모리에 데이터를 이동 저장하는 동작을 기입 모드 또는 오더 모드 중 어느 하나를 선택적으로 처리되도록 제어할 수 있다. 예컨대, 전자 장치 800은 어플리케이션이 백그라운드 프로세싱으로 동작하는 경우 관련 데이터의 크기를 확인하고, 크기가 지정된 크기 이상이면 기입 모드 방식으로 저장되도록 제어할 수 있다. 또한 전자 장치 800은 어플리케이션이 포어그라운드 프로세싱 방식으로 동작하는 경우 관련 데이터를 기입 모드 방식으로 저장되도록 제어할 수 있다. 기타, 데이터 처리와 관련하여 전자 장치 800은 앞서 설명한 다양한 방식에 따른 데이터 처리를 지원할 수 있다.
본 발명의 다양한 실시 예에 따른 전자 장치의 전술한 구성요소들 각각은 하나 또는 그 이상의 부품(component)으로 구성될 수 있으며, 해당 구성 요소의 명칭은 전자 장치의 종류에 따라서 달라질 수 있다. 본 발명의 다양한 실시 예에 따른 전자 장치는 전술한 구성요소 중 적어도 하나를 포함하여 구성될 수 있으며, 일부 구성요소가 생략되거나 또는 추가적인 다른 구성요소를 더 포함할 수 있다. 또한, 본 발명의 다양한 실시 예에 따른 전자 장치의 구성 요소들 중 일부가 결합되어 하나의 개체(entity)로 구성됨으로써, 결합되기 이전의 해당 구성 요소들의 기능을 동일하게 수행할 수 있다.
본 발명의 다양한 실시 예에 사용된 용어 “모듈”은, 예를 들어, 하드웨어, 소프트웨어 또는 펌웨어(firmware) 중 하나 또는 둘 이상의 조합을 포함하는 단위(unit)를 의미할 수 있다. “모듈”은 예를 들어, 유닛(unit), 로직(logic), 논리 블록(logical block), 부품(component) 또는 회로(circuit) 등의 용어와 바꾸어 사용(interchangeably use)될 수 있다. “모듈”은, 일체로 구성된 부품의 최소 단위 또는 그 일부가 될 수 있다. “모듈”은 하나 또는 그 이상의 기능을 수행하는 최소 단위 또는 그 일부가 될 수도 있다. “모듈”은 기계적으로 또는 전자적으로 구현될 수 있다. 예를 들면, 본 발명의 다양한 실시 예에 따른 “모듈”은, 알려졌거나 앞으로 개발될, 어떤 동작들을 수행하는 ASIC(application-specific integrated circuit) 칩, FPGAs(field-programmable gate arrays) 또는 프로그램 가능 논리 장치(programmable-logic device) 중 적어도 하나를 포함할 수 있다.
다양한 실시 예에 따르면, 본 발명의 다양한 실시 예에 따른 장치(예: 모듈들 또는 그 기능들) 또는 방법(예: 동작들)의 적어도 일부는, 예컨대, 프로그래밍 모듈의 형태로 컴퓨터로 읽을 수 있는 저장매체(computer-readable storage media)에 저장된 명령어로 구현될 수 있다. 상기 명령어는, 하나 이상의 프로세서 (예: 상기 프로세서 120)에 의해 실행될 경우, 상기 하나 이상의 프로세서가 상기 명령어에 해당하는 기능을 수행할 수 있다. 컴퓨터로 읽을 수 있는 저장매체는, 예를 들면, 상기 메모리 130가 될 수 있다. 상기 프로그래밍 모듈의 적어도 일부는, 예를 들면, 상기 프로세서 120에 의해 구현(implement)(예: 실행)될 수 있다. 상기 프로그래밍 모듈 의 적어도 일부는 하나 이상의 기능을 수행하기 위한, 예를 들면, 모듈, 프로그램, 루틴, 명령어 세트 (sets of instructions) 또는 프로세스 등을 포함할 수 있다.
상기 컴퓨터로 판독 가능한 기록 매체에는 하드디스크, 플로피디스크 및 자기 테이프와 같은 마그네틱 매체(Magnetic Media)와, CD-ROM(Compact Disc Read Only Memory), DVD(Digital Versatile Disc)와 같은 광기록 매체(Optical Media)와, 플롭티컬 디스크(Floptical Disk)와 같은 자기-광 매체(Magneto-Optical Media)와, 그리고 ROM(Read Only Memory), RAM(Random Access Memory), 플래시 메모리 등과 같은 프로그램 명령(예: 프로그래밍 모듈)을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함될 수 있다. 또한, 프로그램 명령에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함할 수 있다. 상술한 하드웨어 장치는 본 발명의 다양한 실시 예의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지다.
본 발명의 다양한 실시 예에 따른 모듈 또는 프로그래밍 모듈은 전술한 구성요소들 중 적어도 하나 이상을 포함하거나, 일부가 생략되거나, 또는 추가적인 다른 구성요소를 더 포함할 수 있다. 본 발명의 다양한 실시 예에 따른 모듈, 프로그래밍 모듈 또는 다른 구성요소에 의해 수행되는 동작들은 순차적, 병렬적, 반복적 또는 휴리스틱(heuristic)한 방법으로 실행될 수 있다. 또한, 일부 동작은 다른 순서로 실행되거나, 생략되거나, 또는 다른 동작이 추가될 수 있다.
그리고 본 명세서와 도면에 개시된 본 발명의 실시 예들은 본 발명의 실시 예에 따른 의 기술 내용을 쉽게 설명하고 본 발명의 실시 예의 이해를 돕기 위해 특정 예를 제시한 것일 뿐이며, 본 발명의 실시 예의 범위를 한정하고자 하는 것은 아니다. 따라서 본 발명의 다양한 실시 예의 범위는 여기에 개시된 실시 예들 이외에도 본 발명의 다양한 실시 예의 기술적 사상을 바탕으로 도출되는 모든 변경 또는 변형된 형태가 본 발명의 다양한 실시 예의 범위에 포함되는 것으로 해석되어야 한다.
본 발명의 다양한 실시 예에 따른 전자 장치의 전술한 구성요소들 각각은 하나 또는 그 이상의 부품(component)으로 구성될 수 있으며, 해당 구성 요소의 명칭은 전자 장치의 종류에 따라서 달라질 수 있다. 본 발명의 다양한 실시 예에 따른 전자 장치는 전술한 구성요소 중 적어도 하나를 포함하여 구성될 수 있으며, 일부 구성요소가 생략되거나 또는 추가적인 다른 구성요소를 더 포함할 수 있다. 또한, 본 발명의 다양한 실시 예에 따른 전자 장치의 구성 요소들 중 일부가 결합되어 하나의 개체(entity)로 구성됨으로써, 결합되기 이전의 해당 구성 요소들의 기능을 동일하게 수행할 수 있다.
본 발명의 다양한 실시 예에 사용된 용어 “모듈”은, 예를 들어, 하드웨어, 소프트웨어 또는 펌웨어(firmware) 중 하나 또는 둘 이상의 조합을 포함하는 단위(unit)를 의미할 수 있다. “모듈”은 예를 들어, 유닛(unit), 로직(logic), 논리 블록(logical block), 부품(component) 또는 회로(circuit) 등의 용어와 바꾸어 사용(interchangeably use)될 수 있다. “모듈”은, 일체로 구성된 부품의 최소 단위 또는 그 일부가 될 수 있다. “모듈”은 하나 또는 그 이상의 기능을 수행하는 최소 단위 또는 그 일부가 될 수도 있다. “모듈”은 기계적으로 또는 전자적으로 구현될 수 있다. 예를 들면, 본 발명의 다양한 실시 예에 따른 “모듈”은, 알려졌거나 앞으로 개발될, 어떤 동작들을 수행하는 ASIC(application-specific integrated circuit) 칩, FPGAs(field-programmable gate arrays) 또는 프로그램 가능 논리 장치(programmable-logic device) 중 적어도 하나를 포함할 수 있다.
다양한 실시 예에 따르면, 본 발명의 다양한 실시 예에 따른 장치(예: 모듈들 또는 그 기능들) 또는 방법(예: 동작들)의 적어도 일부는, 예컨대, 프로그래밍 모듈의 형태로 컴퓨터로 읽을 수 있는 저장매체(computer-readable storage media)에 저장된 명령어로 구현될 수 있다. 상기 명령어는, 하나 이상의 프로세서 (예: 상기 프로세서)에 의해 실행될 경우, 상기 하나 이상의 프로세서가 상기 명령어에 해당하는 기능을 수행할 수 있다. 컴퓨터로 읽을 수 있는 저장매체는, 예를 들면, 상기 메모리가 될 수 있다. 상기 프로그래밍 모듈의 적어도 일부는, 예를 들면, 상기 프로세서에 의해 구현(implement)(예: 실행)될 수 있다. 상기 프로그래밍 모듈 의 적어도 일부는 하나 이상의 기능을 수행하기 위한, 예를 들면, 모듈, 프로그램, 루틴, 명령어 세트 (sets of instructions) 또는 프로세스 등을 포함할 수 있다.
다양한 실시 예에 따른 컴퓨터 기록 매체는 프로그래밍 모듈의 형태로 컴퓨터로 읽을 수 있는 저장매체(computer-readable storage media)에 저장된 명령어로서, 상기 명령어는, 장치 운용에 따른 파일을 메모리에 저장하는 동작, 상기 메모리에 저장된 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드 또는 오더 모드 중 어느 하나로 결정하여 상기 파일을 스토리지에 저장 처리하는 동작을 처리할 수 있다.
상기 컴퓨터로 판독 가능한 기록 매체에는 하드디스크, 플로피디스크 및 자기 테이프와 같은 마그네틱 매체(Magnetic Media)와, CD-ROM(Compact Disc Read Only Memory), DVD(Digital Versatile Disc)와 같은 광기록 매체(Optical Media)와, 플롭티컬 디스크(Floptical Disk)와 같은 자기-광 매체(Magneto-Optical Media)와, 그리고 ROM(Read Only Memory), RAM(Random Access Memory), 플래시 메모리 등과 같은 프로그램 명령(예: 프로그래밍 모듈)을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함될 수 있다. 또한, 프로그램 명령에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함할 수 있다. 상술한 하드웨어 장치는 본 발명의 다양한 실시 예의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지다.
본 발명의 다양한 실시 예에 따른 모듈 또는 프로그래밍 모듈은 전술한 구성요소들 중 적어도 하나 이상을 포함하거나, 일부가 생략되거나, 또는 추가적인 다른 구성요소를 더 포함할 수 있다. 본 발명의 다양한 실시 예에 따른 모듈, 프로그래밍 모듈 또는 다른 구성요소에 의해 수행되는 동작들은 순차적, 병렬적, 반복적 또는 휴리스틱(heuristic)한 방법으로 실행될 수 있다. 또한, 일부 동작은 다른 순서로 실행되거나, 생략되거나, 또는 다른 동작이 추가될 수 있다.
그리고 본 명세서와 도면에 개시된 본 발명의 실시 예들은 본 발명의 실시 예에 따른 의 기술 내용을 쉽게 설명하고 본 발명의 실시 예의 이해를 돕기 위해 특정 예를 제시한 것일 뿐이며, 본 발명의 실시 예의 범위를 한정하고자 하는 것은 아니다. 따라서 본 발명의 다양한 실시 예의 범위는 여기에 개시된 실시 예들 이외에도 본 발명의 다양한 실시 예의 기술적 사상을 바탕으로 도출되는 모든 변경 또는 변형된 형태가 본 발명의 다양한 실시 예의 범위에 포함되는 것으로 해석되어야 한다.
100 : 전자 장치
110 : 버스
120 : 프로세서 130 : 메모리
140 : 입출력 인터페이스 150 : 디스플레이
160 : 통신 인터페이스 170 : 데이터 처리 모듈
180 : 스토리지
120 : 프로세서 130 : 메모리
140 : 입출력 인터페이스 150 : 디스플레이
160 : 통신 인터페이스 170 : 데이터 처리 모듈
180 : 스토리지
Claims (20)
- 장치 운용에 따른 파일을 저장하는 메모리;
상기 메모리에 저장된 파일의 저널링을 지원하는 스토리지;
상기 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드(writeback mode) 또는 오더 모드(ordered mode) 중 어느 하나의 모드로 처리하는 데이터 처리 모듈;을 포함하는 전자 장치. - 제1항에 있어서,
상기 데이터 처리 모듈은
상기 어플리케이션 실행 위치가 포어그라운드인 경우 상기 파일을 기입 모드에 따라 저장되도록 제어하는 전자 장치. - 제1항에 있어서,
상기 데이터 처리 모듈은
상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일을 오더 모드에 따라 저장되도록 제어하는 전자 장치. - 제1항에 있어서,
상기 데이터 처리 모듈은
상기 파일의 크기에 따라 상기 파일을 기입 모드 또는 오더 모드 중 어느 하나의 모드로 저장 처리하는 전자 장치. - 제4항에 있어서,
상기 데이터 처리 모듈은
상기 파일의 크기가 지정된 크기 이상인 경우 상기 파일을 기입 모드로 처리하는 전자 장치. - 제4항에 있어서,
상기 데이터 처리 모듈은
상기 파일의 크기가 지정된 크기 미만인 경우 상기 파일을 오더 모드로 처리하는 전자 장치. - 제1항에 있어서,
상기 데이터 처리 모듈은
상기 어플리케이션 속성에 의해 기입 모드 처리가 결정되는 경우 파일 노드에 기입 모드 플래그 처리와 관련한 변수 정의 및 셋업을 수행하는 전자 장치. - 제1항에 있어서,
상기 데이터 처리 모듈은
상기 파일이 저장되는 위치의 디렉토리 속성을 확인하고, 상기 디렉토리 속성이 기입 모드 설정인 경우 이를 상속하여 상기 파일의 속성을 기입 모드 처리로 결정하는 전자 장치. - 제1항에 있어서,
상기 데이터 처리 모듈은
상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일의 크기를 확인하고, 상기 파일의 크기가 지정된 값보다 큰 경우 상기 파일을 기입 모드로 처리하는 전자 장치. - 제1항에 있어서,
상기 데이터 처리 모듈은
상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일의 크기를 확인하고, 상기 파일의 크기가 지정된 값보다 작은 경우 상기 파일을 오더 모드로 처리하는 전자 장치. - 장치 운용에 따른 파일을 메모리에 저장하는 동작;
상기 메모리에 저장된 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드(writeback mode) 또는 오더 모드(ordered mode) 중 어느 하나로 결정하여 상기 파일을 스토리지에 저장 처리하는 동작;을 포함하는 데이터 처리 방법. - 제11항에 있어서,
상기 처리하는 동작은
상기 어플리케이션 실행 위치가 포어그라운드인 경우 상기 파일을 기입 모드에 따라 저장하는 동작;을 포함하는 데이터 처리 방법. - 제11항에 있어서,
상기 처리하는 동작은
상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일을 오더 모드에 따라 저장하는 동작;을 포함하는 데이터 처리 방법. - 제11항에 있어서,
상기 처리하는 동작은
상기 파일의 크기에 따라 상기 파일을 기입 모드 또는 오더 모드 중 어느 하나의 모드로 저장하는 동작;을 포함하는 데이터 처리 방법. - 제14항에 있어서,
상기 저장하는 동작은
상기 파일의 크기가 지정된 크기 이상인 경우 상기 파일을 기입 모드로 처리하는 동작;을 포함하는 데이터 처리 방법. - 제14항에 있어서,
상기 저장하는 동작은
상기 파일의 크기가 지정된 크기 미만인 경우 상기 파일을 오더 모드로 처리하는 동작;을 포함하는 데이터 처리 방법. - 제11항에 있어서,
상기 처리하는 동작은
상기 어플리케이션 속성에 의해 기입 모드 처리가 결정되는 경우 파일 노드에 기입 모드 플래그 처리와 관련한 변수 정의 및 셋업을 수행하는 동작;을 포함하는 데이터 처리 방법. - 제11항에 있어서,
상기 처리하는 동작은
상기 파일이 저장되는 위치의 디렉토리 속성을 확인하는 동작;
상기 디렉토리 속성이 기입 모드 설정인 경우 이를 상속하여 상기 파일의 속성을 기입 모드로 처리하는 동작;을 포함하는 데이터 처리 방법. - 제11항에 있어서,
상기 처리하는 동작은
상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일의 크기를 확인하고, 상기 파일 크기가 지정된 값보다 큰 경우 상기 파일을 기입 모드로 처리하는 동작;
상기 어플리케이션 실행 위치가 백그라운드인 경우 상기 파일의 크기를 확인하고, 상기 파일의 크기가 지정된 값보다 작은 경우 상기 파일을 오더 모드로 처리하는 동작;을 포함하는 데이터 처리 방법. - 프로그래밍 모듈의 형태로 컴퓨터로 읽을 수 있는 저장매체(computer-readable storage media)에 저장된 명령어로서,
상기 명령어는,
장치 운용에 따른 파일을 메모리에 저장하는 동작,
상기 메모리에 저장된 파일 관련 어플리케이션의 속성 또는 상기 파일의 속성 중 적어도 하나에 대응하여 상기 파일의 저널링 방식을 기입 모드 또는 오더 모드 중 어느 하나로 결정하여 상기 파일을 스토리지에 저장 처리하는 동작을 포함하는 컴퓨터 기록 매체.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020140069617A KR102312672B1 (ko) | 2014-06-09 | 2014-06-09 | 데이터 처리 방법 및 전자 장치 |
US14/734,539 US10042856B2 (en) | 2014-06-09 | 2015-06-09 | Method and electronic device for processing data |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020140069617A KR102312672B1 (ko) | 2014-06-09 | 2014-06-09 | 데이터 처리 방법 및 전자 장치 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20150141073A true KR20150141073A (ko) | 2015-12-17 |
KR102312672B1 KR102312672B1 (ko) | 2021-10-15 |
Family
ID=54769715
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020140069617A KR102312672B1 (ko) | 2014-06-09 | 2014-06-09 | 데이터 처리 방법 및 전자 장치 |
Country Status (2)
Country | Link |
---|---|
US (1) | US10042856B2 (ko) |
KR (1) | KR102312672B1 (ko) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2017209508A1 (ko) * | 2016-06-01 | 2017-12-07 | 삼성전자 주식회사 | 전자 장치 및 전자 장치의 파일 데이터 저널링 방법 |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR101674176B1 (ko) * | 2014-07-24 | 2016-11-08 | 성균관대학교산학협력단 | 파일 단위 순서 모드 저널링 기법을 이용한 fsync 시스템 호출 처리 장치 및 방법 |
CN110278219B (zh) * | 2018-03-14 | 2022-03-04 | 吉旗(成都)科技有限公司 | 过程性的物联网设备模拟工具和模拟方法 |
CN111898035B (zh) * | 2020-06-19 | 2023-10-31 | 深圳奇迹智慧网络有限公司 | 基于物联网的数据处理策略配置方法、装置和计算机设备 |
US12013820B1 (en) * | 2020-09-25 | 2024-06-18 | Amazon Technologies, Inc. | Dynamically changing journaling types for files in a distributed file system |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6523102B1 (en) * | 2000-04-14 | 2003-02-18 | Interactive Silicon, Inc. | Parallel compression/decompression system and method for implementation of in-memory compressed cache improving storage density and access speed for industry standard memory subsystems and in-line memory modules |
US20060230175A1 (en) * | 2005-03-23 | 2006-10-12 | De Vries Jeffrey | System and method for tracking changes to files in streaming applications |
KR100866513B1 (ko) * | 2007-02-16 | 2008-11-03 | 한국과학기술원 | 플래시 메모리 기반 저널링 파일 시스템을 이용한 데이터처리 방법 |
US20120179730A1 (en) * | 2009-07-10 | 2012-07-12 | Walter Slegers | Data Storage System and Method |
KR101258589B1 (ko) * | 2008-03-03 | 2013-05-02 | 삼성전자주식회사 | 저널링 파일 시스템에 따라 데이터를 기록한 정보저장매체,저널링 파일 시스템을 이용해서 데이터를 기록/복구하는방법 및 장치 |
Family Cites Families (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6067599A (en) * | 1997-05-29 | 2000-05-23 | International Business Machines Corporation | Time delayed auto-premigeration of files in a virtual data storage system |
US6412042B1 (en) * | 1999-11-17 | 2002-06-25 | Maxtor Corporation | System and method for improved disk drive performance and reliability |
GB2378278B (en) * | 2001-07-31 | 2003-09-10 | Sun Microsystems Inc | Live memory snapshot |
US8315973B1 (en) * | 2004-09-28 | 2012-11-20 | Symantec Operating Corporation | Method and apparatus for data moving in multi-device file systems |
US7386664B1 (en) * | 2004-10-13 | 2008-06-10 | Symantec Operation Corporation | Method and system for mirror storage element resynchronization in a storage virtualization device |
US7389382B2 (en) * | 2005-06-08 | 2008-06-17 | Cisco Technology, Inc. | ISCSI block cache and synchronization technique for WAN edge device |
US20070168405A1 (en) * | 2006-01-17 | 2007-07-19 | Ori Pomerantz | Self-optimizing network attached storage for multiple geographic locations |
US7818302B2 (en) * | 2007-03-09 | 2010-10-19 | Emc Corporation | System and method for performing file system checks on an active file system |
US8615496B2 (en) | 2007-10-19 | 2013-12-24 | Apple Inc. | File system reliability using journaling on a storage medium |
US8762347B1 (en) * | 2008-09-22 | 2014-06-24 | Symantec Corporation | Method and apparatus for processing transactional file system operations to enable point in time consistent file data recreation |
US8930424B2 (en) * | 2009-07-10 | 2015-01-06 | Tomtom International B.V. | Data storage system and method for protecting the system in case of power-failure |
US8352691B2 (en) * | 2010-08-17 | 2013-01-08 | International Business Machines Corporation | Facilitation of simultaneous storage initialization and data destage |
US20130326114A1 (en) * | 2012-05-30 | 2013-12-05 | Seagate Technology Llc | Write mitigation through fast reject processing |
US8930612B2 (en) * | 2012-05-31 | 2015-01-06 | Seagate Technology Llc | Background deduplication of data sets in a memory |
US8880476B2 (en) | 2012-06-28 | 2014-11-04 | International Business Machines Corporation | Low-overhead enhancement of reliability of journaled file system using solid state storage and de-duplication |
US20150178702A1 (en) * | 2013-12-18 | 2015-06-25 | PayRange Inc. | Method and device for multi-drop bus payment peripheral expansion |
US20150170136A1 (en) * | 2013-12-18 | 2015-06-18 | PayRange Inc. | Method and System for Performing Mobile Device-To-Machine Payments |
KR101584760B1 (ko) * | 2014-06-30 | 2016-01-22 | 성균관대학교산학협력단 | 순서 모드 저널링 파일 시스템을 위한 블록 그룹 단위 저널링 방법 및 장치 |
-
2014
- 2014-06-09 KR KR1020140069617A patent/KR102312672B1/ko active IP Right Grant
-
2015
- 2015-06-09 US US14/734,539 patent/US10042856B2/en active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6523102B1 (en) * | 2000-04-14 | 2003-02-18 | Interactive Silicon, Inc. | Parallel compression/decompression system and method for implementation of in-memory compressed cache improving storage density and access speed for industry standard memory subsystems and in-line memory modules |
US20060230175A1 (en) * | 2005-03-23 | 2006-10-12 | De Vries Jeffrey | System and method for tracking changes to files in streaming applications |
KR100866513B1 (ko) * | 2007-02-16 | 2008-11-03 | 한국과학기술원 | 플래시 메모리 기반 저널링 파일 시스템을 이용한 데이터처리 방법 |
KR101258589B1 (ko) * | 2008-03-03 | 2013-05-02 | 삼성전자주식회사 | 저널링 파일 시스템에 따라 데이터를 기록한 정보저장매체,저널링 파일 시스템을 이용해서 데이터를 기록/복구하는방법 및 장치 |
US20120179730A1 (en) * | 2009-07-10 | 2012-07-12 | Walter Slegers | Data Storage System and Method |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2017209508A1 (ko) * | 2016-06-01 | 2017-12-07 | 삼성전자 주식회사 | 전자 장치 및 전자 장치의 파일 데이터 저널링 방법 |
KR20170136366A (ko) * | 2016-06-01 | 2017-12-11 | 삼성전자주식회사 | 전자 장치 및 전자 장치의 파일 데이터 저널링 방법 |
Also Published As
Publication number | Publication date |
---|---|
US20150356112A1 (en) | 2015-12-10 |
KR102312672B1 (ko) | 2021-10-15 |
US10042856B2 (en) | 2018-08-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10261683B2 (en) | Electronic apparatus and screen display method thereof | |
US10025451B2 (en) | Method and electronic device for managing screen | |
KR102219861B1 (ko) | 화면 공유 방법 및 그 전자 장치 | |
KR102213190B1 (ko) | 홈스크린 구성 방법 및 이를 이용한 전자 장치 | |
US10402222B2 (en) | Task migration method and apparatus | |
KR20170086750A (ko) | 기능을 제어하는 방법 및 이를 지원하는 전자 장치 | |
US20150220247A1 (en) | Electronic device and method for providing information thereof | |
KR20150141313A (ko) | 전자 장치의 정보 처리 방법 및 장치 | |
KR102157858B1 (ko) | 전력 소모를 줄일 수 있는 전자 장치 및 방법 | |
US10432926B2 (en) | Method for transmitting contents and electronic device thereof | |
EP3026782A1 (en) | Method for charging control and an electronic device thereof | |
KR20150066876A (ko) | 사용자 인터페이스 제어 방법 및 그 전자 장치 | |
KR102312672B1 (ko) | 데이터 처리 방법 및 전자 장치 | |
KR102343642B1 (ko) | 데이터 운용 방법 및 전자 장치 | |
KR102241831B1 (ko) | 전자 장치 및 이의 운영 방법 | |
KR20150117968A (ko) | 입력방향에 따라 기능을 전환하는 전자 장치 및 방법 | |
KR20160029510A (ko) | 인덱스 처리 방법 및 장치 | |
KR20150086808A (ko) | 폴더 관리 방법 및 장치 | |
KR20180127831A (ko) | 전자 장치 및 그의 정보 공유 방법 | |
AU2015219606B2 (en) | Method of providing preview image regarding display setting for device | |
US20150356058A1 (en) | Method for displaying images and electronic device for implementing the same | |
KR102249745B1 (ko) | 전자 장치 및 이의 제어 방법 | |
KR20150099255A (ko) | 정보 표시 방법 및 이를 이용하는 전자 장치 | |
KR20150112252A (ko) | 전자 장치 및 이의 연결 방법 | |
KR102250777B1 (ko) | 컨텐츠 제공 방법 및 그 전자 장치 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
E902 | Notification of reason for refusal | ||
E902 | Notification of reason for refusal | ||
E701 | Decision to grant or registration of patent right |