KR102343642B1 - 데이터 운용 방법 및 전자 장치 - Google Patents

데이터 운용 방법 및 전자 장치 Download PDF

Info

Publication number
KR102343642B1
KR102343642B1 KR1020140094173A KR20140094173A KR102343642B1 KR 102343642 B1 KR102343642 B1 KR 102343642B1 KR 1020140094173 A KR1020140094173 A KR 1020140094173A KR 20140094173 A KR20140094173 A KR 20140094173A KR 102343642 B1 KR102343642 B1 KR 102343642B1
Authority
KR
South Korea
Prior art keywords
file
ramdisk
electronic device
volatile memory
data
Prior art date
Application number
KR1020140094173A
Other languages
English (en)
Other versions
KR20160012572A (ko
Inventor
이우중
정대호
Original Assignee
삼성전자주식회사
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 삼성전자주식회사 filed Critical 삼성전자주식회사
Priority to KR1020140094173A priority Critical patent/KR102343642B1/ko
Priority to CN201580037994.7A priority patent/CN106663053A/zh
Priority to US15/322,268 priority patent/US10459650B2/en
Priority to PCT/KR2015/007455 priority patent/WO2016013815A1/ko
Priority to EP15824756.9A priority patent/EP3173932A4/en
Publication of KR20160012572A publication Critical patent/KR20160012572A/ko
Application granted granted Critical
Publication of KR102343642B1 publication Critical patent/KR102343642B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/0643Management of files
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0238Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
    • G06F12/0246Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1415Saving, restoring, recovering or retrying at system level
    • G06F11/1417Boot up procedures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1415Saving, restoring, recovering or retrying at system level
    • G06F11/1441Resetting or repowering
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/16Error detection or correction of the data by redundancy in hardware
    • G06F11/20Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements
    • G06F11/2015Redundant power supplies
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0604Improving or facilitating administration, e.g. storage management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0625Power saving in storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/10Providing a specific technical effect
    • G06F2212/1016Performance improvement
    • G06F2212/1024Latency reduction
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/20Employing a main memory using a specific memory technology
    • G06F2212/202Non-volatile memory
    • G06F2212/2022Flash memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/22Employing cache memory using specific memory technology
    • G06F2212/225Hybrid cache memory, e.g. having both volatile and non-volatile portions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/72Details relating to flash memory management
    • G06F2212/7203Temporary buffering, e.g. using volatile buffer or dedicated buffer blocks

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Quality & Reliability (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Stored Programmes (AREA)

Abstract

다양한 실시 예는 메인 전원 공급 차단 시 데이터 기입 상태 유지와 관련한 전원을 공급받는 메모리의 예약 영역을 데이터 입출력 처리와 관련한 램디스크 파일 시스템으로 할당하는 동작, 상기 램디스크 파일 시스템의 파일 처리를 제어하는 동작을 포함하는 데이터 운용 방법 및 전자 장치를 개시한다. 또한 본 발명은 다른 다양한 실시예도 가능하다.

Description

데이터 운용 방법 및 전자 장치{Method and Electronic Device for operating data}
다양한 실시 예는 데이터 운용에 관한 것이다.
스마트 폰(Smart Phone) 및 태블릿(Tablet) 등의 전자 기기는 여러 가지 다양한 애플리케이션들을 통해 사용자에게 여러 가지 유용한 기능을 제공하고 있다. 이러한 전자 기기는 기능 수행에 따라 다양한 데이터가 운용된다.
데이터 운용과 관련하여, 전자 기기는 스토리지(예: 비휘발성 메모리)에 저장된 데이터를 메모리(예: 휘발성 메모리)에 이동 저장하거나, 메모리에 저장된 데이터를 스토리지에 이동 저장한다. 이러한 종래 파일 시스템 상에서 음악, 동영상, 사진 등의 사용자 데이터는 일반적으로 비동기 기입 방식(asynchronous write)에 따라 데이터를 저장하지만, 데이터베이스 파일이나 시스템 설정 파일 등은 스토리지 저장 완료를 보장하기 위해 동기 기입 방식(synchronous write)으로 저장한다. 종래의 저널링 파일 시스템에서는 시스템의 파일 변경에 대해 주기적으로 트랜젝션 (Transaction) 묶음 단위로 커밋(commit: 저널링 장치에 Transaction을 저장)을 진행한다. 따라서, 동기 기입 방식으로 저장되는 파일과 비동기 기입방식의 파일이 단일 트랜젝션에 포함될 경우 동기 기입 방식의 파일 업데이트가 비동기 기입방식으로 저장되는 파일의 업데이트 완료를 기다려야 하므로 응답시간이 증가하는 문제가 있다. 따라서, 다양한 실시 예는 동기 기입 방식 입출력과 비동기 기입 방식 입출력을 분리하여 수행하는 데이터 운용 방법 및 전자 장치를 제공한다.
다양한 실시 예에 따르면, 한 실시 예에 따른 데이터 운용 방법은 메모리의 예약 영역을 데이터 입출력 처리와 관련한 램디스크 파일 시스템으로 할당하는 동작, 상기 램디스크 파일 시스템의 파일 처리를 제어하는 동작을 포함할 수 있다.
한 실시 예에 따른 전자 장치는 예약 영역을 데이터 입출력 처리와 관련한 램디스크 파일 시스템으로 할당하는 메모리, 상기 램디스크 파일 시스템의 파일 처리를 제어하는 데이터 처리 모듈을 포함할 수 있다.
한 실시 예에 따른 컴퓨터 기록 매체는 프로그래밍 모듈의 형태로 컴퓨터로 읽을 수 있는 저장매체(computer-readable storage media)에 저장된 명령어로서, 상기 명령어는 메인 전원 공급 차단 시 데이터 기입 상태 유지와 관련한 전원을 공급받는 메모리의 예약 영역을 데이터 입출력 처리와 관련한 램디스크 파일 시스템으로 할당하는 동작, 상기 램디스크 파일 시스템의 파일 처리를 제어하는 동작을 포함할 수 있다.
다양한 실시 예에서 개시되는 데이터 운용 방법 및 전자 장치는 동기 기입 방식의 파일 입출력 최적화를 지원할 수 있다.
예컨대, 다양한 실시 예는 동기 기입 방식 입출력 및 비동기 기입 방식 입출력을 분리하여 수행함으로써 백그라운드 프로세싱 입출력에 의해 우선순위가 높은 동기 기입 방식 입출력의 응답 시간 저하를 최소화할 수 있다.
동기 기입 방식의 파일 입출력은 사용자 인터페이스 변경 시 유발되므로, 화면 터치 등을 통한 사용자 인터페이스 변경의 응답시간 최소화가 가능하다.
도 1은 다양한 실시 예에 따른 데이터 운용을 수행하는 전자 장치 관련 시스템을 도시한다.
도 2는 다양한 실시 예에 따른 전자 장치의 메모리와 스토리지의 일예를 도시한다.
도 3은 다양한 실시 예에 따른 데이터 운용 방법을 도시한다.
도 4는 다양한 실시 예에 따른 램디스크 운용 방법을 도시한다.
도 5는 다양한 실시 예에 따른 파일 시스템 복원 방법을 도시한다.
도 6은 다양한 실시 예에 따른 전자 장치의 블록도이다.
이하, 본 발명의 다양한 실시 예가 첨부된 도면과 연관되어 기재된다. 본 발명의 다양한 실시 예는 다양한 변경을 가할 수 있고 여러 가지 실시 예를 가질 수 있는바, 특정 실시 예들이 도면에 예시되고 관련된 상세한 설명이 기재되어 있다. 그러나 이는 본 발명의 다양한 실시 예를 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 발명의 다양한 실시 예의 사상 및 기술 범위에 포함되는 모든 변경 및/또는 균등물 내지 대체물을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 구성요소에 대해서는 유사한 참조 부호가 사용되었다.
본 발명의 다양한 실시 예 가운데 사용될 수 있는 "포함한다" 또는 "포함할 수 있다" 등의 표현은 개시된 해당 기능, 동작 또는 구성요소 등의 존재를 가리키며, 추가적인 하나 이상의 기능, 동작 또는 구성요소 등을 제한하지 않는다. 또한 본 발명의 다양한 실시 예에서, "포함하다" 또는 "가지다" 등의 용어는 명세서상에 기재된 특징, 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것이 존재함을 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.
본 발명의 다양한 실시 예에서 "또는" 또는 "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은 특정 데이터(예: 동영상 데이터, 게임 데이터, 텍스트 데이터 등)를 전자 장치 100 또는 외부 전자 장치 102 등에 제공할 수 있다. 서버 장치 106이 전자 장치 100에 제공한 데이터는 메모리 130 또는 스토리지 180 중 적어도 하나에 저장될 수 있다. 한 실시 예에 따르면, 서버 장치 106이 제공한 특정 데이터는 메모리 130에 일시적으로 저장될 수 있다. 또는 서버 장치 106이 제공한 특정 데이터는 스토리지 180에 저장될 수도 있다. 다양한 실시 예에 따르면, 서버 장치 106이 제공한 특정 데이터(예: 일정 크기 이상의 대용량 데이터)는 메모리 130에 일시적으로 저장된 후 스토리지 180에 저장될 수 있다. 또는 서버 장치 106이 제공한 특정 데이터는 메모리 130에 반영구적으로 저장될 수 있다. 한 실시 예에 따르면, 서버 장치 106과 전자 장치 100 간에 송수신되는 데이터 중 동기 기입 방식으로 운용되는 데이터의 입출력 또는 저널링은 메모리 130의 배터리 전원 공급을 지원받는 지정된 영역 예컨대, 램디스크를 통해 처리될 수 있다. 서버 장치 106과 전자 장치 100 간에 송수신되는 데이터 중 비동기 기입 방식으로 운용되는 데이터의 입출력 또는 저널링은 스토리지 180 기반으로 처리될 수 있다.
전자 장치 102는 전자 장치 100의 통신 인터페이스 160과 통신 채널을 형성할 수 있다. 예컨대, 전자 장치 102는 통신 인터페이스 160과 근거리 통신 채널 또는 유선 통신 채널을 형성할 수 있다. 한 실시 예에 따르면, 전자 장치 102는 통신 인터페이스 160과 블루투스 통신 채널 또는 와이파이다이렉트 통신 채널 등을 형성할 수 있다. 또는 전자 장치 102는 네트워크 162를 통하여 전자 장치 100과 통신 채널을 형성할 수 있다. 예컨대, 전자 장치 102는 셀룰러 통신 모듈을 포함하고, 전자 장치 100과 이동통신 채널을 형성할 수 있다. 또는 전자 장치 102는 와이파이 통신 모듈을 포함하고, 전자 장치 100과 와이파이 통신 채널을 형성할 수 있다. 전자 장치 102는 스크롤 가능한 정보를 전자 장치 100에 전송할 수 있다.
다양한 실시 예에 따르면, 전자 장치 102는 전자 장치 100과 형성된 통신 채널을 통하여 다양한 데이터를 전송할 수 있다. 예컨대, 전자 장치 102는 채팅 메시지 데이터, 문자 메시지 데이터, 멀티미디어 데이터 등을 전자 장치 100에 전송할 수 있다. 또는 전자 장치 102는 특정 파일(예: 일정 크기 이상의 대용량 데이터, 예컨대 사진 파일, 문서 파일, 동영상 파일, 음악 파일 등)을 전자 장치 100에 전송할 수 있다. 전자 장치 102와 송수신하는 데이터 중 동기 기입 방식으로 처리되는 데이터는 메모리 130 기반으로 데이터 입출력 또는 저널링이 처리되며, 비동기 기입 방식으로 처리되는 데이터는 스토리지 180 기반으로 데이터 입출력 또는 저널링이 처리될 수 있다.
전자 장치 100은 전자 장치 102, 서버 장치 106 중 적어도 하나와 통신 채널을 형성할 수 있다. 전자 장치 100은 통신 채널을 형성한 다른 장치들과 관련된 화면을 디스플레이에 표시할 수 있다. 전자 장치 100은 서버 장치 106 또는 외부 전자 장치 102 등과 송수신하는 데이터를 메모리 130 또는 스토리지 180 중 적어도 하나에 저장할 수 있다. 또한, 전자 장치 100은 특정 어플리케이션 실행에 따라 운용되는 데이터를 메모리 130 또는 스토리지 180 중 적어도 하나에 저장할 수 있다.
다양한 실시 예에 따르면, 전자 장치 100은 운용되는 데이터 중 동기 기입 방식으로 처리되는 데이터가 메모리 130 기반으로 입출력 또는 저널링 처리되도록 제어할 수 있다. 또한 전자 장치 100은 비동기 기입 방식으로 처리되는 데이터가 스토리지 180 기반으로 입출력 또는 저널링 처리되도록 제어할 수 있다. 동기 기입 방식은 어플리케이션 실행과 관련한 화면 갱신과 같이 데이터의 실시간 처리 또는 빠른 검색이 요구되는 방식일 수 있다. 비동기 기입 방식은 파일 다운로드 방식과 같이 데이터를 저장한 후 선택적으로 처리하는 방식일 수 있다.
도 1을 참조하면, 상기 전자 장치 100은 버스 110, 프로세서 120, 메모리 130, 입출력 인터페이스 140, 디스플레이 150, 통신 인터페이스 160, 데이터 처리 모듈 170, 스토리지 180 및 배터리 190을 포함할 수 있다.
상기 버스 110은 전술한 구성요소들을 서로 연결하고, 전술한 구성요소들 간의 통신(예: 제어 메시지, 입력 이벤트, 데이터 등)을 수행하는 회로일 수 있다. 예컨대, 버스 110은 입출력 인터페이스 140에서 입력된 입력 신호를 프로세서 120 또는 데이터 처리 모듈 170 중 적어도 하나에 전달할 수 있다. 또한 버스 110은 프로세서 120 또는 데이터 처리 모듈 170의 제어 신호를 메모리 130 또는 스토리지 180 중 적어도 하나에 전달할 수 있다. 예컨대, 버스 110은 스토리지 180에 저장된 데이터를 메모리 130의 일정 영역에 전달할 수 있다. 또한 버스 110은 메모리 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와 관련한 데이터는 메모리 130 기반으로 처리하거나 스토리지 180 기반으로 처리할 수 있다. 예를 들어, 어플리케이션 134와 관련한 데이터 중 화면 갱신과 관련한 데이터 또는 실시간 적용이 요구되는 데이터(예: 게임 데이터) 등은 메모리 130에 마련된 램디스크를 기반으로 처리될 수 있다. 또한 어플리케이션 134와 관련한 데이터 중 실시간 적용이 요구되지 않는 데이터(예: 정지 영상 또는 동영상 다운로드 등 지정된 크기 이상의 대용량 데이터) 처리는 스토리지 180 기반으로 처리될 수 있다. 다양한 실시 예에 따르면, 어플리케이션 134 종류나 속성 또는 파일의 종류나 속성 등에 따라 메모리 130 기반 처리 또는 스토리지 180 기반 처리가 설정될 수 있다. 이와 관련하여, 전자 장치 100은 설정 정보(예: 설정 테이블)를 사전 저장하거나 또는 사용자 조작에 의해 생성 또는 갱신할 수 있다.
다양한 실시 예에 따르면, 메모리 130은 어플리케이션 134와 관련한 데이터의 입출력 또는 저널링 처리를 제어하는 제어 모듈과, 저널링 장치들이 배치되는 영역을 포함할 수 있다. 한 실시 예에 따르면, 메모리 130 영역 중 적어도 일부 영역은 배터리 190으로부터 전원을 공급받아 데이터가 유지될 수 있다. 예컨대, 메모리 130 영역 중 램디스크 영역은 전원 오프(예: sudden power off)가 발생할 경우, 배터리 190이 공급하는 전원을 기반으로 데이터 기입 상태를 유지할 수 있다.
상기 입출력 인터페이스 140은, 입출력 장치(예: 센서, 키보드 또는 터치스크린)를 통하여 사용자로부터 입력된 명령 또는 데이터를, 예를 들면, 상기 버스 110을 통해 상기 프로세서 120, 상기 메모리 130, 상기 통신 인터페이스 160, 또는 상기 데이터 처리 모듈 170에 전달할 수 있다. 또한, 상기 입출력 인터페이스 140은, 예를 들면, 상기 버스 110을 통해 상기 프로세서 120, 상기 메모리 130, 상기 통신 인터페이스 160, 또는 상기 데이터 처리 모듈 170으로부터 수신된 명령 또는 데이터를 상기 입출력 장치(예: 스피커 또는 디스플레이)를 통하여 출력할 수 있다. 다양한 실시 예에 따르면, 입출력 인터페이스 140은 물리 키 버튼(예: 홈 키, 사이드 키, 전원 키 등), 죠그 키, 키패드 등을 포함할 수 있다. 입출력 인터페이스 140은 디스플레이 150에 출력되는 가상 키패드를 입력 장치로 포함할 수 있다. 입출력 인터페이스 140은 적어도 하나의 어플리케이션 실행과 관련한 입력 신호, 전원-오프된 전자 장치 100의 전원 공급을 요청하는 입력 신호 등을 생성할 수 있다.
다양한 실시 예에 따르면, 입출력 인터페이스 140은 오디오 처리와 관련한 기능을 수행할 수 있다. 이와 관련하여 입출력 인터페이스 140은 스피커 및 마이크 중 적어도 하나를 단수 개 또는 복수 개 포함할 수 있다. 입출력 인터페이스 140은 예를 들면, 상기 데이터 처리 모듈 170의 제어에 따라 특정 어플리케이션 실행과 관련한 오디오 데이터를 스피커를 통하여 출력할 수 있다.
상기 디스플레이 150은 각종 정보(예: 멀티미디어 데이터 또는 텍스트 데이터 등)를 표시할 수 있다. 예컨대, 디스플레이 150은 락 스크린, 대기 화면 등을 출력할 수 있다. 디스플레이 150은 특정 기능 수행 화면 예컨대 음원 재생 화면, 동영상 재생 화면, 방송 수신 화면 등을 기능 수행에 대응하여 출력할 수 있다. 한 실시 예에 따르면, 디스플레이 150은 어플리케이션의 데이터 처리 방식과 관련한 화면을 출력할 수 있다. 예를 들어, 디스플레이 150은 특정 데이터가 메모리 130의 램디스크에 저장되는지 또는 스토리지 180에 저장되는지 등에 대한 알람 정보를 출력할 수 있다. 상기 알람 정보 출력은 설정에 따라 생략될 수도 있다.
상기 통신 인터페이스 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에 임시 저장되고, 설정에 따라 메모리 130 또는 스토리지 180 중 적어도 하나에 저장될 수 있다. 예컨대, 수신된 데이터의 속성 또는 종류에 따라 또는 관련된 어플리케이션의 속성이나 종류에 따라 메모리 130의 램디스크에 저장되거나 또는 스토리지 180에 저장될 수 있다.
상기 데이터 처리 모듈 170은, 다른 구성요소들(예: 상기 프로세서 120, 상기 메모리 130, 상기 입출력 인터페이스 140, 또는 상기 통신 인터페이스 160 등)로부터 획득된 데이터를 처리할 수 있다. 예를 들면, 데이터 처리 모듈 170은 특정 어플리케이션과 관련한 데이터의 속성 또는 종류에 대응하여, 해당 데이터를 메모리 130의 램디스크 영역에 저장하거나, 또는 스토리지 180에 저장하도록 제어할 수 있다.
스토리지 180은 전자 장치 100 운용과 관련한 데이터를 저장하고, 전자 장치 100 운용에 따라 데이터를 메모리 130에 전달할 수 있다. 스토리지 180은 예컨대 비휘발성 저장 영역을 포함할 수 있다. 스토리지 180은 메모리 130에 저장된 데이터 처리와 관련하여 저널링 장치를 포함할 수 있다. 저널링 장치는 파일 시스템 변경이 발생할 경우, 변경내용을 트랜잭션(Transaction) 단위로 커밋(commit)하고, 커밋 완료 후 트랜잭션 변경사항을 파일 시스템에 적용하는 동작을 지원할 수 있다.
배터리 190은 메모리 130의 적어도 일부 영역에 전원을 공급할 수 있다. 예컨대, 배터리 190은 전자 장치 100의 메인 배터리가 탈락되는 경우 메모리 130에 전원을 공급하여 데이터 기입 상태를 유지하도록 지원할 수 있다. 배터리 190은 1차 전지 또는 2차 전지 중 어느 하나의 타입으로 마련될 수 있다. 배터리 190이 2차 전지로 마련되는 경우 메인 배터리 장착 상태에서, 배터리 190은 메인 배터리의 전원을 이용하여 충전될 수 있다.
도 2는 다양한 실시 예에 따른 전자 장치의 메모리와 스토리지의 일예를 도시한다.
도 2를 참조하면, 메모리 130은 제1 저널링 장치(journaling file system, JFS) 71 영역, 제2 저널링 장치 73 영역, 램디스크(ramdisk) 75 영역, 어플리케이션 134 영역, 가상 파일 시스템(virtual file system, VFS) 79 영역, 버퍼 파일 시스템(buffer file system, BFS) 77 영역이 할당될 수 있다. 상술한 구성 중 제1 저널링 장치 71, 제2 저널링 장치 73, 가상 파일 시스템 79, 버퍼 파일 시스템 77 중 적어도 하나는 소프트웨어 모듈, 미들웨어 모듈, 하드웨어 모듈 중 적어도 하나로 구성될 수 있다. 예컨대, 제1 저널링 장치 71, 제2 저널링 장치 73, 버퍼 파일 시스템 77 중 적어도 하나는 데이터 처리 모듈 170에 포함되며, 메모리 130 구성과 독립적인 위치에 배치될 수도 있다.
다양한 실시 예에 따르면, 제1 저널링 장치 71 또는 제2 저널링 장치 73 중 적어도 하나는 메모리 130에 배치되지 않고 스토리지 180에 배치될 수도 있다. 또한 버퍼 파일 시스템 77은 스토리지 180에 배치될 수도 있다. 가상 파일 시스템 79는 어플리케이션 134의 시스템 콜을 버퍼 파일 시스템 77에 전달하고, 버퍼 파일 시스템 77의 데이터 처리 결과를 어플리케이션 134에 전달할 수 있다. 이 동작에서 가상 파일 시스템 79는 어플리케이션 134 운용과 관련한 파일 시스템 지원 및 버퍼 파일 시스템 77 운용과 관련한 파일 시스템 지원을 수행할 수 있다. 다양한 실시 예에 따르면, 제1 저널링 장치 71은 메모리 130에 배치되고, 트랜잭션 커밋 동작에서 스토리지 180에 파일을 이동 저장하는데 이용될 수 있다. 제2 저널링 장치 73은 메모리 130에 배치되되 배터리 190의 전원 공급을 지원받는 예약 영역을 기반으로 마련된 램디스크 75와 연관되어 마련되거나 또는 램디스크 75의 적어도 일부를 기반으로 마련될 수 있다. 제2 저널링 장치 73에 저장된 데이터는 트랜잭션 커밋 동작에서 램디스크 75 또는 예약 영역에 이동 저장될 수 있다.
한 실시 예에 따르면, 데이터 처리 모듈 170은 전자 장치 100 운용에 대응하여 가상 파일 시스템 79, 버퍼 파일 시스템 77의 메모리 130 배치(또는 할당)를 제어할 수 있다. 또한, 데이터 처리 모듈 170은 어플리케이션 134 실행 요청이 발생하면, 어플리케이션 134가 메모리 130 일정 영역에 배치되도록 제어할 수 있다. 데이터 처리 모듈 170은 어플리케이션 134와 관련한 데이터 처리를 제1 저널링 장치 71 또는 제2 저널링 장치 73 중 적어도 하나를 기반으로 처리할 수 있다. 여기서 어플리케이션 134는 복수개가 메모리 130에 배치될 수도 있다. 데이터 처리 모듈 170은 어플리케이션 134의 속성 또는 종류(예: 동기 기입 방식 또는 비동기 기입 방식)에 따른 처리를 지원하기 위하여 버퍼 파일 시스템 77의 배치를 제어할 수 있다.
상술한 전자 장치 100은 배터리 190이 배치된 상태에서 램디스크 75를 이용한 파일 시스템 상 데이터베이스 입출력 성능 개선을 지원할 수 있다. 전자 장치 100은 메모리 130에 예약된 고정 주소 영역(예: 예약 영역, reserved area)을 동기 기입 방식과 관련한 파일 시스템 예컨대 데이터베이스 입출력(DB I/O: database input/output)과 관련한 램디스크 75 파일 시스템으로 사용하거나, 램디스크 75 운용과 관련한 영역으로 이용할 수 있다. 데이터베이스 입출력의 경우 자체 저널링 메커니즘 지원과 관련하여 파일 시스템 동기화 동작이 수행될 수 있다. 예를 들어, 전자 장치 100은 데이터베이스 입출력 처리 시 램디스크 75를 사용하여 데이터베이스 입출력 처리와 사용자 파일 입출력을 동적으로 분리하여 버퍼링할 수 있다. 배터리 190은 메인 배터리가 분리될 경우 전자 장치 100의 메모리 130에 일정 시간 동안 전원 공급을 수행할 수 있다. 이에 따라, 전자 장치 100은 전자 장치 100의 시스템 크래쉬(System Crash) 또는 배터리 탈착 등에 의한 비정상 전원 오프(예: Sudden power off) 발생 시 램디스크 75의 데이터 유실을 방지할 수 있다.
다양한 실시 예에 따르면, 파일 시스템 초기화와 관련하여, 버퍼 파일 시스템 77은 파일 시스템 마운트(mount) 시 램디스크 75 영역과 관련한 파일 시스템 슈퍼블록(superblock)에 해당하는 제2 저널링 장치 73을 검사할 수 있다. 버퍼 파일 시스템 77은 제2 저널링 장치 73이 존재하지 않을 경우 램디스크 75와 관련한 일정 영역에 지정된 저널링 장치를 할당하거나, 지정된 영역을 저널링 파일 시스템(예: ext4)으로 포맷(format), 해당 저널링 장치 또는 저널링 파일 시스템(예: 제2 저널링 장치 73)을 마운트할 수 있다.
한 실시 예에 따르면, 데이터 처리 모듈 170은 스토리지 180의 데이터 처리와 관련하여 지정된 저널링 파일 시스템 또는 제1 저널링 장치 71이 메모리 130의 일정 영역 또는 스토리지 180의 일정 영역 중 적어도 하나의 영역에 마운트되도록 제어할 수 있다. 데이터 처리 모듈 170은 상위 소프트웨어 스택인 버퍼 파일 시스템 77의 초기화 완료를 수행할 수 있다. 사용자 요청에 따라 또는 스케줄 정보에 대응하여 메모리 130에 배치된 어플리케이션 134는 입출력-컨트롤(예: ioctl(input output control)) 등의 시스템 콜을 통해 램디스크 75를 사용하여 파일 입출력을 처리할 파일 타입 (확장명) 또는 파일 명을 셋업 할 수 있다. 이 동작에서 셋업된 확장명 또는 파일명은 파일 시스템의 제2 저널링 장치 73 또는 특수 파일(hidden file) 영역에 저장될 수 있다.
데이터 처리 모듈 170은 지정된 파일 타입(예: DB files: .db, .db-journal, .db-wal, .shm)에 대한 파일 개방(open) 요청이 들어올 경우 스토리지 180의 제1 저널링 장치 71로부터 제2 저널링 장치 73 또는 램디스크 75 영역으로 파일 복사를 통해 로딩한 후 파일 요청을 처리할 수 있다. 여기서 데이터 처리 모듈 170은 램디스크 75 영역에 데이터를 쓸 공간이 부족할 경우(예: 어플리케이션 134 관련 데이터가 램디스크 75 영역 전체에 할당된 상태)의 처리와 관련하여, 램디스크 75의 파일 리스트(예: LRU(least recently used) 파일 리스트)를 유지할 수 있다.
데이터 처리 모듈 170은 파일 시스템 umount, read-only remount 및 freeze (suspend) 동작 시, 램디스크 75 영역에 저장된 파일 또는 제2 저널링 장치 73에 저장된 파일이 제1 저널링 장치 71(또는 스토리지 180에 배치된 저널링 장치)에 저장된 파일과 동기화되도록 제어할 수 있다. 데이터 처리 모듈 170은 동기화 완료 시 램디스크 75 영역 또는 제2 저널링 장치 73 영역에 복구 완료(recovery complete) 상태를 표시할 수 있다. 이와 관련하여, 램디스크 75 영역 또는 제2 저널링 장치 73 영역 중 적어도 하나는 복구 완료 상태 표시와 관련한 저장 영역(예: 비트 영역)을 포함할 수 있다.
데이터 처리 모듈 170은 파일 동기화 성능 최적화와 관련하여, 아이노드 버전(inode version) 정보를 활용할 수 있다. 데이터 처리 모듈 170은 아이노드 버전 값이 램디스크 75 영역(예: 램디스크 파티션)으로 파일 로딩 시, 제1 저널링 장치 71 영역의 아이노드 버전 값(예: 제1 저널링 장치 71에 저장된 파일의 아이노드 버전 정보)을 증가시켜서 유지하도록 제어할 수 있다. 데이터 처리 모듈 170은 제1 저널링 장치 71과 제2 저널링 장치 73 또는 램디스크 75 파일 동기화 수행 시 램디스크 75 영역 또는 제2 저널링 장치 73을 스캐닝하여 제1 저널링 장치 71에 저장된 원본 파일의 아이노드 버전 값 보다 램디스크 75 영역 또는 제2 저널링 장치 73의 아이노드 버전 값(예: 램디스크 75 또는 제2 저널링 장치 73에 저장된 파일의 아이노드 버전 정보)이 클 경우 파일을 복사하도록 할 수 있다. 데이터 처리 모듈 170은 제1 저널링 장치 71에 저장된 원본 파일의 아이노드 버전 값과 램디스크 75 영역 또는 제2 저널링 장치 73의 아이노드 버전 값이 같을 경우에는 파일 복사 처리를 수행하지 않도록 제어할 수 있다.
다양한 실시 예에 따르면, 비정상 전원-오프 발생에 따른 램디스크 75 복구와 관련하여, 데이터 처리 모듈 170은 리부팅(reboot) 동작에서 메모리 130의 예약 영역을 검사하여 램디스크 75 복원을 처리할 수 있다.
상술한 바와 같이 전자 장치 100은 동기 기입 방식(예: 데이터베이스 입출력)을 비동기 기입 방식(Asynchronous input/output)과 분리하여 수행함으로써, 백그라운드 프로세싱에서 입출력 우선순위가 높은 동기 기입 방식의 응답시간 저하를 방지할 수 있다. 예컨대, 전자 장치 100은 사용자 인터페이스 처리 시 응용프로그램 상태 저장과 관련한 데이터베이스 입출력 응답 시간처리를 적응적으로 수행하여 사용자 인터페이스 래깅(lagging) 현상을 최소화할 수 있다. 또한, 전자 장치 100은 어플리케이션 134에서 빈번하게 접근하는 파일 또는 빠른 입출력 처리가 필요한 파일에 대해 파일 입출력 성능을 최적화할 수 있다.
상술한 바와 같이, 다양한 실시 예에 따르면, 전자 장치는 예약 영역을 데이터 입출력 처리와 관련한 램디스크 파일 시스템으로 할당하는 메모리, 상기 램디스크 파일 시스템의 파일 처리를 제어하는 데이터 처리 모듈을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 전자 장치는 메인 전원 공급 차단 시 상기 메모리의 데이터 기입 상태 유지와 관련한 전원을 공급하는 배터리를 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 램디스크 파일 시스템 처리를 고속 스토리지를 기반으로 교체 처리할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 램디스크 영역 또는 상기 램디스크와 관련한 메모리 영역을 저널링 파일 시스템으로 포맷하여 마운트할 수 있다.
다양한 실시 예에 따르면, 상기 메모리는 시스템 콜을 통해 상기 램디스크를 사용하여 파일 입출력을 처리할 파일 타입 또는 파일 명을 셋업하는 적어도 하나의 어플리케이션, 상기 어플리케이션 운용과 관련한 파일 처리를 지원하는 가상 파일 시스템, 상기 가상 파일 시스템을 통해 전달된 명령 또는 파일의 속성에 따라 동기 기입 방식에 따른 파일 처리와 비동기 기입 방식에 따른 파일 처리를 제어하는 버퍼 파일 시스템, 상기 버퍼 파일 시스템 제어에 따라 동기 기입 방식 처리가 요구되는 파일을 처리하는 상기 램디스크 파일 시스템을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 전자 장치는 상기 비동기 기입 방식 처리가 요구되는 파일 처리를 지원하는 스토리지를 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 지정된 파일 타입에 대한 파일 개방 요청이 들어올 경우 스토리지의 저널링 장치로부터 상기 램디스크로 파일을 복사하여 파일 처리할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 램디스크로 신규 파일 로딩 시 상기 램디스크의 잔여 공간을 확인하고, 상기 램디스크에 기입된 데이터들과 관련한 리스트를 기반으로 특정 파일을 상기 램디스크에서 제거하여 스토리지에 이동 저장할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 리스트에 등록된 파일들 중 닫힘 상태이면서 가장 오래 사용되지 않은 파일 순으로 제거할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 특정 이벤트 발생 시 상기 램디스크의 파일을 스토리지에 동기화하고, 동기화 완료에 따른 상태가 표시되도록 제어할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 상기 램디스크에 저장된 파일의 버전 값 및 상기 스토리지에 저장된 파일의 버전 값의 비교 결과를 기반으로 파일 동기화 수행 여부를 결정할 수 있다.
다양한 실시 예에 따르면, 상기 데이터 처리 모듈은 비정상 종료 후 리부팅 과정에서 상기 메모리의 예약 영역을 검사하여 상기 램디스크를 복원할 수 있다.
도 3은 다양한 실시 예에 따른 데이터 운용 방법을 도시한다.
도 3을 참조하면, 데이터 운용 방법과 관련하여 동작 301에서 데이터 처리 모듈 170은 파일 처리 요청을 수신할 수 있다. 예컨대, 데이터 처리 모듈 170은 입출력 인터페이스 140에서 발생한 입력 이벤트에 의하여 특정 어플리케이션 실행을 처리할 수 있다. 이 동작에서 어플리케이션 실행과 관련한 데이터(예: 파일) 처리가 요청될 수 있다. 또는 데이터 처리 모듈 170은 통신 인터페이스 160을 통해 외부로부터 수신된 데이터의 처리 요청을 수신할 수 있다. 또는 데이터 처리 모듈 170은 전자 장치 100의 운용(예: 스케줄 정보에 따른 처리)에 따라 특정 데이터 처리 요청을 수신할 수 있다.
데이터 처리 모듈 170은 데이터 처리와 관련하여 초기화 과정을 수행할 수 있다. 초기화 과정에서 데이터 처리 모듈 170은 버퍼 파일 시스템 77을 메모리 130에 마운트할 수 있다. 이 동작에서 데이터 처리 모듈 170은 램디스크 75 영역의 파일 시스템 슈퍼블록(예: 제2 저널링 장치 73)이 존재하는지 확인할 수 있다. 데이터 처리 모듈 170은 슈퍼블록이 존재하지 않은 경우 램디스크 75 영역과 관련된 일정 영역을 지정된 저널링 파일 시스템(예: ext4)으로 포맷한 후 마운트할 수 있다. 또한, 데이터 처리 모듈 170은 스토리지 180의 일정 영역을 제1 저널링 장치 71 영역으로 마운트하고, 상위 소프트웨어 스택인 버퍼 파일 시스템 77의 초기화 완료를 처리할 수 있다. 여기서 데이터 처리 모듈 170은 제1 저널링 장치 71을 메모리 130의 일정 영역에 마운트할 수 있다.
동작 301에서, 어플리케이션 134는 시스템 콜(예: ioctl)을 통해 램디스크 75 영역을 이용하여 파일 입출력을 처리할 파일 타입(확장명) 또는 파일 명을 셋업 할 수 있다. 또한 어플리케이션 134에서 셋업된 확장명 또는 파일명은 파일 시스템의 제2 저널링 장치 73 또는 특수 파일(hidden file) 영역에 저장될 수 있다.
동작 303에서, 데이터 처리 모듈 170은 처리 요청된 파일의 속성을 확인할 수 있다. 예컨대, 데이터 처리 모듈 170은 처리 요청된 파일이 제1 타입(예: 동기 기입 방식의 처리가 필요한 데이터 입출력 또는 파일 처리)인지 또는 제2 타입(비동기 기입 방식의 처리가 필요한 데이터 입출력 또는 파일 처리)인지 확인할 수 있다. 동작 303에서 파일 속성이 제1 타입인 경우, 동작 305에서 데이터 처리 모듈 170은 메모리 130 기반 저널링 파일 시스템 운용을 수행할 수 있다. 예컨대, 데이터 처리 모듈 170은 메모리 130의 램디스크 75 영역 또는 제2 저널링 장치 73을 기반으로 동기 기입 방식의 데이터 처리를 지원할 수 있다. 동작 303에서 파일 속성이 제2 타입인 경우, 동작 307에서 데이터 처리 모듈 170은 스토리지 180 기반 저널링 파일 시스템 운용을 수행할 수 있다. 예컨대, 데이터 처리 모듈 170은 메모리 130에 배치된 제1 저널링 장치 71을 기반으로 스토리지 180에 데이터를 저장하는 비동기 기입 방식에 따른 데이터 처리를 지원할 수 있다. 또는 데이터 처리 모듈 170은 스토리지 180에 배치된 제1 저널링 장치 71을 기반으로 비동기 기입 방식에 따른 데이터 처리를 지원할 수 있다. 한 실시 예에 따르면, 데이터 처리 모듈 170은 지정된 파일 타입(예: DB files: .db, .db-journal, .db-wal, .shm)에 대한 파일 오픈(open) 요청이 발생하면, 스토리지 180 영역의 제1 저널링 장치 71로부터 램디스크 75 영역 또는 관련된 제2 저널링 장치 73로 파일 복사를 통한 로딩을 수행한 후 파일 요청을 처리할 수 있다.
동작 305에서의 데이터 처리 또는 동작 307에서의 데이터 처리가 완료되면, 동작 309에서 데이터 처리 모듈 170은 파일 처리 요청과 관련한 종료 이벤트 발생이 있는지 확인할 수 있다. 데이터 처리 모듈 170은 종료 이벤트(예: 전자 장치 100의 턴-오프 또는 슬립 모드 전환 등)가 발생하면, 해당 상태 천이를 제어할 수 있다. 데이터 처리 모듈 170은 종료 이벤트 발생이 없으면, 동작 301 이전으로 분기하여 이하 과정을 재수행하도록 제어할 수 있다.
상술한 바와 같이, 다양한 실시 예에 따른 전자 장치 100의 데이터 처리 모듈 170은 배터리(Backup battery)가 장착된 장치에서 메모리 130에 예약된 고정 주소 영역(reserved area)을 동기 기입 방식(예: 데이터베이스 입출력을 위한 램디스크 75 파일 시스템으로 운용하거나, 램디스크 75 설정 또는 복구를 위한 영역으로 이용할 수 있다.
도 4는 다양한 실시 예에 따른 램디스크 운용 방법을 도시한다.
도 4를 참조하면, 램디스크 운용 방법과 관련하여, 동작 401에서 데이터 처리 모듈 170은 예컨대, 파일 처리 요청을 수신할 수 있다. 파일 처리 요청 수신과 관련하여, 데이터 처리 모듈 170은 앞서 언급한 바와 같이 메모리 130 초기화를 수행하면서 램디스크 75 배치를 처리할 수 있다. 또한 데이터 처리 모듈 170은 스케줄 정보에 대응하여 또는 사용자 입력에 대응하여 어플리케이션 134를 메모리 130에 배치할 수 있다. 어플리케이션 134는 운용과 관련한 데이터 처리가 필요한 경우 시스템 콜을 가상 파일 시스템 79를 통해 버퍼 파일 시스템 77에 요청할 수 있다.
파일 처리 요청이 발생하면, 동작 403에서 데이터 처리 모듈 170은 예컨대, 램디스크 75 공간 확인을 수행할 수 있다. 예컨대, 데이터 처리 모듈 170은 메모리 130의 예약 영역을 이용하여 정의한 램디스크 75 영역의 위치와 크기 확인을 수행할 수 있다. 데이터 처리 모듈 170은 램디스크 75 영역에 데이터가 기입되지 않은 영역의 크기와 위치를 확인할 수 있다.
동작 405에서 데이터 처리 모듈 170은 예컨대, 램디스크 75의 잔여 공간이 지정 값 이하인지 여부를 확인할 수 있다. 예를 들어, 데이터 처리 모듈 170은 파일 처리 요청된 데이터의 크기 값과 램디스크 75의 잔여 공간의 크기를 비교할 수 있다.
동작 405에서 램디스크 75의 잔여 공간이 지정 값 이하인 경우(예: 램디스크 75 잔여 공간이 파일 처리 요청된 데이터의 크기보다 작은 경우), 동작 407에서 데이터 처리 모듈 170은 리스트(예: LRU 파일 리스트)를 확인할 수 있다. 이와 관련하여, 데이터 처리 모듈 170은 램디스크 75에 데이터를 기입하는 동작에서 파일 리스트 생성과 관리를 수행할 수 있다.
동작 409에서, 데이터 처리 모듈 170은 특정 파일 제거를 수행할 수 있다. 제거된 파일은 제1 저널링 장치 71 또는 스토리지 180에 이동 저장(evict)할 수 있다. 한 실시 예에 따르면, 데이터 처리 모듈 170은 리스트에 포함된 파일들 중 특정 파일, 예컨대 어플리케이션 134에 의해 액세스되지 않은 시기가 가장 오래된 파일을 제거할 수 있다. 데이터 처리 모듈 170은 파일 제거 후, 램디스크 75의 잔여 공간과 파일 처리 요청된 데이터의 크기를 비교하여 램디스크 75의 잔여 공간에 비하여 상대적으로 작은지 확인할 수 있다. 데이터 처리 모듈 170은 파일 제거 후 램디스크 75의 잔여 공간이 파일 처리 요청된 데이터 크기보다 작은 경우 리스트를 확인하여 다른 특정 파일(예: 전자 장치 100에 의해 액세스되지 않은 시기가 가장 오래된 파일)을 제거할 수 있다. 데이터 처리 모듈 170은 램디스크 75 잔여 공간이 파일 처리 요청된 데이터의 처리가 가능한 크기를 확보할 때까지 상술한 동작을 반복 처리할 수 있다.
다양한 실시 예에 따르면, 데이터 처리 모듈 170은 파일 처리 요청된 데이터 크기를 확인한 후 램디스크 75의 잔여 공간이 파일 처리 요청된 데이터 크기 이상을 가지도록 파일 제거를 일괄 처리할 수도 있다. 예컨대, 데이터 처리 모듈 170은 램디스크 75의 잔여 공간과 파일 처리 요청된 데이터 크기를 확인하여 필요한 공간을 확인할 수 있다. 데이터 처리 모듈 170은 필요한 공간의 크기에 대응하는 적어도 하나의 파일을 선택하여 제거할 수 있다. 이 동작에서 데이터 처리 모듈 170은 사용되지 않은 가장 오래된 파일들 순으로 필요한 공간에 대응하는 파일들을 제거할 수 있다.
다양한 실시 예에 따르면, 데이터 처리 모듈 170은 가장 오래된 파일들 중 램디스크 75 잔여 공간을 제외하고 파일 처리에 대응하는 크기의 파일을 선택하여 제거할 수 있다. 다양한 실시 예에 따르면, 데이터 처리 모듈 170은 파일 닫힘(closed) 상태의 데이터들 중에서 파일 제거를 수행할 수 있다. 데이터 처리 모듈 170은 파일 닫힘(close) 상태의 데이터들의 램디스크 75 제거 이후에도 램디스크 75 공간이 부족한 경우 파일 개방(open) 상태의 데이터들 중에 사용되지 않은 가장 오래된 파일을 제거할 수 있다. 이 동작에서 데이터 처리 모듈 170은 개방 파일의 제거와 관련한 알람을 출력할 수 있다. 또는 데이터 처리 모듈 170은 새로운 파일 처리와 관련하여 개방 파일을 제거할지 여부를 묻는 팝업창 등을 출력하도록 제어할 수 있다.
동작 406에서 램디스크 75의 잔여 공간이 지정 값 이상인 경우, 데이터 처리 모듈 170은 동작 407 및 동작 409를 생략할 수 있다. 동작 409에서 특정 파일이 제거되면(예: 램디스크 75 잔여 공간이 파일 처리 요청된 데이터 크기 이상으로 확보된 경우), 동작 411에서 데이터 처리 모듈 170은 파일 처리 요청에 따른 파일 처리를 수행할 수 있다. 예컨대, 버퍼 파일 시스템 77은 데이터 처리 모듈 170 제어에 대응하여 램디스크 75와 스토리지 180에 각각 ext4 타입 파일 시스템을 구성하고, 파일 처리 요청된 데이터를 램디스크 75의 제2 저널링 장치 73에 동적 로딩하여 파일 입출력을 처리한다.
파일 처리가 완료되면, 동작 413에서 데이터 처리 모듈 170은 리스트 갱신을 수행할 수 있다. 예컨대, 데이터 처리 모듈 170은 새로 파일 처리 요청된 데이터 항목을 리스트에 등록할 수 있다. 동작 415에서, 데이터 처리 모듈 170은 예컨대 파일 처리와 관련한 종료 이벤트 발생이 있는지 확인할 수 있다. 데이터 처리 모듈 170은 파일 처리와 관련한 종료 이벤트 발생이 없으면, 동작 401 이전으로 분기하여 갱신된 리스트를 가지고 이하 과정을 재수행할 수 있다.
도 5는 다양한 실시 예에 따른 파일 시스템 복원 방법을 도시한다.
도 5를 참조하면, 파일 시스템 복원 방법과 관련하여, 동작 501에서 데이터 처리 모듈 170은 비정상 종료 이후 부트 수행과 관련한 적어도 하나의 처리(예: 부트 로더 로딩, 운영체제 로딩, 전자 장치 100 운용과 관련한 프로세스 처리 등)를 수행할 수 있다. 부트 수행 중에 동작 503에서, 데이터 처리 모듈 170은 메모리 130의 예약 영역 확인을 수행할 수 있다. 예를 들어, 데이터 처리 모듈 170은 예약 영역을 기반으로 배터리 190으로 구동 중인 램디스크 75 크기를 스토리지 180의 입출력 성능 및 배터리 190 용량을 고려하여 설정할 수 있다.
예약 영역이 확인되면, 동작 505에서 데이터 처리 모듈 170은 예컨대, 램디스크 75 복원을 처리할 수 있다. 한 실시 예에 다르면, 데이터 처리 모듈 170은 부팅 과정에서 버퍼 파일 시스템 77 마운트 중 메모리 130의 예약 영역을 통해 초기화된 램디스크 75 파일 시스템 슈퍼블록(예: 제2 저널링 장치)을 검사할 수 있다. 데이터 처리 모듈 170은 파일 시스템 슈퍼블록이 존재하고 복구 완료(recovery complete)가 되지 않은 상태이면, 제1 저널링 장치 71에 램디스크 75 파일을 동기화할 수 있다.
동작 507에서 데이터 처리 모듈 170은 예컨대, 동기화가 완료되었는지 확인할 수 있다. 동작 507에서 동기화가 완료되지 않은 경우, 동작 509에서 데이터 처리 모듈 170은 스토리지 180 기반 파일 동기화를 수행할 수 있다. 동작 507에서 동기화가 완료되면, 데이터 처리 모듈 170은 동작 509를 스킵할 수 있다. 데이터 처리 모듈 170은 램디스크 75 영역에 저장된 파일들의 동기화(예: 램디스크 75 영역에 저장된 파일을 스토리지 180 또는 제1 저널링 장치 71로 복사 저장)가 완료되면, 버퍼 파일 시스템 77 마운트 동작을 처리할 수 있다.
상술한 바와 같이, 배터리 190이 제공되는 전자 장치 100에서 메인 배터리 탈착 시 시스템 유지 동작을 지원하도록 설계된 경우, 데이터 처리 모듈 170은 파일 시스템 동결(file system freeze) 동작을 통해 램디스크 75 또는 제2 저널링 장치 73을 스토리지 180 또는 제1 저널링 장치 71로 동기화할 수 있다. 데이터 처리 모듈 170은 동기화 완료 시 복구 완료(recovery complete)를 램디스크 75의 제2 저널링 장치 73에 표기할 수 있다.
다양한 실시 예에 따르면, 데이터 처리 모듈 170은 파일 시스템 umount, read-only remount 및 freeze (suspend) 동작 시, 램디스크 75 또는 제2 저널링 장치 73의 파일은 제1 저널링 장치 71로 동기화 되며, 동기화 완료 시에는 램디스크 75 영역 또는 제2 저널링 장치 73 영역에 복구 완료 상태를 표시할 수 있다. 상술한 동작에서 데이터 처리 모듈 170은 파일 동기화 성능 최적화를 위해 아이노드 버전 정보를 이용할 수 있다.
상술한 바와 같이, 다양한 실시 예에 따른 데이터 운용 방법은 메모리의 예약 영역을 데이터 입출력 처리와 관련한 램디스크 파일 시스템으로 할당하는 동작, 상기 램디스크 파일 시스템의 파일 처리를 제어하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 방법은 상기 램디스크 영역 또는 상기 램디스크와 관련한 메모리 영역을 저널링 파일 시스템으로 포맷하여 마운트하는 동작을 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 방법은 상기 메모리에 배치된 어플리케이션이 시스템 콜을 통해 상기 램디스크를 사용하여 파일 입출력을 처리할 파일 타입 또는 파일 명을 셋업하는 동작, 상기 어플리케이션 운용과 관련한 파일 처리를 지원하는 가상 파일 시스템을 상기 메모리에 배치하는 동작, 상기 가상 파일 시스템을 통해 전달된 명령 또는 파일의 속성에 따라 동기 기입 방식에 따른 파일 처리와 비동기 기입 방식에 따른 파일 처리를 제어하는 버퍼 파일 시스템을 상기 메모리에 배치하는 동작 중 적어도 하나를 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 방법은 상기 비동기 기입 방식 처리가 요구되는 파일 처리를 스토리지에 전달하는 동작을 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 방법은 지정된 파일 타입에 대한 파일 개방 요청이 들어올 경우 스토리지의 저널링 장치로부터 상기 램디스크로 파일을 복사하여 파일 처리를 수행하는 동작을 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 방법은 상기 램디스크로 신규 파일 로딩 시 상기 램디스크의 잔여 공간을 확인하는 동작, 상기 램디스크에 기입된 데이터들과 관련한 리스트를 기반으로 특정 파일을 상기 램디스크에서 제거하여 스토리지에 이동 저장하는 동작, 상기 특정 파일 제거에 따라 확보된 영역을 기반으로 상기 신규 파일을 처리하는 동작을 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 이동 저장하는 동작은 상기 리스트에 등록된 파일들 중 닫힘 상태이면서 가장 오래 사용되지 않은 파일 순으로 이동 저장하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 방법은 특정 이벤트 발생 시 상기 램디스크의 파일을 스토리지에 동기화하는 동작, 상기 동기화 완료에 따른 상태 표시를 수행하는 동작 중 적어도 하나를 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 동기화하는 동작은 상기 램디스크에 저장된 파일의 버전 값 및 상기 스토리지에 저장된 파일의 버전 값의 비교 결과를 기반으로 파일 동기화 수행 여부를 결정하는 동작을 포함할 수 있다.
다양한 실시 예에 따르면, 상기 방법은 비정상 종료 후 리부팅 과정에서 상기 메모리의 예약 영역을 검사하여 상기 램디스크를 복원하는 동작을 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 방법은 메인 전원 공급 차단 시 배터리 전원을 이용하여 상기 메모리의 데이터 기입 상태를 유지하는 동작을 더 포함할 수 있다.
다양한 실시 예에 따르면, 상기 제어하는 동작은 램디스크 파일 시스템 처리를 고속 스토리지를 기반으로 교체 처리하는 동작을 포함할 수 있다.
도 6은 다양한 실시 예에 따른 전자 장치의 블록도이다.
도 6을 참조하면, 상기 전자 장치 600은, 예를 들면, 도 1에 도시된 전자 장치 100의 전체 또는 일부를 구성할 수 있다. 도 6을 참조하면, 상기 전자 장치 600은 하나 이상의 어플리케이션 프로세서(AP: application processor) 610(예: 상기 프로세서 120, 상기 데이터 처리 모듈 170 등), 통신 모듈 620(예: 상기 통신 인터페이스 160), SIM(subscriber identification module) 카드 624, 메모리 630(예: 상기 메모리 130, 상기 스토리지 180), 센서 모듈 640, 입력 장치 650(예: 상기 입출력 인터페이스 140), 디스플레이 660(상기 디스플레이 150), 인터페이스 670, 오디오 모듈 680(예: 상기 입출력 인터페이스 140), 카메라 모듈 691, 전력관리 모듈 695, 배터리 696, 인디케이터 697 및 모터 698을 포함할 수 있다.
상기 AP 610은 운영체제 또는 응용 프로그램을 구동하여 상기 AP 610에 연결된 다수의 하드웨어 또는 소프트웨어 구성요소들을 제어할 수 있고, 멀티미디어 데이터를 포함한 각종 데이터 처리 및 연산을 수행할 수 있다. 상기 AP 610은, 예를 들면, SoC(system on chip) 로 구현될 수 있다. 한 실시 예에 따르면, 상기 AP 610은 GPU(graphic processing unit, 미도시)를 더 포함할 수 있다.
상기 통신 모듈 620(예: 상기 통신 인터페이스 160)은 상기 전자 장치 600(예: 상기 전자 장치 100)과 네트워크를 통해 연결된 다른 전자 장치들(예: 전자 장치 102 또는 서버 장치 106) 간의 통신에서 데이터 송수신을 수행할 수 있다. 한 실시 예에 따르면, 상기 통신 모듈 620은 셀룰러 모듈 621, Wifi 모듈 623, BT 모듈 625, GPS 모듈 627, NFC 모듈 628 및 RF(radio frequency) 모듈 629를 포함할 수 있다.
상기 셀룰러 모듈 621은 통신망(예: LTE, LTE-A, CDMA, WCDMA, UMTS, WiBro 또는 GSM 등)을 통해서 음성 통화, 영상 통화, 문자 서비스 또는 인터넷 서비스 등을 제공할 수 있다. 또한, 상기 셀룰러 모듈 621은, 예를 들면, 가입자 식별 모듈(예: SIM 카드 624)을 이용하여 통신 네트워크 내에서 전자 장치의 구별 및 인증을 수행할 수 있다. 한 실시 예에 따르면, 상기 셀룰러 모듈 621은 상기 AP 610이 제공할 수 있는 기능 중 적어도 일부 기능을 수행할 수 있다. 예를 들면, 상기 셀룰러 모듈 621은 멀티미디어 제어 기능의 적어도 일부를 수행할 수 있다.
한 실시 예에 따르면, 상기 셀룰러 모듈 621은 커뮤니케이션 프로세서(CP: communication processor)를 포함할 수 있다. 또한, 상기 셀룰러 모듈 621은, 예를 들면, SoC로 구현될 수 있다. 도 6에서는 상기 셀룰러 모듈 621(예: 커뮤니케이션 프로세서), 상기 메모리 630 또는 상기 전력관리 모듈 695 등의 구성요소들이 상기 AP 610과 별개의 구성요소로 도시되어 있으나, 한 실시 예에 따르면, 상기 AP 610이 전술한 구성요소들의 적어도 일부(예: 셀룰러 모듈 621)를 포함하도록 구현될 수 있다.
한 실시 예에 따르면, 상기 AP 610 또는 상기 셀룰러 모듈 621(예: 커뮤니케이션 프로세서)은 각각에 연결된 비휘발성 메모리(예: 상기 스토리지 180) 또는 다른 구성요소 중 적어도 하나로부터 수신한 명령 또는 데이터를 휘발성 메모리(예: 상기 메모리 130)에 로드(load)하여 처리할 수 있다. 또한, 상기 AP 610 또는 상기 셀룰러 모듈 621은 다른 구성요소 중 적어도 하나로부터 수신하거나 다른 구성요소 중 적어도 하나에 의해 생성된 데이터를 비휘발성 메모리(예: 상기 스토리지 180)에 저장(store)할 수 있다.
상기 Wifi 모듈 623, 상기 BT 모듈 625, 상기 GPS 모듈 627 또는 상기 NFC 모듈 628 각각은, 예를 들면, 해당하는 모듈을 통해서 송수신되는 데이터를 처리하기 위한 프로세서를 포함할 수 있다. 도 6에서는 셀룰러 모듈 621, Wifi 모듈 623, BT 모듈 625, GPS 모듈 627 또는 NFC 모듈 628이 각각 별개의 블록으로 도시되었으나, 한 실시 예에 따르면, 셀룰러 모듈 621, Wifi 모듈 623, BT 모듈 625, GPS 모듈 627 또는 NFC 모듈 628 중 적어도 일부(예: 두 개 이상)는 하나의 integrated chip(IC) 또는 IC 패키지 내에 포함될 수 있다. 예를 들면, 셀룰러 모듈 621, Wifi 모듈 623, BT 모듈 625, GPS 모듈 627 또는 NFC 모듈 628 각각에 대응하는 프로세서들 중 적어도 일부(예: 셀룰러 모듈 621에 대응하는 커뮤니케이션 프로세서 및 Wifi 모듈 623에 대응하는 Wifi 프로세서)는 하나의 SoC로 구현될 수 있다.
상기 RF 모듈 629는 데이터의 송수신, 예를 들면, RF 신호의 송수신을 할 수 있다. 상기 RF 모듈 629는, 도시되지는 않았으나, 예를 들면, 트랜시버(transceiver), PAM(power amp module), 주파수 필터(frequency filter) 또는 LNA(low noise amplifier) 등을 포함할 수 있다. 또한, 상기 RF 모듈 629는 무선 통신에서 자유 공간상의 전자파를 송수신하기 위한 부품, 예를 들면, 도체 또는 도선 등을 더 포함할 수 있다. 도 6에서는 셀룰러 모듈 621, Wifi 모듈 623, BT 모듈 625, GPS 모듈 627 및 NFC 모듈 628이 하나의 RF 모듈 629을 서로 공유하는 것으로 도시되어 있으나, 한 실시 예에 따르면, 셀룰러 모듈 621, Wifi 모듈 623, BT 모듈 625, GPS 모듈 627 또는 NFC 모듈 628 중 적어도 하나는 별개의 RF 모듈을 통하여 RF 신호의 송수신을 수행할 수 있다.
상기 SIM 카드 624는 가입자 식별 모듈을 포함하는 카드일 수 있으며, 전자 장치의 특정 위치에 형성된 슬롯에 삽입될 수 있다. 상기 SIM 카드 624는 고유한 식별 정보(예: ICCID(integrated circuit card identifier)) 또는 가입자 정보(예: IMSI(international mobile subscriber identity))를 포함할 수 있다.
상기 메모리 630(예: 상기 메모리 130)은 내장 메모리 632 또는 외장 메모리 634를 포함할 수 있다. 상기 내장 메모리 632는, 예를 들면, 휘발성 메모리(예: 상기 메모리 130)(예를 들면, DRAM(dynamic RAM), SRAM(static RAM), SDRAM(synchronous dynamic RAM) 등) 또는 비휘발성 메모리(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) 중 적어도 하나를 포함할 수 있다.
한 실시 예에 따르면, 상기 내장 메모리 632는 Solid State Drive (SSD)일 수 있다. 상기 외장 메모리 634는 flash drive, 예를 들면, CF(compact flash), SD(secure digital), Micro-SD(micro secure digital), Mini-SD(mini secure digital), xD(extreme digital) 또는 Memory Stick 등을 더 포함할 수 있다. 상기 외장 메모리 634는 다양한 인터페이스를 통하여 상기 전자 장치 600과 기능적으로 연결될 수 있다. 한 실시 예에 따르면, 상기 전자 장치 600은 하드 드라이브와 같은 저장 장치(또는 저장 매체)를 더 포함할 수 있다.
다양한 실시 예에 따르면, 메모리 630 중 휘발성 메모리로 마련된 적어도 일부 영역(예: 예약 영역)은 배터리 190으로부터 제공되는 전원에 의해 데이터 기입 상태를 유지할 수 있다. 이에 따라, 메모리 630은 동기 기입 방식에 따라 처리가 요구되는 파일의 입출력 또는 저널링과 관련하여 예약 영역을 기반으로 정의된 램디스크 75 영역을 제공할 수 있다. 메모리 630은 비동기 기입 방식에 따른 처리가 요구되는 파일의 입출력 또는 저널링과 관련하여 비휘발성 메모리(예: 상기 스토리지 180)를 제공할 수 있다.
상기 센서 모듈 640은 물리량을 계측하거나 전자 장치 600의 작동 상태를 감지하여, 계측 또는 감지된 정보를 전기 신호로 변환할 수 있다. 상기 센서 모듈 640은, 예를 들면, 제스처 센서 640A, 자이로 센서 640B, 기압 센서 640C, 마그네틱 센서 640D, 가속도 센서 640E, 그립 센서 640F, 근접 센서 640G, color 센서 640H(예: RGB(red, green, blue) 센서), 생체 센서 640I, 온/습도 센서 640J, 조도 센서 640K 또는 UV(ultra violet) 센서 640M 중의 적어도 하나를 포함할 수 있다. 추가적으로 또는 대체적으로, 상기 센서 모듈 640은, 예를 들면, 후각 센서(E-nose sensor, 미도시), EMG 센서(electromyography sensor, 미도시), EEG 센서(electroencephalogram sensor, 미도시), ECG 센서(electrocardiogram sensor, 미도시), IR(infra-red) 센서(미도시), 홍채 센서(미도시) 또는 지문 센서(미도시) 등을 포함할 수 있다. 상기 센서 모듈 640은 그 안에 속한 적어도 하나 이상의 센서들을 제어하기 위한 제어 회로를 더 포함할 수 있다.
상기 입력 장치 650은 터치 패널(touch panel) 652, (디지털) 펜 센서(pen sensor) 654, 키(key) 656 또는 초음파(ultrasonic) 입력 장치 658을 포함할 수 있다. 상기 터치 패널 652은, 예를 들면, 정전식, 감압식, 적외선 방식 또는 초음파 방식 중 적어도 하나의 방식으로 터치 입력을 인식할 수 있다. 또한, 상기 터치 패널 652는 제어 회로를 더 포함할 수도 있다. 정전식의 경우, 물리적 접촉 또는 근접 인식이 가능하다. 상기 터치 패널 652는 택타일 레이어(tactile layer)를 더 포함할 수도 있다. 이 경우, 상기 터치 패널 652는 사용자에게 촉각 반응을 제공할 수 있다.
상기 (디지털) 펜 센서 654는, 예를 들면, 사용자의 터치 입력을 받는 것과 동일 또는 유사한 방법 또는 별도의 인식용 쉬트(sheet)를 이용하여 구현될 수 있다. 상기 키 656는, 예를 들면, 물리적인 버튼, 광학식 키 또는 키패드를 포함할 수 있다. 상기 초음파(ultrasonic) 입력 장치 658는 초음파 신호를 발생하는 입력 도구를 통해, 전자 장치 600에서 마이크(예: 마이크 688)로 음파를 감지하여 데이터를 확인할 수 있는 장치로서, 무선 인식이 가능하다. 한 실시 예에 따르면, 상기 전자 장치 600은 상기 통신 모듈 620을 이용하여 이와 연결된 외부 장치(예: 컴퓨터 또는 서버)로부터 사용자 입력을 수신할 수도 있다.
다양한 실시 예에 따르면, 상기 입력 장치 650은 제1 표시 영역에서의 이벤트 발생을 지원할 수 있다. 예컨대, 입력 장치 650은 제1 표시 영역의 스크롤 동작과 관련한 터치 이벤트, 호버링 이벤트 등을 생성을 지원할 수 있다.
상기 디스플레이 660(예: 상기 디스플레이 150)은 패널 662, 홀로그램 장치 664 또는 프로젝터 666을 포함할 수 있다. 상기 패널 662은, 예를 들면, LCD(liquid-crystal display) 또는 AM-OLED(active-matrix organic light-emitting diode) 등일 수 있다. 상기 패널 662은, 예를 들면, 유연하게(flexible), 투명하게(transparent) 또는 착용할 수 있게(wearable) 구현될 수 있다. 상기 패널 662은 상기 터치 패널 652와 하나의 모듈로 구성될 수도 있다. 상기 홀로그램 장치 664는 빛의 간섭을 이용하여 입체 영상을 허공에 보여줄 수 있다. 상기 프로젝터 666은 스크린에 빛을 투사하여 영상을 표시할 수 있다. 상기 스크린은, 예를 들면, 상기 전자 장치 600의 내부 또는 외부에 위치할 수 있다. 한 실시 예에 따르면, 상기 디스플레이 660은 상기 패널 662, 상기 홀로그램 장치 664, 또는 프로젝터 666을 제어하기 위한 제어 회로를 더 포함할 수 있다.
디스플레이 660은 램디스크 75에 저장된 데이터와 스토리지 180에 저장된 데이터를 구분하여 표시할 수도 있다. 또한, 디스플레이 660은 램디스크 75 관리와 관련하여 LRU 파일 리스트를 제공하고, 신규 파일 로딩 시 리스트에서 사용자가 선택한 파일을 제거(evict)할 수 있도록 지원할 수 있다.
상기 인터페이스 670은, 예를 들면, HDMI(high-definition multimedia interface) 672, USB(universal serial bus) 674, 광 인터페이스(optical interface) 676 또는 D-sub(D-subminiature) 678을 포함할 수 있다. 상기 인터페이스 670은, 예를 들면, 도 1에 도시된 통신 인터페이스 160에 포함될 수 있다. 추가적으로 또는 대체적으로, 상기 인터페이스 670은, 예를 들면, MHL(mobile high-definition link) 인터페이스, SD(secure Digital) 카드/MMC(multi-media card) 인터페이스 또는 IrDA(infrared data association) 규격 인터페이스를 포함할 수 있다.
상기 오디오 모듈 680은 소리(sound)와 전기신호를 쌍방향으로 변환시킬 수 있다. 상기 오디오 모듈 680의 적어도 일부 구성요소는, 예를 들면, 도 1 에 도시된 입출력 인터페이스 140에 포함될 수 있다. 상기 오디오 모듈 680은, 예를 들면, 스피커 682, 리시버 684, 이어폰 686 또는 마이크 688 등을 통해 입력 또는 출력되는 소리 정보를 처리할 수 있다.
상기 카메라 모듈 691은 정지 영상 및 동영상을 촬영할 수 있는 장치로서, 한 실시 예에 따르면, 하나 이상의 이미지 센서(예: 전면 센서 또는 후면 센서), 렌즈(미도시), ISP(image signal processor, 미도시) 또는 플래쉬 (flash, 미도시)(예: LED 또는 xenon lamp)를 포함할 수 있다.
상기 전력 관리 모듈 695는 상기 전자 장치 600의 전력을 관리할 수 있다. 도시하지는 않았으나, 상기 전력 관리 모듈 695는, 예를 들면, PMIC(power management integrated circuit), 충전 IC(charger integrated circuit) 또는 배터리 또는 연료 게이지(battery or fuel gauge)를 포함할 수 있다. 전력 관리 모듈 695는 메인 배터리의 탈착이 발생하는 등에 의해 전원 공급이 중단되면, 배터리 190의 전원을 메모리 130 또는 메모리 130의 예약 영역에 공급되도록 제어할 수 있다.
상기 PMIC는, 예를 들면, 집적회로 또는 SoC 반도체 내에 탑재될 수 있다. 충전 방식은 유선과 무선으로 구분될 수 있다. 상기 충전 IC는 배터리를 충전시킬 수 있으며, 충전기로부터의 과전압 또는 과전류 유입을 방지할 수 있다. 한 실시 예에 따르면, 상기 충전 IC는 유선 충전 방식 또는 무선 충전 방식 중 적어도 하나를 위한 충전 IC를 포함할 수 있다. 무선 충전 방식으로는, 예를 들면, 자기공명 방식, 자기유도 방식 또는 전자기파 방식 등이 있으며, 무선 충전을 위한 부가적인 회로, 예를 들면, 코일 루프, 공진 회로 또는 정류기 등의 회로가 추가될 수 있다.
상기 배터리 게이지는, 예를 들면, 상기 배터리 696의 잔량, 충전 중 전압, 전류 또는 온도를 측정할 수 있다. 상기 배터리 696는 전기를 저장 또는 생성할 수 있고, 그 저장 또는 생성된 전기를 이용하여 상기 전자 장치 600에 전원을 공급할 수 있다. 상기 배터리 696는, 예를 들면, 충전식 전지(rechargeable battery) 또는 태양 전지(solar battery)를 포함할 수 있다. 배터리 696은 메인 배터리 또는 보조 배터리(예: 상기 배터리 190)을 포함할 수 있다.
상기 인디케이터 697은 상기 전자 장치 600 혹은 그 일부(예: 상기 AP 610)의 특정 상태, 예를 들면, 부팅 상태, 메시지 상태 또는 충전 상태 등을 표시할 수 있다. 상기 모터 698은 전기적 신호를 기계적 진동으로 변환할 수 있다. 도시되지는 않았으나, 상기 전자 장치 600은 모바일 TV 지원을 위한 처리 장치(예: GPU)를 포함할 수 있다. 상기 모바일 TV지원을 위한 처리 장치는, 예를 들면, DMB(digital multimedia broadcasting), DVB(digital video broadcasting) 또는 미디어플로우(media flow) 등의 규격에 따른 미디어 데이터를 처리할 수 있다.
본 발명의 다양한 실시 예에 따른 전자 장치의 전술한 구성요소들 각각은 하나 또는 그 이상의 부품(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, 상기 스토리지 180이 될 수 있다. 상기 프로그래밍 모듈의 적어도 일부는, 예를 들면, 상기 프로세서 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 : 스토리지 190 : 배터리

Claims (20)

  1. 전자 장치에 있어서, 휘발성 메모리;
    비 휘발성 메모리;
    상기 전자 장치에 메인 전원을 공급하는 메인 배터리;
    보조 배터리; 및
    상기 휘발성메모리, 상기 비 휘발성 메모리, 상기 메인 배터리 및 상기 보조 배터리와 통신하는 프로세서;를 포함하며,
    상기 프로세서는:
    파일 요청이 수신됨에 따라, 상기 요청된 파일이 동기 기입 방식에서 처리될 제 1 타입인지 또는 비동기 기입 방식에서 처리될 제 2 타입인지를 결정하고,
    상기 요청된 파일이 상기 제 1 타입인 것에 기반하여, 램디스크로 사용되는 상기 휘발성 메모리를 위해 예약된 고정 주소 영역을 기반으로 상기 램디스크와 연결되도록 구성된 제 1 저널링 장치(journaling file system)을 작동하고,
    상기 요청된 파일이 상기 제 2 타입인 것에 기반하여, 상기 비 휘발성 메모리와 연결되도록 구성된 제 2 저널링 장치를 작동하고,
    상기 메인 배터리에 의한 상기 메인 전원의 공급이 중단됨에 따라, 상기 휘발성 메모리의 데이터 기입 상태를 유지하기 위해 상기 보조 배터리를 사용하여 상기 휘발성 메모리에 전원을 공급하도록 구성된, 전자 장치.
  2. 삭제
  3. 제1항에 있어서,
    상기 프로세서는,
    상기 요청된 파일의 속성 또는 유형, 또는 상기 요청된 파일과 연관된 응용 프로그램의 유형 또는 속성을 기반으로 상기 요청된 파일이 상기 제 1 타입인지 상기 제 2 타입인지를 결정하도록 구성된, 전자장치.
  4. 제1항에 있어서,
    상기 프로세서는,
    상기 램디스크의 영역 또는 상기 램디스크와 관련된 메모리 영역을 상기 제 1 저널링 장치로 포맷하고 상기 제 1 저널링 장치를 마운트하도록 구성된, 전자 장치.
  5. 제1항에 있어서,
    상기 휘발성 메모리는,
    시스템 콜을 통해 상기 램디스크를 사용하여 파일 입출력을 처리할 파일 타입 또는 파일 명을 셋업하는 적어도 하나의 어플리케이션을 위한 영역;
    상기 적어도 하나의 어플리케이션의 운용과 관련된 파일의 처리를 지원하는 가상 파일 시스템(virtual file system)의 영역;
    상기 가상 파일 시스템을 통해 전달된 명령 또는 상기 파일의 속성에 기반하여 상기 동기 기입 방식에 따른 파일 처리와 상기 비동기 기입 방식에 따른 파일 처리를 제어하는 버퍼 파일 시스템(buffer file system)의 영역; 및
    상기 버퍼 파일 시스템의 제어에 따라 상기 동기 기입 방식 처리가 요구되는 파일을 처리하는 상기 램디스크의 영역; 중 적어도 하나를 포함하는, 전자 장치.
  6. 삭제
  7. 제1항에 있어서,
    상기 프로세서는,
    상기 휘발성 메모리의 상기 고정된 주소 영역을 확인하고, 상기 램디스크의 입출력 과정이 비정상적으로 종료된 후 재부팅 과정을 수행하면 상기 램디스크를 복구하도록 구성된, 전자 장치.
  8. 제1항에 있어서,
    상기 프로세서는,
    신규 파일이 상기 램디스크로 로딩될 시 상기 램디스크의 잔여 공간을 확인하고,
    상기 잔여 공간이 임계 값보다 작은 경우 상기 램디스크에 기입된 데이터들과 관련한 리스트를 기반으로 특정 파일을 상기 램디스크에서 제거하고 상기 제거된 특정 파일을 상기 비 휘발성 메모리에 이동하여 저장하도록 구성된, 전자 장치.
  9. 제8항에 있어서,
    상기 프로세서는,
    상기 리스트에 등록된 파일들 중 닫힘 상태이면서 가장 오래 사용되지 않은 파일 순으로 상기 램디스크로부터 이동 저장하는 전자 장치.
  10. 제1항에 있어서,
    상기 프로세서는,
    특정 이벤트의 발생에 기반하여 상기 램디스크의 파일을 상기 비 휘발성 메모리에 동기화하고, 상기 동기화의 완료에 따른 상태 표시를 제어; 또는
    상기 램디스크에 저장된 파일의 버전 값 및 상기 비 휘발성 메모리에 저장된 오리지널 버전의 파일의 버전 값의 비교 결과를 기반으로 파일 동기화가 수행될지 여부를 결정; 중 적어도 하나를 수행하도록 구성된, 전자 장치.
  11. 전자 장치에 의한 데이터 운용 방법에 있어서,
    파일 요청이 수신됨에 따라, 상기 요청된 파일이 동기 기입 방식에서 처리될 제 1 타입인지 또는 비동기 기입 방식에서 처리될 제 2 타입인지를 결정하고,
    상기 요청된 파일이 상기 제 1 타입인 것에 기반하여, 램디스크로 사용되는 상기 전자 장치의 휘발성 메모리를 위해 예약된 고정 주소 영역을 기반으로 상기 램디스크와 연결되도록 구성된 제 1 저널링 장치(journaling file system)을 작동하고,
    상기 요청된 파일이 상기 제 2 타입인 것에 기반하여, 상기 전자 장치의 비 휘발성 메모리와 연결되도록 구성된 제 2 저널링 장치를 작동하고,
    상기 전자 장치의 메인 배터리에 의한 상기 메인 전원의 공급이 중단됨에 따라, 상기 휘발성 메모리의 데이터 기입 상태를 유지하기 위해 상기 전자 장치의 보조 배터리를 사용하여 상기 휘발성 메모리에 전원을 공급하는, 데이터 운용 방법.
  12. 제11항에 있어서,
    상기 요청된 파일의 속성 또는 유형, 또는 상기 요청된 파일과 연관된 응용 프로그램의 유형 또는 속성을 기반으로 상기 요청된 파일이 상기 제 1 타입인지 상기 제 2 타입인지를 결정하는, 데이터 운용 방법.
  13. 제11항에 있어서,
    상기 램디스크 영역 또는 상기 램디스크와 관련한 메모리 영역을 상기 제 1 저널링 장치로 포맷하여 상기 제1 저널링 장치를 마운트하는 동작;
    상기 휘발성 메모리에 배치된 어플리케이션에 의해, 시스템 콜을 통해 상기 램디스크를 사용하여 파일 입출력을 처리할 파일 타입 또는 파일 명을 셋업하는 동작;
    상기 어플리케이션의 운용과 관련한 파일의 처리를 지원하는 가상 파일 시스템을 상기 휘발성 메모리에 배치하는 동작; 및
    상기 가상 파일 시스템을 통해 전달된 명령 또는 파일의 속성에 기반하여 상기 동기 기입 방식에 따른 파일 처리와 상기 비동기 기입 방식에 따른 파일 처리를 제어하는 버퍼 파일 시스템을 상기 휘발성 메모리에 배치하는 동작; 중 적어도 하나를 더 포함하는, 데이터 운용 방법.
  14. 제13항에 있어서,
    상기 비동기 기입 방식 처리가 요구되는 파일을 상기 비 휘발성 메모리에 전달하는 동작;을 더 포함하는, 데이터 운용 방법.
  15. 제11항에 있어서,
    상기 램디스크로 신규 파일을 로딩할 시 상기 램디스크의 잔여 공간을 확인하는 동작;
    상기 잔여 공간이 임계 값보다 작은 경우 상기 램디스크에 기입된 데이터들과 관련한 리스트를 기반으로 특정 파일을 상기 램디스크에서 제거하고 상기 제거된 특정 파일을 상기 비 휘발성 메모리에 이동하여 저장하는 동작;
    상기 특정 파일의 제거에 따라 확보된 영역을 기반으로 상기 신규 파일을 처리하는 동작;을 더 포함하는, 데이터 운용 방법.
  16. 제15항에 있어서,
    상기 이동하여 저장하는 동작은,
    상기 리스트에 등록된 파일들 중 닫힘 상태이면서 가장 오래 사용되지 않은 파일 순으로 상기 램디스크로부터 이동 저장하는 동작;을 포함하는 데이터 운용 방법.
  17. 제11항에 있어서,
    상기 제1 저널링 장치의 마운트 해제 작업, 상기 제1 저널링 장치의 읽기 전용 재 마운트 작업 또는 상기 제1 저널링 장치의 일시 중지 작업 시 상기 램디스크에 저장된 파일을 상기 비 휘발성 메모리와 동기화하는 동작; 및
    상기 램디스크에 저장된 상기 파일 동기화의 완료와 관련된 복구 완료 상태를 상기 램디스크의 영역에 표시하는 동작;을 더 포함하는, 데이터 운용 방법.
  18. 제17항에 있어서,
    상기 동기화하는 동작은,
    상기 램디스크에 저장된 파일의 제1 버전 값 및 상기 비 휘발성 메모리에 저장된 오리지널 버전의 파일의 제2 버전 값의 비교 결과를 기반으로 파일 동기화가 수행될지 여부를 결정하는 동작; 및
    상기 제 1 버전 값이 상기 제 2 버전 값 보다 큼에 따라, 상기 램디스크에 저장된 상기 파일의 상기 비 휘발성 메모리에 동기화를 수행하는 동작;을 더 포함하는, 데이터 운용 방법.
  19. 제11항에 있어서,
    상기 램디스크의 입출력 과정이 비정상적으로 종료된 후 재부팅 과정에서 상기 휘발성 메모리의 상기 고정된 주소 영역을 확인하는 동작을 더 포함하는, 데이터 운용 방법.
  20. 전자 장치의 데이터 프로세서에 의해 실행될 때 상기 전자 장치를 제어하는 명령어가 저장된 컴퓨터 판독 가능 저장매체(computer-readable storage media)에 있어서,
    상기 명령어는 상기 전자 장치의 프로세서로 하여금,
    파일 요청이 수신됨에 따라, 상기 요청된 파일이 동기 기입 방식에서 처리될 제 1 타입인지 또는 비동기 기입 방식에서 처리될 제 2 타입인지를 결정하고,
    상기 요청된 파일이 상기 제 1 타입인 것에 기반하여, 램디스크로 사용되는 상기 전자 장치의 휘발성 메모리를 위해 예약된 고정 주소 영역을 기반으로 상기 램디스크와 연결되도록 구성된 제 1 저널링 장치(journaling file system)을 작동하고,
    상기 요청된 파일이 상기 제 2 타입인 것에 기반하여, 상기 전자 장치의 비 휘발성 메모리와 연결되도록 구성된 제 2 저널링 장치를 작동하고,
    상기 전자 장치의 메인 배터리에 의한 상기 메인 전원의 공급이 중단됨에 따라, 상기 휘발성 메모리의 데이터 기입 상태를 유지하기 위해 상기 전자 장치의 보조 배터리를 사용하여 상기 휘발성 메모리에 전원을 공급하도록 하는,
    컴퓨터 판독 가능 저장 매체.

KR1020140094173A 2014-07-24 2014-07-24 데이터 운용 방법 및 전자 장치 KR102343642B1 (ko)

Priority Applications (5)

Application Number Priority Date Filing Date Title
KR1020140094173A KR102343642B1 (ko) 2014-07-24 2014-07-24 데이터 운용 방법 및 전자 장치
CN201580037994.7A CN106663053A (zh) 2014-07-24 2015-07-17 数据操作方法和电子设备
US15/322,268 US10459650B2 (en) 2014-07-24 2015-07-17 Data operation method and electronic device
PCT/KR2015/007455 WO2016013815A1 (ko) 2014-07-24 2015-07-17 데이터 운용 방법 및 전자 장치
EP15824756.9A EP3173932A4 (en) 2014-07-24 2015-07-17 Data operation method and electronic device

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020140094173A KR102343642B1 (ko) 2014-07-24 2014-07-24 데이터 운용 방법 및 전자 장치

Publications (2)

Publication Number Publication Date
KR20160012572A KR20160012572A (ko) 2016-02-03
KR102343642B1 true KR102343642B1 (ko) 2021-12-28

Family

ID=55163301

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020140094173A KR102343642B1 (ko) 2014-07-24 2014-07-24 데이터 운용 방법 및 전자 장치

Country Status (5)

Country Link
US (1) US10459650B2 (ko)
EP (1) EP3173932A4 (ko)
KR (1) KR102343642B1 (ko)
CN (1) CN106663053A (ko)
WO (1) WO2016013815A1 (ko)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110286995B (zh) * 2018-03-19 2022-02-25 北京兆易创新科技股份有限公司 一种数据读写方法和装置
CN111198843B (zh) * 2019-12-19 2023-03-28 西安交通大学 一种基于应用处理器片上总线控制的文件系统写加速方法
KR20230034695A (ko) * 2021-09-03 2023-03-10 삼성전자주식회사 전자장치 및 그 제어방법
CN116301669B (zh) * 2023-05-25 2023-08-11 成都凯天电子股份有限公司 一种基于fpga的高速存储系统分区方法及系统

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2009020572A (ja) * 2007-07-10 2009-01-29 Hitachi Industrial Equipment Systems Co Ltd プログラマブルロジックコントローラ
US20090089338A1 (en) * 2007-09-28 2009-04-02 Symantec Corporation Techniques for file system recovery
US20100241613A1 (en) * 2006-09-28 2010-09-23 Emc Corporation Co-operative locking between multiple independent owners of data space

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5519853A (en) * 1993-03-11 1996-05-21 Legato Systems, Inc. Method and apparatus for enhancing synchronous I/O in a computer system with a non-volatile memory and using an acceleration device driver in a computer operating system
US6219693B1 (en) * 1997-11-04 2001-04-17 Adaptec, Inc. File array storage architecture having file system distributed across a data processing platform
JP4055386B2 (ja) 2001-10-11 2008-03-05 三菱電機株式会社 情報処理装置
US7433898B1 (en) 2004-06-01 2008-10-07 Sanbolic, Inc. Methods and apparatus for shared storage journaling
US20050289152A1 (en) 2004-06-10 2005-12-29 Earl William J Method and apparatus for implementing a file system
US20080077590A1 (en) * 2006-09-22 2008-03-27 Honeywell International Inc. Efficient journaling and recovery mechanism for embedded flash file systems
TW200910187A (en) * 2007-08-21 2009-03-01 Sunplus Mmobile Inc Logged FAT file system and method of accessing the same
US8615496B2 (en) 2007-10-19 2013-12-24 Apple Inc. File system reliability using journaling on a storage medium
JP2009122815A (ja) * 2007-11-13 2009-06-04 Toshiba Corp ログ記録装置
CN101593128B (zh) * 2008-05-26 2013-03-06 上海未来宽带技术股份有限公司 基于实时操作系统的atca系统中的ipmc及其构建方法
US8392479B1 (en) 2009-09-14 2013-03-05 Symantec Corporation Method and apparatus for optimizing storage space allocation for computer data
JP5420358B2 (ja) 2009-09-24 2014-02-19 株式会社日立システムズ バッチ処理実行方法及びバッチ処理実行システム
CN101826984A (zh) * 2010-04-08 2010-09-08 中兴通讯股份有限公司 日志信息处理方法及装置
US8505003B2 (en) 2010-04-28 2013-08-06 Novell, Inc. System and method for upgrading kernels in cloud computing environments
US8468334B1 (en) 2011-01-28 2013-06-18 American Megatrends, Inc. Efficient initial RAM disk creation
WO2013036046A2 (ko) 2011-09-06 2013-03-14 삼성전자 주식회사 이동 단말 및 그 파일 시스템 관리 방법
US9864979B2 (en) * 2014-08-29 2018-01-09 Panasonic Intellectual Property Management Co., Ltd. Transaction terminal device

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100241613A1 (en) * 2006-09-28 2010-09-23 Emc Corporation Co-operative locking between multiple independent owners of data space
JP2009020572A (ja) * 2007-07-10 2009-01-29 Hitachi Industrial Equipment Systems Co Ltd プログラマブルロジックコントローラ
US20090089338A1 (en) * 2007-09-28 2009-04-02 Symantec Corporation Techniques for file system recovery

Also Published As

Publication number Publication date
KR20160012572A (ko) 2016-02-03
EP3173932A1 (en) 2017-05-31
US10459650B2 (en) 2019-10-29
EP3173932A4 (en) 2018-02-14
WO2016013815A1 (ko) 2016-01-28
CN106663053A (zh) 2017-05-10
US20170139634A1 (en) 2017-05-18

Similar Documents

Publication Publication Date Title
KR102367551B1 (ko) 전자 장치의 정보 처리 방법 및 장치
US10261683B2 (en) Electronic apparatus and screen display method thereof
US10025451B2 (en) Method and electronic device for managing screen
US20150288629A1 (en) Electronic device and method of providing information by electronic device
US9805437B2 (en) Method of providing preview image regarding display setting for device
US20160081028A1 (en) Information processing method and electronic device supporting the same
CN105980987B (zh) 任务调度方法和设备
US10402222B2 (en) Task migration method and apparatus
US20150220247A1 (en) Electronic device and method for providing information thereof
US10963208B2 (en) Electronic device and method for operating electronic device
KR102161443B1 (ko) 스마트 홈 시스템의 피 제어 장치 검색 및 제어 방법과 장치
KR102343642B1 (ko) 데이터 운용 방법 및 전자 장치
CN105830421B (zh) 电子装置及其操作方法
US10042856B2 (en) Method and electronic device for processing data
US10430046B2 (en) Electronic device and method for processing an input reflecting a user's intention
AU2015219606B2 (en) Method of providing preview image regarding display setting for device
US20150205459A1 (en) Method and device for managing folder
US9612790B2 (en) Method and electronic device for providing frame information
KR102252617B1 (ko) 데이터 전송 방법 및 이를 구현하는 장치
US20150288648A1 (en) Method and apparatus for managing dns addresses
US20160034165A1 (en) Activity processing method and electronic device supporting the same
US20150242370A1 (en) Method and apparatus for processing data
US20150356058A1 (en) Method for displaying images and electronic device for implementing the same
CN109844688B (zh) 片上系统、包括该片上系统的电子装置及其驱动方法
US20160066028A1 (en) Method and apparatus for data processing

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant