summaryrefslogtreecommitdiff
path: root/firmware/target/arm/s5l8700
diff options
context:
space:
mode:
authorMichael Sparmann <theseven@rockbox.org>2009-10-11 12:45:27 +0000
committerMichael Sparmann <theseven@rockbox.org>2009-10-11 12:45:27 +0000
commit264d877889c698736143df6d2cf9648c472c3c52 (patch)
tree6955149c11a2fe02590f3ac775083f46188d68f7 /firmware/target/arm/s5l8700
parenta79dc877615c2af571bf0416dd2867c000701e7e (diff)
downloadrockbox-264d877889c698736143df6d2cf9648c472c3c52.tar.gz
rockbox-264d877889c698736143df6d2cf9648c472c3c52.zip
Add a thread to power down the NAND after inactivity on the iPod Nano 2G
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@23106 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/target/arm/s5l8700')
-rw-r--r--firmware/target/arm/s5l8700/ata-nand-s5l8700.c31
1 files changed, 28 insertions, 3 deletions
diff --git a/firmware/target/arm/s5l8700/ata-nand-s5l8700.c b/firmware/target/arm/s5l8700/ata-nand-s5l8700.c
index 308f0a5e61..d00580279b 100644
--- a/firmware/target/arm/s5l8700/ata-nand-s5l8700.c
+++ b/firmware/target/arm/s5l8700/ata-nand-s5l8700.c
@@ -37,6 +37,8 @@ long last_disk_activity = -1;
37/** static, private data **/ 37/** static, private data **/
38static bool initialized = false; 38static bool initialized = false;
39 39
40static long nand_stack[20];
41
40/* API Functions */ 42/* API Functions */
41 43
42void nand_led(bool onoff) 44void nand_led(bool onoff)
@@ -47,13 +49,17 @@ void nand_led(bool onoff)
47int nand_read_sectors(IF_MD2(int drive,) unsigned long start, int incount, 49int nand_read_sectors(IF_MD2(int drive,) unsigned long start, int incount,
48 void* inbuf) 50 void* inbuf)
49{ 51{
50 return ftl_read(start, incount, inbuf); 52 int rc = ftl_read(start, incount, inbuf);
53 last_disk_activity = current_tick;
54 return rc;
51} 55}
52 56
53int nand_write_sectors(IF_MD2(int drive,) unsigned long start, int count, 57int nand_write_sectors(IF_MD2(int drive,) unsigned long start, int count,
54 const void* outbuf) 58 const void* outbuf)
55{ 59{
56 return ftl_write(start, count, outbuf); 60 int rc = ftl_write(start, count, outbuf);
61 last_disk_activity = current_tick;
62 return rc;
57} 63}
58 64
59void nand_spindown(int seconds) 65void nand_spindown(int seconds)
@@ -73,6 +79,7 @@ void nand_sleepnow(void)
73 79
74void nand_spin(void) 80void nand_spin(void)
75{ 81{
82 last_disk_activity = current_tick;
76 nand_power_up(); 83 nand_power_up();
77} 84}
78 85
@@ -88,20 +95,38 @@ void nand_get_info(IF_MD2(int drive,) struct storage_info *info)
88 95
89long nand_last_disk_activity(void) 96long nand_last_disk_activity(void)
90{ 97{
91 return 0; 98 return last_disk_activity;
92} 99}
93 100
94#ifdef HAVE_STORAGE_FLUSH 101#ifdef HAVE_STORAGE_FLUSH
95int nand_flush(void) 102int nand_flush(void)
96{ 103{
104 last_disk_activity = current_tick;
97 return ftl_sync(); 105 return ftl_sync();
98} 106}
99#endif 107#endif
100 108
109static void nand_thread(void)
110{
111 while (1)
112 {
113 if (TIME_AFTER(current_tick, last_disk_activity + HZ / 5))
114 nand_power_down();
115 sleep(HZ / 10);
116 }
117}
118
101int nand_init(void) 119int nand_init(void)
102{ 120{
103 if (ftl_init()) return 1; 121 if (ftl_init()) return 1;
104 122
123 last_disk_activity = current_tick;
124
125 create_thread(nand_thread, nand_stack,
126 sizeof(nand_stack), 0, "nand"
127 IF_PRIO(, PRIORITY_USER_INTERFACE)
128 IF_COP(, CPU));
129
105 initialized = true; 130 initialized = true;
106 return 0; 131 return 0;
107} 132}