KR100433686B1 - 메모리,메모리를위한프로그래밍방법및프로그램회로 - Google Patents

메모리,메모리를위한프로그래밍방법및프로그램회로 Download PDF

Info

Publication number
KR100433686B1
KR100433686B1 KR10-1998-0702619A KR19980702619A KR100433686B1 KR 100433686 B1 KR100433686 B1 KR 100433686B1 KR 19980702619 A KR19980702619 A KR 19980702619A KR 100433686 B1 KR100433686 B1 KR 100433686B1
Authority
KR
South Korea
Prior art keywords
cell array
program
groups
zeros
byte
Prior art date
Application number
KR10-1998-0702619A
Other languages
English (en)
Other versions
KR19990064138A (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 아드밴스트 마이크로 디이바이시스 인코포레이티드
Publication of KR19990064138A publication Critical patent/KR19990064138A/ko
Application granted granted Critical
Publication of KR100433686B1 publication Critical patent/KR100433686B1/ko

Links

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/10Programming or data input circuits

Landscapes

  • Read Only Memory (AREA)

Abstract

프로그래밍 회로가 개별적으로 제어 가능한 한 세트의 그룹들로 세분되는 플래시 메모리를 위한 프로그래밍 알고리즘이 제공된다. 상기 알고리즘은 각각의 그룹에 의해 플래시 셀 어레이에 프로그램 될 논리 0의 수를 검출하며, 상기 플래시 셀 어레이에서 동시 프로그램 된 셀의 수가 미리 정해진 수를 초과하지 않도록, 그리고 최대 이용 가능한 프로그래밍 전류가 프로그래밍 속도를 증진시키는 데 이용되도록, 상기 그룹들 사이를 스위칭 한다.

Description

메모리, 메모리를 위한 프로그래밍 방법 및 프로그램 회로
플래시 메모리는 비휘발성 정보 저장을 제공하기 위해 다양한 컴퓨터 시스템에 흔히 이용되고 있다. 종래의 플래시 메모리는 전형적으로 플래시 메모리 셀에 정보를 프로그래밍 하는 프로그램 회로와 메모리 셀을 소거하는 소거 회로를 포함한다. 그렇지만, 프로그램 회로 및 소거 회로에 의해 요구되는 전압원 레벨들은 컴퓨터 시스템 전원으로부터 전형적으로 이용 가능한 전압원 레벨들과는 다르다.
종래의 플래시 메모리의 일부는 프로그램 회로 및 소거 회로를 수용하기 위해 다수의 전압원을 필요로 한다. 예를 들면, 종래의 플래시 메모리의 하나는 프로그램을 위한 VCC 전압원 및 개별적인 VPP 전압원을 필요로 한다. 유감스럽게도, 이러한 이중(dual) 전압원의 필요성은 이러한 이중 전원 플래시 메모리를 채용하는 컴퓨터 시스템을 위한 전력 시스템 설계의 복잡성을 더욱 증가시키고, 시스템의 전체적인 비용을 증가시킨다.
다른 한편, 단일 전원 플래시 메모리는 개별 플래시 메모리 셀을 프로그램하고 소거하는데 필요한 적절한 전압 레벨들 및 전기 전류 레벨들을 발생하는 특정회로를 통상적으로 포함한다. 예를 들면, 이러한 플래시 메모리는 전형적으로, 프로그래밍 동안 플래시 메모리 셀에 대한 입력들을 구동하는데 요구되는 적당한 전압 레벨로 단일 전원전압을 변환시키는 전하 펌프 회로(charge pump circuit)를 포함한다.
휴대용 컴퓨터와 같은 보다 최근의 컴퓨터 시스템은 이전의 시스템에 비해 비교적 저 전원전압 (VCC) 레벨로 기능하는 집적 회로 및 다른 소자를 이용한다. 예를 들면, 5v VCC 전원을 이용하는 종래의 노트북 컴퓨터 시스템은 현재 3v 이하의 VCC 전원으로 발전하고 있다.
유감스럽게도, 저 레벨의 전원전압은, 플래시 메모리의 전하 펌프 회로에 의해 발생될 수 있는 전기적 프로그래밍 전류량을 실제로 제한한다. 이용 가능한 프로그래밍 전류에 대한 제한은, 동시에 프로그램 될 수 있는 플래시 셀의 수를 제한함으로써 플래시 메모리의 전체 속도를 감소시킬 수 있다.
이론상, 전하 펌프 회로를 보다 크고 보다 복잡하게 구현함으로써, 플래시 메모리 셀의 전체 바이트 또는 워드를 동시에 프로그램 하는 데 요구되는 필요한 전류가 제공될 수 있다. 그러나, 보다 크고 보다 복잡한 전하 펌프 회로는 전형적으로 집적 회로 다이의 큰 면적을 차지한다. 전하 펌프에 전용적으로 이용되는 큰 면적의 집적 회로 다이 공간은 플래시 메모리 셀 및 관련 액세스 회로에 이용 가능한 다이 공간을 감소시키며 이에 의해 플래시 메모리의 전체 저장 용량을 제한한다. 다른 한편으로, 이러한 큰 면적의 다이 공간은 집적 회로 다이의 전체 사이즈의 상당한 증가를 요구하기 때문에, 제조 비용이 증가된다.
[발명의 개요]
본 발명의 한 목적은 단일 전원 플래시 메모리를 위한 신규한 프로그램 알고리즘을 제공하는 것이다.
본 발명의 다른 목적은 프로그래밍을 필요로 하는 플래시 메모리 셀에만 이용 가능한 프로그래밍 전류를 효율적으로 분배하는 프로그램 알고리즘을 제공하는 것이다.
본 발명의 다른 목적은 이용 가능한 프로그래밍 전류에 대한 제한이 있을지라도 최고속 프로그래밍 속도를 가능하게 하는 프로그래밍 알고리즘을 제공하는 것이다.
본 발명의 또 다른 목적은 바이트 모드 및 워드 모드 모두에서 동작하는 저 전압 단일 전원 플래시 메모리를 위한 프로그램 알고리즘을 제공하는 것이다.
상기 목적 및 다른 목적은 플래시 메모리를 위한 프로그래밍 알고리즘에 의해 제공된다. 플래시 메모리에 있어서 데이터 입력 버퍼 및 프로그래밍 회로는 한 세트의 개별적인 제어 가능 그룹들로 세분된다. 상기 알고리즘은 각각의 그룹에 의해 플래시 셀 어레이에 프로그램 될 특정 수의 논리 0을 검출한다. 상기 알고리즘은 플래시 셀 어레이에 있어서 동시에 프로그램 된 셀의 수가 미리 정해진 수를 초과하지 않도록, 최대 전류 용량이 이용되도록 그리고 프로그래밍을 위해 최대 전류성능이 이용되도록, 상기 그룹들 간에 스위칭을 행한다. 상기 미리 정해진 수는, 플래시 메모리에 있어서의 전하 펌프 회로의 과도한 사용(overtaxing)을 방지하면서 최대 프로그래밍 속도를 성취할 수 있도록 선택된다.
본 발명의 다른 목적, 특성 및 이점은 이하의 상세한 설명으로부터 명백해질 것이다.
본 발명은 그 특정의 예시적인 실시예에 대하여 설명되고 이에 따라서 도면이 참조된다.
본 발명은 플래시 메모리 분야에 관한 것이다. 특히, 저 전압 단일 전원 플래시 메모리, 이 메모리를 위한 프로그램 방법 및 프로그램 회로에 관한 것이다.
도 1은 프로그램 회로 및 플래시 셀 어레이를 포함하는 단일 전원 플래시 메모리 도시도.
도 2는 워드 검출기가 플래시 셀 어레이에 프로그램 될 5개 이하의 0을 검출할 때, 프로그램 제어 상태 머신이 프로그래밍 그룹 0 내지 3을 선택하는 시퀀스 도시도.
도 3은 저 바이트 검출기 및 고 바이트 검출기가 프로그래밍을 위한 5개 이하의 0을 검출하고, 0들과 고 바이트 및 저 바이트의 조합이 5 보다 클 때, 프로그램 제어 상태 머신이 그룹 0 내지 3을 선택하는 시퀀스 도시도.
도 4는 저 바이트 검출기가 프로그램 될 5개 이하의 0을 검출하고, 고 바이트 검출기가 플래시 셀 어레이에 프로그램 될 5개 이상의 0을 검출할 때, 프로그램 제어 상태 머신이 그룹 0 내지 3을 선택하는 시퀀스 도시도.
도 5는 저 바이트 검출기가 프로그램 될 5개 이상의 0을 검출하는 반면에, 고 바이트 검출기는 플래시 셀 어레이에 프로그램 될 5개 이하의 0을 검출할 때, 프로그램 제어 상태 머신이 그룹 0 내지 3을 선택하는 시퀀스 도시도.
도 6은 저 바이트 검출기가 프로그램 될 5개 이상의 0을 검출하고, 고 바이트 검출기도 플래시 셀 어레이에 프로그램 될 5개 이상의 0을 검출할 때, 프로그램 제어 상태 머신이 그룹 0 내지 3을 선택하는 시퀀스 도시도.
도 7은 플래시 셀 어레이에서의 바이트 모드 프로그래밍 및 워드 모드 프로그래밍 모두를 위한 프로그램 제어 상태 머신의 상태 도시도.
도 8은 일 실시예에서의 워드 검출기의 개략도,
도 9는 일 실시예에서의 저 바이트 검출기의 개략도.
도 10은 일 실시예에서의 고 바이트 검출기의 개략도.
도 11은 일 실시예에서의 프로그램 제어 상태 머신의 개략도.
도 1은 프로그램 회로(100) 및 플래시 셀 어레이(120)를 포함하는 단일 전원플래시 메모리(200)를 도시하고 있다. 프로그램 회로(100)는 저 VCC 전원 레벨에서의 동작을 가능하게 하는 단일 전원 플래시 메모리(200)를 위한 프로그램 알고리즘을 실현한다.
프로그램 회로(100)는 프로그램 제어 상태 머신(10), 저 바이트 검출기(20), 고 바이트 검출기(21) 및 워드 검출기(22)를 포함한다. 프로그램 회로(100)는 또한 Dinbuf0 내지 Dinbuf15(Dinbuf0-15)로 칭해지는 데이터 입력 버퍼 회로들의 세트를 포함한다. Dinbuf0-15 회로는 라인 I/00 내지 I/015(I/00-15)로 칭해지는 입력/출력 라인의 세트로 통해 입력/출력 포드(pod)의 대응 세트에 결합된다. Dinbuf0-15회로는 플래시 셀 어레이(120)의 비트 라인을 구동한다.
일 실시예에 있어서, 플래시 셀 어레이(120)는 폭이 16비트이고, 바이트 모드 및 워드 모드 모두에서 액세스 가능하다. Dinbuf0-15 회로에 결합된 플래시 셀 어레이의 각각의 16 비트 워드는 그룹 0 내지 그룹 3(그룹 0-3)으로 칭해지는 4개의 그룹으로 세분된다. 그룹 0은 데이터 입력 버퍼 Dinbuf0-3을 포함하고, 그룹 1은 Dinbuf4-7을 포함하고, 그룹 2는 Dinbuf8-11을 포함하며, 그룹 3은 Dinbuf12-15 를 포함한다.
그룹 0 및 그룹 1의 데이터 입력 버퍼는 플래시 및 어레이(120)를 위한 바이트 모드에서 프로그래밍 워드 또는 프로그래밍 바이트의 저 바이트로 조합되는 반면, 그룹 2 및 그룹 3의 입력 버퍼는 프로그래밍 워드의 고 바이트로 조합된다. 플래시 셀 어레이(120)를 위한 바이트 모드에서의 전체 프로그래밍 워드 또는 프로그래밍 바이트는, 모두 4개의 데이터 입력 버퍼 그룹, 즉 그룹 0-3을 포함한다.
프로그램 제어 상태 머신(10)은 프로그래밍 동작 동안 플래시 셀 어레이(120)의 대응 비트 라인을 구동하도록 하나 이상의 데이터 입력 버퍼 그룹 0-3을 선택한다. 프로그램 제어 상태 머신(10)은 한 세트의 제어 신호들 SOPGM 내지 S3PGM을 통해 그룹 0-3 간에 스위칭 한다. 프로그램 제어 상태 머신(10)은, 플래시 셀 어레이(120)에 타겟된(targeted) 프로그래밍 데이터의 내용물(content)과, 그리고 프로그램 회로(100)가 바이트 모드로 또는 워드 모드로 동작하는 지의 여부에 따라, 전체 바이트 또는 워드를 프로그램 하는 데 필요한 만큼 데이터 입력 버퍼 그룹 0-3을 스위칭 한다.
각 Dinbuf0-15는 플래시 셀 어레이(120)에서 대응 비트 라인의 세트를 구동하는 프로그램 회로를 포함한다. 프로그램 제어 상태 머신(10)은, 프로그래밍 동안플래시 셀 어레이(120)를 구동하는 드레인 펌프 회로(도시되지 않음)의 전류 출력을 Dinbuf0-15의 프로그래밍 회로가 과도하게 사용하지 않게 하는 시퀀스로 그룹 0-3을 활성화시킨다.
일 실시예에 있어서, 플래시 메모리(200)용 드레인 펌프 회로는 2.7v와 3.6v사이에서 변하는 전원전압 VCC로부터 5v에서 대략 2.5 밀리암페어의 프로그래밍 전류를 공급할 수 있다. 2.5 밀리암페어는 프로그램 동작 동안 5개까지의 플래시 메모리 셀의 드레인을 구동하기에 충분하다.
플래시 셀 어레이(120)의 워드 라인들 및 Y 통과 게이트들(pass gates)은, 프로그램 제어 상태 머신(10)이 그룹 0-3 사이에서의 필요한 스위칭을 완료하여 프로그래밍 동작을 완료할 때까지는 스위칭 되지 않는다. 플래시 메모리(200)에서 프로그램 검증 동작은 프로그래밍 시간을 절약하기 위하여 그룹 0-3의 스위칭 사이에서는 일어나지 않는다. 프로그래밍 검증 동작은 전체 워드 프로그램 동작 또는 전체 바이트 프로그램 동작의 완료 후에 수행된다.
프로그램 검증 동작이 실패인 경우, 전체 워드 또는 전체 바이트는 동일한 프로그램 프로세스에 따라 재프로그램 된다. 재프로그래밍 동안, 실패한 프로그램 셀만이 후속의 프로그램 사이클에서 프로그램된다. 이에 의해, 초기 프로그램 사이클 동안에 정확하게 프로그램 된 플래시 셀들의 과도한 프로그래밍을 방지한다.
저 바이트 검출기(20), 고 바이트 검출기(21) 및 워드 검출기(22)는 각각 한 세트의 제어 신호 X4BL, X4BH 및 X4BW를 발생한다. 프로그램 제어 상태 머신(10)은 다른 정보와 함께 제어 신호 X4BL, X4BH 및 X4BW를 사용하여 그룹 0-3을 위한 적당한 스위칭 시퀀스를 결정한다.
저 바이트의 검출기(20)는 플래시 셀 어레이(120)의 저 바이트에 프로그램 될 실제의 논리 "0" 상태를 나타내는 한 세트의 신호 Din(0:7)을 수신한다. 저 바이트의 검출기(20)가 Din(0:7) 데이터에서 5개 이하의 0을 검출하는 경우, 제어 신호 X4BL는 하이(high)로 표명(assert) 된다. 저 바이트의 검출기(20)가 Din(0:7) 데이터에서 5개 이상의 0을 검출하는 경우, 제어 신호 X4BL는 로우(low)로 표명된다.
마찬가지로, 고 바이트 검출기(21)는 플래시 셀 어레이(120)의 고 바이트에 프로그램 될 실제의 논리 "0" 상태를 나타내는 한 세트의 신호 Din(8:15)을 수신한다. 고 바이트의 검출기(21)는 Din(8:15) 데이터에서 5개 이하의 0이 검출되는 경우 제어 신호 X4BH는 하이로 표명되고, 그렇지 않을 경우에는 제어 신호 X4BH는 로우로 표명된다.
워드 검출기(22)는 신호 Din(0:15)을 수신하여, 플래시 셀 어레이(120)의 워드에 프로그램 될 실제의 논리 "0" 상태를 검출한다. 워드 검출기(22)는 Din(0:15) 데이터에서 5개 이하의 0이 검출될 경우에 제어 신호 X4BW를 하이로 표명시키고, 그렇지 않을 경우에는 제어 신호 X4BW를 로우로 표명시킨다.
프로그램 제어 상태 머신(10)은 BYTE 신호 및 HBYTE 신호와 함께 제어 신호 X4BL, X4BH 및 X4BW를 이용하여, 그룹 0-3이 플래시 및 어레이(120)를 프로그램 하게 하는 적당한 시퀀스를 결정한다. 프로그램 제어 상태 머신(10)은 프로그래밍 클 록(PGMCLK)에 의해 클록된다. BYTE 신호는 플래시 메모리(200)가 바이트 모드로 액세스되는지 또는 워드 모드로 액세스되는지를 나타낸다. HBYTE 신호는 바이트 모드가 표시되는 경우에, 플래시 셀 어레이(120)에서 고 바이트가 프로그램 되는지 또는 저 바이트가 프로그램 되는지를 나타낸다.
프로그램 제어 상태 머신(10)은 그룹 0-3을 위한 한 세트의 프로그래밍 제어신호를 발생한다. 상기 프로그래밍 제어 신호는 그룹 0을 선택하는 SOPGM 신호, 그룹 1을 선택하는 SIPGM 신호, 그룹 2를 선택하는 S2PGM 신호 및, 그룹 3을 선택하는 S3PGM 제어 신호를 포함한다. S0 내지 S3PGM 제어 신호는 또한 플래시 셀 어레이(120)에서의 프로그램 동작의 완료 후 프로그램 제어 상태 머신(10)이 언제 프로그램 프로세스를 종료시키는지를 결정한다.
도 2는 워드 검출기(22)가 플래시 셀 어레이(120)에 프로그램 될 5개 이하의 0을 검출하는 경우, 프로그램 제어 상태 머신(10)이 그룹 0-3을 선택하는 워드 모드 프로그래밍을 위한 시퀀스를 도시하고 있다. 이러한 프로그래밍 시퀀스에서, S0PGM 내지 S3PGM 신호는 시간 t1 및 t2 사이에서 동시에 활성화되어, 그룹 0-3에 의해 플래시 셀 어레이(120)의 프로그래밍을 동시에 가능하게 한다.
도 3은 저 바이트 검출기(20)가 프로그래밍을 위한 5개 이하의 0을 검출하고, 고 바이트 검출기(21)가 프로그래밍을 위한 5개 이하의 0을 검출하며, 0들과 고 바이트 및 저 바이트의 조합이 5보다 큰 경우, 프로그램 제어 상태 머신(10)이 그룹 0-3을 선택하는 워드 모드 프로그래밍을 위한 시퀀스를 도시하고 있다. 이러한 프로그래밍 시퀀스에서, 프로그램 제어 상태 머신은 시간 t3 및 t4 사이에서 S0PGM 및 S1PGM 제어 신호를 활성화시켜, 플래시 셀 어레이(120)에서 그룹 0 및 1의 프로그래밍을 가능하게 한다. 시간 t4 및 t5 사이에서, 프로그램 제어 상태 머신(10)은 S2PGM 및 S3PGM 제어 신호를 활성화시켜, 그룹 2 및 3 에 의해 프로그래밍을 활성화시킨다.
도 4는 저 바이트 검출기(20)가 프로그램 될 5개 이하의 0을 검출하고, 고 바이트 검출기(21)가 플래시 셀 어레이(120)에 프로그램 될 5개 이상의 0을 검출하는 경우, 프로그램 제어 상태 머신(10)이 그룹 0-3을 선택하는 워드 모드 프로그래밍을 위한 시퀀스를 도시하고 있다. 이러한 시퀀스에서, 프로그램 제어 상태 머신(10)은 시간 t6 및 t7 사이에서 그룹 0 및 1을 활성화시키고, 이어서 시간 t7 및 t8 사이에서 그룹 2를 활성화시키며, 이어서 시간 t8 및 t9 사이에서 그룹 3을 활성화시킨다.
도 5는 저 바이트 검출기(20)가 프로그래밍 될 5개 이상의 0을 검출하는 반면, 고 바이트 검출기(21)는 플래시 셀 어레이(120)에 프로그래밍 될 5개 이하의 0을 검출하는 경우, 프로그램 제어 상태 머신(10)이 그룹 0-3을 선택하는 워드 모드 프로그래밍을 위한 시퀀스를 도시하고 있다. 이러한 시퀀스에서, 프로그램 제어 상태 머신(10)은 시간 t10 및 t11 사이에서 그룹 0을 활성화시키고, 이어서 시간 t11 및 t12 사이에서 그룹 1을 활성화시킨다. 그룹 0 및 1의 프로그래밍 완료 후에, 프로그램 제어 상태 머신(10)은 시간 t12 및 t13 사이에서 그룹 2 및 3을 동시에 활성화시켜, 프로그래밍 시퀀스를 완료한다.
도 6은 프로그램 제어 상태 머신(10)이 그룹 0-3을 선택하는 워드 모드 프로그래밍을 위한 시퀀스를 도시한 것으로, 여기서 저 바이트 검출기(20)가 프로그래밍 될 5개 이상의 0을 검출하고, 고 바이트 검출기(21) 또한 플래시 셀 어레이(120)에 프로그래밍 될 5개 이상의 0을 검출한다. 이러한 경우에, 프로그램제어 상태 머신(10)은 그룹 0-3을 개별 구간에서 순차적으로 활성화시킨다. 프로그램 제어 상태 머신(10)은 시간 t14 및 t15 사이에서 그룹 0, 시간 t15 및 t16 사이에서 그룹 1, 시간 t16 및 t17 사이에서 그룹 2, 그리고 시간 t17 및 t18 사이에서 그룹 3을 활성화시킨다.
도 7은 플래시 셀 어레이(120)에서의 바이트 모드 프로그래밍 및 워드 모드 프로그래밍 모두를 위한 프로그램 제어 상태 머신(10)의 상태를 도시하고 있다. 저 바이트 검출 칼럼은 X4BL 제어 신호의 상태를 나타내고, 고 바이트 검출 칼럼은 X4BH 제어 신호의 상태를 나타내며, 워드 검출 칼럼은 X4BW 제어 신호의 상태를 나타낸다. 각각의 프로그래밍 시퀀스는 제 1 PGM 서브펄스 내지 제 4 PGM 서브펄스로 칭해지는 4개까지의 프로그램 서브펄스를 포함할 수 있다. 각각의 서브펄스 동안, 프로그램 제어 상태 머신(10)의 상태는 제어 신호 S0PGM 내지 S3PGM에 대응하는 상태 S0 내지 S3으로 표시된다.
도 2 내지 6에 대해 전술된 바와 같이, 프로그램 제어 상태 머신(10)의 워드 모드는 5개의 가능한 프로그래밍 시퀀스를 생성한다. 바이트 모드에서, 고 바이트 프로그래밍 및 저 바이트 프로그래밍 각각은 도 7에서 표시된 바와 같은 2개의 가능한 프로그래밍 시퀀스를 포함한다.
도 8은 일 실시예에서의 워드 검출기(22)의 개략도이다. 워드 검출기(22)는 DIN(15:0) 신호 라인 상에 표시된 0의 수를 결정하는 아날로그 합산 회로를 포함한다.
도 9 및 10은 각각 저 바이트 검출기(20) 및 고 바이트 검출기(21)의 개략도이다. 저 바이트 검출기(20) 및 고 바이트 검출기(21) 각각은 대응하는 입력 데이터 라인 DIN(7:0) 또는 DIN(15:8)에서 0의 수를 결정하는 아날로그 합산 회로를 포함한다.
도 11은 일 실시예에서의 프로그램 제어 상태 머신(10)의 개략도이다. 상태 S0 내지 S3은 프로그램 제어 상태 머신에 대한 다음 상태를 나타낸다.
본 발명의 전술한 상세한 설명은 설명을 목적을 위해 제공된 것이며, 본 발명을 기술된 실시예로 제한하도록 의도된 것이 아니다. 따라서, 본 발명의 범주는 첨부한 청구의 범위에 의해 정의된다.

Claims (19)

  1. 메모리(200)내의 프로그래밍 회로(100)를 한 세트의 그룹들로 세분하는 단계 및 최대 이용 가능한 프로그래밍 전류를 사용하는 동안 셀 어레이(120)에서 동시 프로그램 된 셀의 수가 미리 정해진 수를 초과하지 않도록 상기 그룹들 간을 스위칭 하는 단계를 포함하는, 메모리 셀(120)의 어레이를 포함하는 메모리(200)에 대한 프로그래밍 방법에 있어서,
    각 그룹에 의해 셀 어레이에 프로그램 될 논리 0의 수를 검출하는 단계와; 그리고 상기 검출된 0의 수에 따라 상기 그룹들 간의 스위칭을 제어하는 단계를 포함하는 것을 특징으로 하는 메모리에 대한 프로그래밍 방법.
  2. 제 1 항에 있어서,
    상기 검출된 0의 전체 수가 상기 미리 정해진 셀의 수를 초과하지 않는 그룹들은 동시에 활성화되는 반면에, 상기 검출된 0의 전체 수가 상기 미리 정해진 수를 초과하는 그룹들은 순차적으로 활성화되도록 상기 그룹들 간의 스위칭을 제어하는 것을 특징으로 하는 메모리를 위한 프로그래밍 방법.
  3. 제 1 또는 2항에 있어서,
    상기 논리 0의 수는 상기 셀 어레이에 타겟된(targeted) 프로그램 바이트(20, 21)에서 검출되는 것을 특징으로 하는 메모리를 위한 프로그래밍 방법.
  4. 제 3 항에 있어서,
    상기 프로그램 바이트는 상기 셀 어레이의 고 바이트로 이루어지는 것을 특징으로 하는 메모리를 위한 프로그래밍 방법.
  5. 제 3 항에 있어서,
    상기 프로그램 바이트는 상기 셀 어레이의 저 바이트로 이루어지는 것을 특징으로 하는 메모리를 위한 프로그래밍 방법.
  6. 제 1 또는 2 항에 있어서,
    상기 논리 0의 수는 상기 셀 어레이에 타겟된 프로그램 워드에서 검출되는 것을 특징으로 하는 메모리를 위한 프로그래밍 방법.
  7. 제 1 항에 있어서,
    상기 메모리(200)는 저 전압 단일 전원 플래시 메모리인 것을 특징으로 하는 메모리를 위한 프로그래밍 방법.
  8. 한 세트의 개별적으로 제어 가능한 그룹들 및 스위칭 회로(10)로 배열되는 프로그래밍 회로(100)를 포함하며, 상기 스위칭 회로(10)는 메모리(200)의 셀 어레이(120)에 동시에 프로그램 된 셀의 수가 미리 정해진 수를 초과하지 않고 또한 최대 이용 가능한 프로그래밍 전류를 사용하도록 상기 그룹들 간을 스위칭 하는 메모리(200)에 있어서,
    각각의 그룹에 의해 상기 셀 어레이에 프로그램 될 논리 0의 수를 검출하는 검출 회로(20, 21, 22)와; 그리고
    상기 검출된 0의 수에 따라 스위칭 시퀀스를 제어하는 제어 수단(10)을 포함하는 것을 특징으로 하는 메모리.
  9. 제 8 항에 있어서,
    상기 제어 수단(10)은 상기 검출된 0의 전체 수가 셀들의 상기 미리 정해진 수를 초과하지 않는 그룹들을 동시에 활성화시키고, 상기 0의 전체 수가 상기 미리 정해진 수를 초과하는 그룹들을 순차적으로 활성화시키는 것을 특징으로 하는 메모리.
  10. 제 8 또는 9 항에 있어서,
    상기 제어 수단(10)은 상태 머신을 포함하는 것을 특징으로 하는 메모리.
  11. 제 10 항에 있어서,
    상기 검출 회로(20, 21, 22)는 상기 셀 어레이에 타겟된 프로그램 바이트에 포함되는 논리 0의 수를 결정하는 것을 특징으로 하는 메모리.
  12. 제 11 항에 있어서,
    상기 프로그램 바이트는 상기 셀 어레이의 고 바이트로 이루어지는 것을 특징으로 하는 메모리.
  13. 제 11 항에 있어서,
    상기 프로그램 바이트는 상기 셀 어레이의 저 바이트로 이루어진 것을 특징으로 하는 메모리.
  14. 제 8 또는 9 항에 있어서,
    상기 검출 회로(20, 21, 22)는 상기 셀 어레이에 타겟된 프로그램 워드에 포함되는 논리 0의 수를 결정하는 것을 특징으로 하는 메모리.
  15. 제 8 또는 9 항에 있어서,
    상기 셀 어레이(120)는 저 전압 단일 전원 플래시 메모리를 위한 플래시 셀 어레이를 포함하는 것을 특징으로 하는 메모리.
  16. 플래시 셀 어레이를 갖는 플래시 메모리에 대한 프로그램 회로에 있어서,
    상기 플래시 셀 어레이에 프로그램될 바이트 혹은 워드에서 논리 상태를 검출하고, 상기 검출에 근거하여 제어 신호들을 발생하는 검출기와;
    상기 검출기로부터의 제어 신호들에 따라 상기 플래시 셀 어레이를 프로그램하는 시퀀스를 결정하고, 상기 결정에 근거하여 프로그램 제어신호들을 발생하는 상태 머신과; 그리고
    각각 상기 상태 머신으로부터의 프로그램 제어 신호들에 따라 상기 플래시 메모리 셀 어레이를 프로그램하는 동작을 하는 복수의 데이터 입력 버퍼회로(Dinbuf0-15)를 포함하는 프로그램 회로.
  17. 제 16항에 있어서,
    상기 검출기는 검출된 논리 제로들의 수가 소정의 범위내에 있는지의 여부에 따라 제어 신호들을 발생하는 것을 특징으로 하는 프로그램 회로.
  18. 제 16항에 있어서,
    상기 데이터 입력 버퍼 회로들은 그룹들(groups 0-3)로 분할되는 것을 특징으로 하는 프로그램 회로.
  19. 제 18항에 있어서,
    상기 상태 머신은 상기 그룹 각각에 프로그램 제어 신호를 인가함으로써, 상기 그룹들을 선택적으로 활성화시키는 것을 특징으로 하는 프로그램 회로.
KR10-1998-0702619A 1995-11-01 1996-07-19 메모리,메모리를위한프로그래밍방법및프로그램회로 KR100433686B1 (ko)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US8/551705 1995-11-01
US08/551,705 US5644531A (en) 1995-11-01 1995-11-01 Program algorithm for low voltage single power supply flash memories
US08/551705 1995-11-01

Publications (2)

Publication Number Publication Date
KR19990064138A KR19990064138A (ko) 1999-07-26
KR100433686B1 true KR100433686B1 (ko) 2004-09-10

Family

ID=24202345

Family Applications (1)

Application Number Title Priority Date Filing Date
KR10-1998-0702619A KR100433686B1 (ko) 1995-11-01 1996-07-19 메모리,메모리를위한프로그래밍방법및프로그램회로

Country Status (7)

Country Link
US (1) US5644531A (ko)
EP (1) EP0858661B1 (ko)
JP (1) JP3947781B2 (ko)
KR (1) KR100433686B1 (ko)
DE (1) DE69605684T2 (ko)
TW (1) TW298631B (ko)
WO (1) WO1997016831A1 (ko)

Families Citing this family (43)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5430859A (en) * 1991-07-26 1995-07-04 Sundisk Corporation Solid state memory system including plural memory chips and a serialized bus
US6728851B1 (en) * 1995-07-31 2004-04-27 Lexar Media, Inc. Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices
US5890192A (en) 1996-11-05 1999-03-30 Sandisk Corporation Concurrent write of multiple chunks of data into multiple subarrays of flash EEPROM
US5787039A (en) * 1997-03-06 1998-07-28 Macronix International Co., Ltd. Low current floating gate programming with bit-by-bit verification
DE19754704A1 (de) * 1997-12-10 1999-06-24 Bosch Gmbh Robert Verfahren zum Beschreiben und/oder Löschen eines flash-EPROMs
US6928001B2 (en) 2000-12-07 2005-08-09 Saifun Semiconductors Ltd. Programming and erasing methods for a non-volatile memory cell
US6563339B2 (en) * 2001-01-31 2003-05-13 Micron Technology, Inc. Multiple voltage supply switch
US6665769B2 (en) * 2001-04-05 2003-12-16 Saifun Semiconductors Ltd. Method and apparatus for dynamically masking an N-bit memory array having individually programmable cells
US6584017B2 (en) 2001-04-05 2003-06-24 Saifun Semiconductors Ltd. Method for programming a reference cell
GB0123416D0 (en) 2001-09-28 2001-11-21 Memquest Ltd Non-volatile memory control
US6700818B2 (en) * 2002-01-31 2004-03-02 Saifun Semiconductors Ltd. Method for operating a memory device
US7190620B2 (en) * 2002-01-31 2007-03-13 Saifun Semiconductors Ltd. Method for operating a memory device
US6917544B2 (en) 2002-07-10 2005-07-12 Saifun Semiconductors Ltd. Multiple use memory chip
US7136304B2 (en) 2002-10-29 2006-11-14 Saifun Semiconductor Ltd Method, system and circuit for programming a non-volatile memory array
ITMI20022387A1 (it) * 2002-11-12 2004-05-13 Simicroelectronics S R L Circuito per programmare un dispositivo di memoria non-volatile con
US6967896B2 (en) * 2003-01-30 2005-11-22 Saifun Semiconductors Ltd Address scramble
US7178004B2 (en) 2003-01-31 2007-02-13 Yan Polansky Memory array programming circuit and a method for using the circuit
US6987695B2 (en) * 2003-03-25 2006-01-17 Promos Technologies Inc. Writing data to nonvolatile memory
US7046551B2 (en) 2003-03-25 2006-05-16 Mosel Vitelic, Inc. Nonvolatile memories with asymmetric transistors, nonvolatile memories with high voltage lines extending in the column direction, and nonvolatile memories with decoding circuits sharing a common area
US7343470B1 (en) * 2003-09-26 2008-03-11 Altera Corporation Techniques for sequentially transferring data from a memory device through a parallel interface
US7652930B2 (en) 2004-04-01 2010-01-26 Saifun Semiconductors Ltd. Method, circuit and system for erasing one or more non-volatile memory cells
US7366025B2 (en) * 2004-06-10 2008-04-29 Saifun Semiconductors Ltd. Reduced power programming of non-volatile cells
US7379372B2 (en) 2004-09-15 2008-05-27 Samsung Electronics Co., Ltd. Non-volatile memory device with scanning circuit and method
US7638850B2 (en) 2004-10-14 2009-12-29 Saifun Semiconductors Ltd. Non-volatile memory structure and method of fabrication
US8053812B2 (en) 2005-03-17 2011-11-08 Spansion Israel Ltd Contact in planar NROM technology
KR100706245B1 (ko) 2005-04-13 2007-04-11 삼성전자주식회사 비트 스캔 방식을 사용한 노어 플래시 메모리 장치 및그것의 프로그램 방법
US8400841B2 (en) 2005-06-15 2013-03-19 Spansion Israel Ltd. Device to program adjacent storage cells of different NROM cells
US7804126B2 (en) 2005-07-18 2010-09-28 Saifun Semiconductors Ltd. Dense non-volatile memory array and method of fabrication
US7668017B2 (en) 2005-08-17 2010-02-23 Saifun Semiconductors Ltd. Method of erasing non-volatile memory cells
US7443732B2 (en) * 2005-09-20 2008-10-28 Spansion Llc High performance flash memory device capable of high density data storage
US7808818B2 (en) 2006-01-12 2010-10-05 Saifun Semiconductors Ltd. Secondary injection for NROM
US8253452B2 (en) 2006-02-21 2012-08-28 Spansion Israel Ltd Circuit and method for powering up an integrated circuit and an integrated circuit utilizing same
US7692961B2 (en) 2006-02-21 2010-04-06 Saifun Semiconductors Ltd. Method, circuit and device for disturb-control of programming nonvolatile memory cells by hot-hole injection (HHI) and by channel hot-electron (CHE) injection
US7760554B2 (en) 2006-02-21 2010-07-20 Saifun Semiconductors Ltd. NROM non-volatile memory and mode of operation
US7701779B2 (en) 2006-04-27 2010-04-20 Sajfun Semiconductors Ltd. Method for programming a reference cell
JP4666394B2 (ja) * 2007-07-09 2011-04-06 ルネサスエレクトロニクス株式会社 データ処理装置
US8161310B2 (en) * 2008-04-08 2012-04-17 International Business Machines Corporation Extending and scavenging super-capacitor capacity
US8040750B2 (en) * 2008-06-25 2011-10-18 International Business Machines Corporation Dual mode memory system for reducing power requirements during memory backup transition
US8219740B2 (en) * 2008-06-25 2012-07-10 International Business Machines Corporation Flash sector seeding to reduce program times
US8037380B2 (en) 2008-07-08 2011-10-11 International Business Machines Corporation Verifying data integrity of a non-volatile memory system during data caching process
US8093868B2 (en) * 2008-09-04 2012-01-10 International Business Machines Corporation In situ verification of capacitive power support
US8243532B2 (en) * 2010-02-09 2012-08-14 Infineon Technologies Ag NVM overlapping write method
US9123401B2 (en) * 2012-10-15 2015-09-01 Silicon Storage Technology, Inc. Non-volatile memory array and method of using same for fractional word programming

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5430674A (en) * 1993-09-10 1995-07-04 Intel Corporation Method and apparatus for sequential programming of a flash EEPROM memory array

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2900523B2 (ja) * 1990-05-31 1999-06-02 日本電気株式会社 不揮発性半導体メモリ装置の書込回路
US5245572A (en) * 1991-07-30 1993-09-14 Intel Corporation Floating gate nonvolatile memory with reading while writing capability
US5508968A (en) * 1994-08-12 1996-04-16 International Business Machines Corporation Dynamic random access memory persistent page implemented as processor register sets

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5430674A (en) * 1993-09-10 1995-07-04 Intel Corporation Method and apparatus for sequential programming of a flash EEPROM memory array

Also Published As

Publication number Publication date
EP0858661B1 (en) 1999-12-15
US5644531A (en) 1997-07-01
DE69605684D1 (de) 2000-01-20
DE69605684T2 (de) 2000-11-23
JP3947781B2 (ja) 2007-07-25
WO1997016831A1 (en) 1997-05-09
TW298631B (en) 1997-02-21
EP0858661A1 (en) 1998-08-19
KR19990064138A (ko) 1999-07-26
JPH11514775A (ja) 1999-12-14

Similar Documents

Publication Publication Date Title
KR100433686B1 (ko) 메모리,메모리를위한프로그래밍방법및프로그램회로
US5111079A (en) Power reduction circuit for programmable logic device
US5430674A (en) Method and apparatus for sequential programming of a flash EEPROM memory array
US5907700A (en) Controlling flash memory program and erase pulses
JP2648840B2 (ja) 半導体記憶装置
KR100908542B1 (ko) 불휘발성 메모리 소자 및 그 프로그램 방법
JPH0845290A (ja) メモリ集積回路およびそのメモリセルのプログラム方法
EP0831397A2 (en) A method and apparatus for operation control of memories
US6064603A (en) Non-volatile semiconductor storage device
US5748939A (en) Memory device with a central control bus and a control access register for translating an access request into an access cycle on the central control bus
JPH03254499A (ja) 半導体記憶装置
JP2003233996A (ja) 半導体記憶装置
KR970016962A (ko) 반도체 메모리 시스템, 프로그래머블 어레이 및 액세스 시간 감소 방법 및 시스템
US6125057A (en) Segmented source memory array
US6052806A (en) Method and apparatus for testing an integrated circuit device
EP0701325A1 (en) Timing circuit
US6870383B2 (en) Semiconductor device with high speed switching of test modes
JP2544027B2 (ja) 低消費電力型プログラマブルロジックアレイおよびそれを用いた情報処理装置
US6081472A (en) Cell refresh circuit of memory device
EP0642135B1 (en) A nonvolatile semiconductor memory and its test method
US6845040B2 (en) Nonvolatile memory
CN112863576A (zh) Nand闪存的字线偏置电压生成电路
JP2002149486A (ja) メモリシステム
JPH10511205A (ja) プログラムロードサイクルを終了させるためのプロトコルを有する浮遊ゲートメモリデバイス
JPH0254494A (ja) Ram制御回路

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
FPAY Annual fee payment

Payment date: 20130429

Year of fee payment: 10

FPAY Annual fee payment

Payment date: 20140512

Year of fee payment: 11

FPAY Annual fee payment

Payment date: 20150520

Year of fee payment: 12

EXPY Expiration of term