AW2015_LED_M.c 93 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389
  1. /*************************************************************************************************
  2. * AW2015_LED.c
  3. *
  4. * Create Date :
  5. *
  6. * Modify Date :
  7. *
  8. * Create by : AWINIC Technology CO., LTD
  9. *
  10. * Version : 0.9, 2016/02/15
  11. *************************************************************************************************/
  12. #include <linux/i2c.h>
  13. #include <linux/gpio.h>
  14. #include <linux/interrupt.h>
  15. #include <linux/delay.h>
  16. #include <linux/irq.h>
  17. #include <linux/firmware.h>
  18. #include <linux/platform_device.h>
  19. #include <linux/slab.h>
  20. #include <linux/fs.h>
  21. #include <linux/proc_fs.h>
  22. #include <asm/uaccess.h>
  23. #include <asm/io.h>
  24. #include <linux/init.h>
  25. #include <linux/pci.h>
  26. #include <linux/dma-mapping.h>
  27. #include <linux/gameport.h>
  28. #include <linux/moduleparam.h>
  29. #include <linux/mutex.h>
  30. #include <linux/wakelock.h>
  31. //////////////////////////////////////////////////////////////////////////////////////////////////////////////
  32. #define AW2015_I2C_NAME "pressure"
  33. #define AW2015_I2C_BUS 0
  34. #define AW2015_I2C_ADDR 0x64
  35. //////////////////////////////////////////////////////////////////////////////////////////////////////////////
  36. static ssize_t AW2015_get_reg(struct device* cd,struct device_attribute *attr, char* buf);
  37. static ssize_t AW2015_set_reg(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  38. static ssize_t AW2015_set_debug(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  39. static ssize_t AW2015_get_debug(struct device* cd, struct device_attribute *attr, char* buf);
  40. static ssize_t AW2015_Set_Red(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  41. static ssize_t AW2015_Set_Green(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  42. static ssize_t AW2015_Set_Blue(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  43. static ssize_t AW2015_Set_Red_delay_off(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  44. static ssize_t AW2015_Set_Red_delay_on(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  45. static ssize_t AW2015_Set_Green_delay_off(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  46. static ssize_t AW2015_Set_Green_delay_on(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  47. static ssize_t AW2015_Set_Blue_delay_off(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  48. static ssize_t AW2015_Set_Blue_delay_on(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  49. static ssize_t AW2015_Set_White(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  50. static ssize_t AW2015_Set_White_delay_off(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  51. static ssize_t AW2015_Set_White_delay_on(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  52. static ssize_t AW2015_Set_Gray(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  53. static ssize_t AW2015_Set_Gray_delay_off(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  54. static ssize_t AW2015_Set_Gray_delay_on(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  55. static ssize_t AW2015_Set_Yellow(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  56. static ssize_t AW2015_Set_Yellow_delay_off(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  57. static ssize_t AW2015_Set_Yellow_delay_on(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  58. static ssize_t AW2015_Set_Pink(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  59. static ssize_t AW2015_Set_Pink_delay_off(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  60. static ssize_t AW2015_Set_Pink_delay_on(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  61. static ssize_t AW2015_Set_Orange(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  62. static ssize_t AW2015_Set_Orange_delay_off(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  63. static ssize_t AW2015_Set_Orange_delay_on(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  64. static ssize_t AW2015_Set_Violet(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  65. static ssize_t AW2015_Set_Violet_delay_off(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  66. static ssize_t AW2015_Set_Violet_delay_on(struct device* cd, struct device_attribute *attr,const char* buf, size_t len);
  67. static DEVICE_ATTR(reg, 0660, AW2015_get_reg, AW2015_set_reg);
  68. static DEVICE_ATTR(debug, 0660, AW2015_get_debug, AW2015_set_debug);
  69. static DEVICE_ATTR(Red, 0660, NULL, AW2015_Set_Red);
  70. static DEVICE_ATTR(Green, 0660, NULL, AW2015_Set_Green);
  71. static DEVICE_ATTR(Blue, 0660, NULL, AW2015_Set_Blue);
  72. static DEVICE_ATTR(White, 0660, NULL, AW2015_Set_White);
  73. static DEVICE_ATTR(Gray, 0660, NULL, AW2015_Set_Gray);
  74. static DEVICE_ATTR(Yellow, 0660, NULL, AW2015_Set_Yellow);
  75. static DEVICE_ATTR(Pink, 0660, NULL, AW2015_Set_Pink);
  76. static DEVICE_ATTR(Orange, 0660, NULL, AW2015_Set_Orange);
  77. static DEVICE_ATTR(Violet, 0660, NULL, AW2015_Set_Violet);
  78. static int RED_DELAY_OFF = 0,RED_DELAY_ON = 0;
  79. static DEVICE_ATTR(Red_delay_off, 0660, NULL, AW2015_Set_Red_delay_off);
  80. static DEVICE_ATTR(Red_delay_on, 0660, NULL, AW2015_Set_Red_delay_on);
  81. static int GREEN_DELAY_OFF = 0,GREEN_DELAY_ON = 0;
  82. static DEVICE_ATTR(Green_delay_off, 0660, NULL, AW2015_Set_Green_delay_off);
  83. static DEVICE_ATTR(Green_delay_on, 0660, NULL, AW2015_Set_Green_delay_on);
  84. static int BLUE_DELAY_OFF = 0,BLUE_DELAY_ON = 0;
  85. static DEVICE_ATTR(Blue_delay_off, 0660, NULL, AW2015_Set_Blue_delay_off);
  86. static DEVICE_ATTR(Blue_delay_on, 0660, NULL, AW2015_Set_Blue_delay_on);
  87. static int WHITE_DELAY_OFF = 0,WHITE_DELAY_ON = 0;
  88. static DEVICE_ATTR(White_delay_off, 0660, NULL, AW2015_Set_White_delay_off);
  89. static DEVICE_ATTR(White_delay_on, 0660, NULL, AW2015_Set_White_delay_on);
  90. static int GRAY_DELAY_OFF = 0,GRAY_DELAY_ON = 0;
  91. static DEVICE_ATTR(Gray_delay_off, 0660, NULL, AW2015_Set_Gray_delay_off);
  92. static DEVICE_ATTR(Gray_delay_on, 0660, NULL, AW2015_Set_Gray_delay_on);
  93. static int YELLOW_DELAY_OFF = 0,YELLOW_DELAY_ON = 0;
  94. static DEVICE_ATTR(Yellow_delay_off, 0660, NULL, AW2015_Set_Yellow_delay_off);
  95. static DEVICE_ATTR(Yellow_delay_on, 0660, NULL, AW2015_Set_Yellow_delay_on);
  96. static int PINK_DELAY_OFF = 0,PINK_DELAY_ON = 0;
  97. static DEVICE_ATTR(Pink_delay_off, 0660, NULL, AW2015_Set_Pink_delay_off);
  98. static DEVICE_ATTR(Pink_delay_on, 0660, NULL, AW2015_Set_Pink_delay_on);
  99. static int ORANGE_DELAY_OFF = 0,ORANGE_DELAY_ON = 0;
  100. static DEVICE_ATTR(Orange_delay_off, 0660, NULL, AW2015_Set_Orange_delay_off);
  101. static DEVICE_ATTR(Orange_delay_on, 0660, NULL, AW2015_Set_Orange_delay_on);
  102. static int VIOLET_DELAY_OFF = 0,VIOLET_DELAY_ON = 0;
  103. static DEVICE_ATTR(Violet_delay_off, 0660, NULL, AW2015_Set_Violet_delay_off);
  104. static DEVICE_ATTR(Violet_delay_on, 0660, NULL, AW2015_Set_Violet_delay_on);
  105. struct i2c_client *AW2015_i2c_client;
  106. //////////////////////////////////////////////////////////////////////////////////////////////////////////////
  107. // i2c write and read
  108. //////////////////////////////////////////////////////////////////////////////////////////////////////////////
  109. unsigned char I2C_write_reg(unsigned char addr, unsigned char reg_data)
  110. {
  111. char ret;
  112. u8 wdbuf[512] = {0};
  113. struct i2c_msg msg[] = {
  114. {
  115. .addr = AW2015_i2c_client->addr,
  116. .flags = 0,
  117. .len = 2,
  118. .buf = wdbuf,
  119. },
  120. };
  121. wdbuf[0] = addr;
  122. wdbuf[1] = reg_data;
  123. ret = i2c_transfer(AW2015_i2c_client->adapter, msg, 1);
  124. if (ret < 0)
  125. pr_err("msg %s i2c read error: %d\n", __func__, ret);
  126. return ret;
  127. }
  128. unsigned char I2C_read_reg(unsigned char addr)
  129. {
  130. int ret = 0;
  131. u8 rdbuf[512] = {0};
  132. struct i2c_msg msg[2] = {
  133. {
  134. .addr = AW2015_i2c_client->addr,
  135. .flags = 0,
  136. .len = 1,
  137. .buf = rdbuf,
  138. },
  139. {
  140. .addr = AW2015_i2c_client->addr,
  141. .flags = I2C_M_RD,
  142. .len = 1,
  143. .buf = rdbuf,
  144. },
  145. };
  146. rdbuf[0] = addr;
  147. ret = i2c_transfer(AW2015_i2c_client->adapter, msg, 2);
  148. if (ret < 0)
  149. pr_err("msg %s i2c read error: %d\n", __func__, ret);
  150. return rdbuf[0];
  151. }
  152. ////////////////////////////////////////////////////////////////////////////////////////////////////////////////
  153. // AW2015 LED
  154. ////////////////////////////////////////////////////////////////////////////////////////////////////////////////
  155. unsigned int ms2timer(unsigned int time)
  156. {
  157. int i;
  158. unsigned int ref[16] = {4, 128, 256, 384, 512, 762, 1024, 1524, 2048, 2560, 3072, 4096, 5120, 6144, 7168, 8192};
  159. for(i=0; i<15; i++)
  160. {
  161. if(time <= ref[0])
  162. {
  163. return 0;
  164. }
  165. else if(time > ref[15])
  166. {
  167. return 15;
  168. }
  169. else if((time>ref[i]) && (time<=ref[i+1]))
  170. {
  171. if((time-ref[i]) <= (ref[i+1]-time))
  172. {
  173. return i;
  174. }
  175. else
  176. {
  177. return (i+1);
  178. }
  179. }
  180. }
  181. return 0;
  182. }
  183. unsigned char AW2015_LED_ON(unsigned char r, unsigned char g, unsigned char b)
  184. {
  185. I2C_write_reg(0x00, 0x55); // software reset
  186. I2C_write_reg(0x01, 0x03); // GCR
  187. I2C_write_reg(0x03, 0x01); // IMAX
  188. I2C_write_reg(0x04, 0x00); // LCFG1
  189. I2C_write_reg(0x05, 0x00); // LCFG2
  190. I2C_write_reg(0x06, 0x00); // LCFG3
  191. I2C_write_reg(0x07, 0x07); // LEDEN
  192. I2C_write_reg(0x10, r ); // ILED1
  193. I2C_write_reg(0x11, g ); // ILED2
  194. I2C_write_reg(0x12, b ); // ILED3
  195. I2C_write_reg(0x1C, 0xFF); // PWM1
  196. I2C_write_reg(0x1D, 0xFF); // PWM2
  197. I2C_write_reg(0x1E, 0xFF); // PWM3
  198. return 0;
  199. }
  200. unsigned char AW2015_LED_OFF(void)
  201. {
  202. I2C_write_reg(0x00, 0x55); // software reset
  203. I2C_write_reg(0x10, 0x00); // Color1_R
  204. I2C_write_reg(0x11, 0x00); // Color1_G
  205. I2C_write_reg(0x12, 0x00); // Color1_B
  206. I2C_write_reg(0x1C, 0x00); // PWM1
  207. I2C_write_reg(0x1D, 0x00); // PWM2
  208. I2C_write_reg(0x1E, 0x00); // PWM3
  209. return 0;
  210. }
  211. EXPORT_SYMBOL(AW2015_LED_OFF);
  212. static int RED_DELAY_OFF_BEFORE;
  213. static int RED_DELAY_ON_BEFORE;
  214. // set red delay off and on to 0 by xmwuwh@20161122
  215. unsigned char AW2015_LED_RED_ON(void)
  216. {
  217. RED_DELAY_OFF_BEFORE = RED_DELAY_OFF;
  218. RED_DELAY_ON_BEFORE = RED_DELAY_ON;
  219. RED_DELAY_OFF = 0;
  220. RED_DELAY_ON = 0;
  221. I2C_write_reg(0x00, 0x55); // software reset
  222. I2C_write_reg(0x01, 0x03); // GCR
  223. I2C_write_reg(0x03, 0x01); // IMAX
  224. I2C_write_reg(0x04, 0x00); // LCFG1
  225. I2C_write_reg(0x05, 0x00); // LCFG2
  226. I2C_write_reg(0x06, 0x00); // LCFG3
  227. I2C_write_reg(0x07, 0x07); // LEDEN
  228. I2C_write_reg(0x10, 0xFF); // Color1_R
  229. I2C_write_reg(0x11, 0x00); // Color1_G
  230. I2C_write_reg(0x12, 0x00); // Color1_B
  231. I2C_write_reg(0x1C, 0xFF); // PWM1
  232. I2C_write_reg(0x1D, 0xFF); // PWM2
  233. I2C_write_reg(0x1E, 0xFF); // PWM3
  234. I2C_write_reg(0x09, 0x07); // PAT_RIN
  235. return 0;
  236. }
  237. EXPORT_SYMBOL(AW2015_LED_RED_ON);
  238. // set red delay off and on to before value by xmwuwh@20161122
  239. unsigned char AW2015_LED_RED_OFF(void)
  240. {
  241. RED_DELAY_OFF = RED_DELAY_OFF_BEFORE;
  242. RED_DELAY_ON = RED_DELAY_ON_BEFORE;
  243. return 0;
  244. }
  245. EXPORT_SYMBOL(AW2015_LED_RED_OFF);
  246. unsigned char AW2015_LED_Blink(unsigned char r, unsigned char g, unsigned char b, unsigned int trise_ms, unsigned int ton_ms, unsigned int tfall_ms, unsigned int toff_ms)
  247. {
  248. unsigned char trise, ton, tfall, toff;
  249. trise = ms2timer(trise_ms);
  250. ton = ms2timer(ton_ms);
  251. tfall = ms2timer(tfall_ms);
  252. toff = ms2timer(toff_ms);
  253. I2C_write_reg(0x00, 0x55); // software reset
  254. I2C_write_reg(0x01, 0x03); // GCR
  255. I2C_write_reg(0x03, 0x01); // IMAX
  256. I2C_write_reg(0x04, 0x01); // LCFG1
  257. I2C_write_reg(0x05, 0x01); // LCFG2
  258. I2C_write_reg(0x06, 0x01); // LCFG3
  259. I2C_write_reg(0x07, 0x07); // LEDEN
  260. I2C_write_reg(0x08, 0x08); // LEDCTR
  261. I2C_write_reg(0x10, r ); // ILED1
  262. I2C_write_reg(0x11, g ); // ILED2
  263. I2C_write_reg(0x12, b ); // ILED3
  264. I2C_write_reg(0x1C, 0xFF); // PWM1
  265. I2C_write_reg(0x1D, 0xFF); // PWM2
  266. I2C_write_reg(0x1E, 0xFF); // PWM3
  267. I2C_write_reg(0x30, (trise<<4)|ton); // PAT_T1 Trise & Ton
  268. I2C_write_reg(0x31, (tfall<<4)|toff); // PAT_T2 Tfall & Toff
  269. I2C_write_reg(0x32, 0x00); // PAT_T3 Tdelay
  270. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  271. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  272. I2C_write_reg(0x09, 0x07); // PAT_RIN
  273. return 0;
  274. }
  275. static ssize_t AW2015_Set_Red_delay_off(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  276. {
  277. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  278. RED_DELAY_OFF = iNewPsSensorState;
  279. return len;
  280. }
  281. static ssize_t AW2015_Set_Red_delay_on(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  282. {
  283. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  284. RED_DELAY_ON = iNewPsSensorState;
  285. return len;
  286. }
  287. static ssize_t AW2015_Set_Green_delay_off(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  288. {
  289. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  290. GREEN_DELAY_OFF = iNewPsSensorState;
  291. return len;
  292. }
  293. static ssize_t AW2015_Set_Green_delay_on(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  294. {
  295. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  296. GREEN_DELAY_ON = iNewPsSensorState;
  297. return len;
  298. }
  299. static ssize_t AW2015_Set_Blue_delay_off(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  300. {
  301. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  302. BLUE_DELAY_OFF = iNewPsSensorState;
  303. return len;
  304. }
  305. static ssize_t AW2015_Set_Blue_delay_on(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  306. {
  307. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  308. BLUE_DELAY_ON = iNewPsSensorState;
  309. return len;
  310. }
  311. static ssize_t AW2015_Set_White_delay_off(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  312. {
  313. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  314. WHITE_DELAY_OFF = iNewPsSensorState;
  315. return len;
  316. }
  317. static ssize_t AW2015_Set_White_delay_on(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  318. {
  319. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  320. WHITE_DELAY_ON = iNewPsSensorState;
  321. return len;
  322. }
  323. static ssize_t AW2015_Set_Gray_delay_off(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  324. {
  325. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  326. GRAY_DELAY_OFF = iNewPsSensorState;
  327. return len;
  328. }
  329. static ssize_t AW2015_Set_Gray_delay_on(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  330. {
  331. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  332. GRAY_DELAY_ON = iNewPsSensorState;
  333. return len;
  334. }
  335. static ssize_t AW2015_Set_Yellow_delay_off(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  336. {
  337. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  338. YELLOW_DELAY_OFF = iNewPsSensorState;
  339. return len;
  340. }
  341. static ssize_t AW2015_Set_Yellow_delay_on(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  342. {
  343. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  344. YELLOW_DELAY_ON = iNewPsSensorState;
  345. return len;
  346. }
  347. static ssize_t AW2015_Set_Pink_delay_off(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  348. {
  349. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  350. PINK_DELAY_OFF = iNewPsSensorState;
  351. return len;
  352. }
  353. static ssize_t AW2015_Set_Pink_delay_on(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  354. {
  355. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  356. PINK_DELAY_ON = iNewPsSensorState;
  357. return len;
  358. }
  359. static ssize_t AW2015_Set_Orange_delay_off(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  360. {
  361. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  362. ORANGE_DELAY_OFF = iNewPsSensorState;
  363. return len;
  364. }
  365. static ssize_t AW2015_Set_Orange_delay_on(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  366. {
  367. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  368. ORANGE_DELAY_ON = iNewPsSensorState;
  369. return len;
  370. }
  371. static ssize_t AW2015_Set_Violet_delay_off(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  372. {
  373. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  374. VIOLET_DELAY_OFF = iNewPsSensorState;
  375. return len;
  376. }
  377. static ssize_t AW2015_Set_Violet_delay_on(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  378. {
  379. unsigned long iNewPsSensorState = simple_strtoul(buf, NULL, 10);
  380. VIOLET_DELAY_ON = iNewPsSensorState;
  381. return len;
  382. }
  383. static ssize_t AW2015_Set_Orange(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  384. {
  385. unsigned int databuf[16];
  386. sscanf(buf,"%d",&databuf[0]);
  387. I2C_write_reg(0x00, 0x55); // software reset
  388. I2C_write_reg(0x01, 0x03); // GCR
  389. I2C_write_reg(0x03, 0x01); // IMAX
  390. I2C_write_reg(0x04, 0x00); // LCFG1
  391. I2C_write_reg(0x05, 0x00); // LCFG2
  392. I2C_write_reg(0x06, 0x00); // LCFG3
  393. I2C_write_reg(0x07, 0x07); // LEDEN
  394. if(databuf[0]!=0)
  395. {
  396. if(ORANGE_DELAY_OFF == 500)
  397. {
  398. if(ORANGE_DELAY_ON == 500)
  399. {
  400. I2C_write_reg(0x00, 0x55); // software reset
  401. I2C_write_reg(0x01, 0x03); // GCR
  402. I2C_write_reg(0x03, 0x01); // IMAX
  403. I2C_write_reg(0x04, 0x01); // LCFG1
  404. I2C_write_reg(0x05, 0x01); // LCFG2
  405. I2C_write_reg(0x06, 0x01); // LCFG3
  406. I2C_write_reg(0x07, 0x07); // LEDEN
  407. I2C_write_reg(0x08, 0x08); // LEDCTR
  408. I2C_write_reg(0x10, 0xFF); // Color1_R
  409. I2C_write_reg(0x11, 0xCE); // Color1_G
  410. I2C_write_reg(0x12, 0x1F); // Color1_B
  411. I2C_write_reg(0x1C, 0xFF); // PWM1
  412. I2C_write_reg(0x1D, 0xFF); // PWM2
  413. I2C_write_reg(0x1E, 0xFF); // PWM3
  414. I2C_write_reg(0x09, 0x07); // PAT_RIN
  415. I2C_write_reg(0x30, 0x00); // PAT_T1 Trise & Ton
  416. I2C_write_reg(0x31, 0x02); // PAT_T2 Tfall & Toff
  417. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  418. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  419. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  420. I2C_write_reg(0x09, 0x07); // PAT_RIN
  421. }
  422. else if(ORANGE_DELAY_ON == 1000)
  423. {
  424. I2C_write_reg(0x00, 0x55); // software reset
  425. I2C_write_reg(0x01, 0x03); // GCR
  426. I2C_write_reg(0x03, 0x01); // IMAX
  427. I2C_write_reg(0x04, 0x01); // LCFG1
  428. I2C_write_reg(0x05, 0x01); // LCFG2
  429. I2C_write_reg(0x06, 0x01); // LCFG3
  430. I2C_write_reg(0x07, 0x07); // LEDEN
  431. I2C_write_reg(0x08, 0x08); // LEDCTR
  432. I2C_write_reg(0x10, 0xFF); // Color1_R
  433. I2C_write_reg(0x11, 0xCE); // Color1_G
  434. I2C_write_reg(0x12, 0x1F); // Color1_B
  435. I2C_write_reg(0x1C, 0xFF); // PWM1
  436. I2C_write_reg(0x1D, 0xFF); // PWM2
  437. I2C_write_reg(0x1E, 0xFF); // PWM3
  438. I2C_write_reg(0x09, 0x07); // PAT_RIN
  439. I2C_write_reg(0x30, 0x13); // PAT_T1 Trise & Ton
  440. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  441. I2C_write_reg(0x32, 0x20); // PAT_T3 Tslot & Tdelay
  442. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  443. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  444. I2C_write_reg(0x09, 0x07); // PAT_RIN
  445. }
  446. else if(ORANGE_DELAY_ON == 1499)
  447. {
  448. I2C_write_reg(0x00, 0x55); // software reset
  449. I2C_write_reg(0x01, 0x03); // GCR
  450. I2C_write_reg(0x03, 0x01); // IMAX
  451. I2C_write_reg(0x04, 0x01); // LCFG1
  452. I2C_write_reg(0x05, 0x01); // LCFG2
  453. I2C_write_reg(0x06, 0x01); // LCFG3
  454. I2C_write_reg(0x07, 0x07); // LEDEN
  455. I2C_write_reg(0x08, 0x08); // LEDCTR
  456. I2C_write_reg(0x10, 0xFF); // Color1_R
  457. I2C_write_reg(0x11, 0xCE); // Color1_G
  458. I2C_write_reg(0x12, 0x1F); // Color1_B
  459. I2C_write_reg(0x1C, 0xFF); // PWM1
  460. I2C_write_reg(0x1D, 0xFF); // PWM2
  461. I2C_write_reg(0x1E, 0xFF); // PWM3
  462. I2C_write_reg(0x09, 0x07); // PAT_RIN
  463. I2C_write_reg(0x30, 0x80); // PAT_T1 Trise & Ton
  464. I2C_write_reg(0x31, 0x00); // PAT_T2 Tfall & Toff
  465. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  466. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  467. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  468. I2C_write_reg(0x09, 0x07); // PAT_RIN
  469. }
  470. } else if(ORANGE_DELAY_ON!=0 &&ORANGE_DELAY_OFF!=0)
  471. {
  472. I2C_write_reg(0x00, 0x55); // software reset
  473. I2C_write_reg(0x01, 0x03); // GCR
  474. I2C_write_reg(0x03, 0x01); // IMAX
  475. I2C_write_reg(0x04, 0x01); // LCFG1
  476. I2C_write_reg(0x05, 0x01); // LCFG2
  477. I2C_write_reg(0x06, 0x01); // LCFG3
  478. I2C_write_reg(0x07, 0x07); // LEDEN
  479. I2C_write_reg(0x08, 0x08); // LEDCTR
  480. I2C_write_reg(0x10, 0xFF); // Color1_R
  481. I2C_write_reg(0x11, 0xCE); // Color1_G
  482. I2C_write_reg(0x12, 0x1F); // Color1_B
  483. I2C_write_reg(0x1C, 0xFF); // PWM1
  484. I2C_write_reg(0x1D, 0xFF); // PWM2
  485. I2C_write_reg(0x1E, 0xFF); // PWM3
  486. I2C_write_reg(0x09, 0x07); // PAT_RIN
  487. I2C_write_reg(0x30, 0x14); // PAT_T1 Trise & Ton
  488. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  489. I2C_write_reg(0x32, 0x31); // PAT_T3 Tslot & Tdelay
  490. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  491. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  492. I2C_write_reg(0x09, 0x07); // PAT_RIN
  493. }
  494. else
  495. {
  496. I2C_write_reg(0x00, 0x55); // software reset
  497. I2C_write_reg(0x01, 0x03); // GCR
  498. I2C_write_reg(0x03, 0x01); // IMAX
  499. I2C_write_reg(0x04, 0x00); // LCFG1
  500. I2C_write_reg(0x05, 0x00); // LCFG2
  501. I2C_write_reg(0x06, 0x00); // LCFG3
  502. I2C_write_reg(0x07, 0x07); // LEDEN
  503. I2C_write_reg(0x10, 0xFF); // Color1_R
  504. I2C_write_reg(0x11, 0xCE); // Color1_G
  505. I2C_write_reg(0x12, 0x1F); // Color1_B
  506. I2C_write_reg(0x1C, 0xFF); // PWM1
  507. I2C_write_reg(0x1D, 0xFF); // PWM2
  508. I2C_write_reg(0x1E, 0xFF); // PWM3
  509. I2C_write_reg(0x09, 0x07); // PAT_RIN
  510. }
  511. }
  512. else
  513. {
  514. I2C_write_reg(0x10, 0x00); // Color1_R
  515. I2C_write_reg(0x11, 0x00); // Color1_G
  516. I2C_write_reg(0x12, 0x00); // Color1_B
  517. I2C_write_reg(0x1C, 0x00); // PWM1
  518. I2C_write_reg(0x1D, 0x00); // PWM2
  519. I2C_write_reg(0x1E, 0x00); // PWM3
  520. I2C_write_reg(0x09, 0x07); // PAT_RIN
  521. ORANGE_DELAY_ON = 0;
  522. ORANGE_DELAY_OFF = 0;
  523. }
  524. return len;
  525. }
  526. static ssize_t AW2015_Set_Violet(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  527. {
  528. unsigned int databuf[16];
  529. sscanf(buf,"%d",&databuf[0]);
  530. I2C_write_reg(0x00, 0x55); // software reset
  531. I2C_write_reg(0x01, 0x03); // GCR
  532. I2C_write_reg(0x03, 0x01); // IMAX
  533. I2C_write_reg(0x04, 0x00); // LCFG1
  534. I2C_write_reg(0x05, 0x00); // LCFG2
  535. I2C_write_reg(0x06, 0x00); // LCFG3
  536. I2C_write_reg(0x07, 0x07); // LEDEN
  537. if(databuf[0]!=0)
  538. {
  539. if(VIOLET_DELAY_OFF == 500)
  540. {
  541. if(VIOLET_DELAY_ON == 500)
  542. {
  543. I2C_write_reg(0x00, 0x55); // software reset
  544. I2C_write_reg(0x01, 0x03); // GCR
  545. I2C_write_reg(0x03, 0x01); // IMAX
  546. I2C_write_reg(0x04, 0x01); // LCFG1
  547. I2C_write_reg(0x05, 0x01); // LCFG2
  548. I2C_write_reg(0x06, 0x01); // LCFG3
  549. I2C_write_reg(0x07, 0x07); // LEDEN
  550. I2C_write_reg(0x08, 0x08); // LEDCTR
  551. I2C_write_reg(0x10, 0xD2); // Color1_R
  552. I2C_write_reg(0x11, 0x74); // Color1_G
  553. I2C_write_reg(0x12, 0xF9); // Color1_B
  554. I2C_write_reg(0x1C, 0xFF); // PWM1
  555. I2C_write_reg(0x1D, 0xFF); // PWM2
  556. I2C_write_reg(0x1E, 0xFF); // PWM3
  557. I2C_write_reg(0x09, 0x07); // PAT_RIN
  558. I2C_write_reg(0x30, 0x00); // PAT_T1 Trise & Ton
  559. I2C_write_reg(0x31, 0x02); // PAT_T2 Tfall & Toff
  560. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  561. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  562. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  563. I2C_write_reg(0x09, 0x07); // PAT_RIN
  564. }
  565. else if(VIOLET_DELAY_ON == 1000)
  566. {
  567. I2C_write_reg(0x00, 0x55); // software reset
  568. I2C_write_reg(0x01, 0x03); // GCR
  569. I2C_write_reg(0x03, 0x01); // IMAX
  570. I2C_write_reg(0x04, 0x01); // LCFG1
  571. I2C_write_reg(0x05, 0x01); // LCFG2
  572. I2C_write_reg(0x06, 0x01); // LCFG3
  573. I2C_write_reg(0x07, 0x07); // LEDEN
  574. I2C_write_reg(0x08, 0x08); // LEDCTR
  575. I2C_write_reg(0x10, 0xD2); // Color1_R
  576. I2C_write_reg(0x11, 0x74); // Color1_G
  577. I2C_write_reg(0x12, 0xF9); // Color1_B
  578. I2C_write_reg(0x1C, 0xFF); // PWM1
  579. I2C_write_reg(0x1D, 0xFF); // PWM2
  580. I2C_write_reg(0x1E, 0xFF); // PWM3
  581. I2C_write_reg(0x09, 0x07); // PAT_RIN
  582. I2C_write_reg(0x30, 0x13); // PAT_T1 Trise & Ton
  583. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  584. I2C_write_reg(0x32, 0x20); // PAT_T3 Tslot & Tdelay
  585. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  586. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  587. I2C_write_reg(0x09, 0x07); // PAT_RIN
  588. }
  589. else if(VIOLET_DELAY_ON == 1499)
  590. {
  591. I2C_write_reg(0x00, 0x55); // software reset
  592. I2C_write_reg(0x01, 0x03); // GCR
  593. I2C_write_reg(0x03, 0x01); // IMAX
  594. I2C_write_reg(0x04, 0x01); // LCFG1
  595. I2C_write_reg(0x05, 0x01); // LCFG2
  596. I2C_write_reg(0x06, 0x01); // LCFG3
  597. I2C_write_reg(0x07, 0x07); // LEDEN
  598. I2C_write_reg(0x08, 0x08); // LEDCTR
  599. I2C_write_reg(0x10, 0xD2); // Color1_R
  600. I2C_write_reg(0x11, 0x74); // Color1_G
  601. I2C_write_reg(0x12, 0xF9); // Color1_B
  602. I2C_write_reg(0x1C, 0xFF); // PWM1
  603. I2C_write_reg(0x1D, 0xFF); // PWM2
  604. I2C_write_reg(0x1E, 0xFF); // PWM3
  605. I2C_write_reg(0x09, 0x07); // PAT_RIN
  606. I2C_write_reg(0x30, 0x80); // PAT_T1 Trise & Ton
  607. I2C_write_reg(0x31, 0x00); // PAT_T2 Tfall & Toff
  608. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  609. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  610. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  611. I2C_write_reg(0x09, 0x07); // PAT_RIN
  612. }
  613. } else if(VIOLET_DELAY_ON!=0 &&VIOLET_DELAY_OFF!=0)
  614. {
  615. I2C_write_reg(0x00, 0x55); // software reset
  616. I2C_write_reg(0x01, 0x03); // GCR
  617. I2C_write_reg(0x03, 0x01); // IMAX
  618. I2C_write_reg(0x04, 0x01); // LCFG1
  619. I2C_write_reg(0x05, 0x01); // LCFG2
  620. I2C_write_reg(0x06, 0x01); // LCFG3
  621. I2C_write_reg(0x07, 0x07); // LEDEN
  622. I2C_write_reg(0x08, 0x08); // LEDCTR
  623. I2C_write_reg(0x10, 0xD2); // Color1_R
  624. I2C_write_reg(0x11, 0x74); // Color1_G
  625. I2C_write_reg(0x12, 0xF9); // Color1_B
  626. I2C_write_reg(0x1C, 0xFF); // PWM1
  627. I2C_write_reg(0x1D, 0xFF); // PWM2
  628. I2C_write_reg(0x1E, 0xFF); // PWM3
  629. I2C_write_reg(0x09, 0x07); // PAT_RIN
  630. I2C_write_reg(0x30, 0x14); // PAT_T1 Trise & Ton
  631. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  632. I2C_write_reg(0x32, 0x31); // PAT_T3 Tslot & Tdelay
  633. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  634. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  635. I2C_write_reg(0x09, 0x07); // PAT_RIN
  636. }
  637. else
  638. {
  639. I2C_write_reg(0x00, 0x55); // software reset
  640. I2C_write_reg(0x01, 0x03); // GCR
  641. I2C_write_reg(0x03, 0x01); // IMAX
  642. I2C_write_reg(0x04, 0x00); // LCFG1
  643. I2C_write_reg(0x05, 0x00); // LCFG2
  644. I2C_write_reg(0x06, 0x00); // LCFG3
  645. I2C_write_reg(0x07, 0x07); // LEDEN
  646. I2C_write_reg(0x10, 0xD2); // Color1_R
  647. I2C_write_reg(0x11, 0x74); // Color1_G
  648. I2C_write_reg(0x12, 0xF9); // Color1_B
  649. I2C_write_reg(0x1C, 0xFF); // PWM1
  650. I2C_write_reg(0x1D, 0xFF); // PWM2
  651. I2C_write_reg(0x1E, 0xFF); // PWM3
  652. I2C_write_reg(0x09, 0x07); // PAT_RIN
  653. }
  654. }
  655. else
  656. {
  657. I2C_write_reg(0x10, 0x00); // Color1_R
  658. I2C_write_reg(0x11, 0x00); // Color1_G
  659. I2C_write_reg(0x12, 0x00); // Color1_B
  660. I2C_write_reg(0x1C, 0x00); // PWM1
  661. I2C_write_reg(0x1D, 0x00); // PWM2
  662. I2C_write_reg(0x1E, 0x00); // PWM3
  663. I2C_write_reg(0x09, 0x07); // PAT_RIN
  664. VIOLET_DELAY_ON = 0;
  665. VIOLET_DELAY_OFF = 0;
  666. }
  667. return len;
  668. }
  669. static ssize_t AW2015_Set_White(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  670. {
  671. unsigned int databuf[16];
  672. sscanf(buf,"%d",&databuf[0]);
  673. I2C_write_reg(0x00, 0x55); // software reset
  674. I2C_write_reg(0x01, 0x03); // GCR
  675. I2C_write_reg(0x03, 0x01); // IMAX
  676. I2C_write_reg(0x04, 0x00); // LCFG1
  677. I2C_write_reg(0x05, 0x00); // LCFG2
  678. I2C_write_reg(0x06, 0x00); // LCFG3
  679. I2C_write_reg(0x07, 0x07); // LEDEN
  680. if(databuf[0]!=0)
  681. {
  682. if(WHITE_DELAY_OFF == 500)
  683. {
  684. if(WHITE_DELAY_ON == 500)
  685. {
  686. I2C_write_reg(0x00, 0x55); // software reset
  687. I2C_write_reg(0x01, 0x03); // GCR
  688. I2C_write_reg(0x03, 0x01); // IMAX
  689. I2C_write_reg(0x04, 0x01); // LCFG1
  690. I2C_write_reg(0x05, 0x01); // LCFG2
  691. I2C_write_reg(0x06, 0x01); // LCFG3
  692. I2C_write_reg(0x07, 0x07); // LEDEN
  693. I2C_write_reg(0x08, 0x08); // LEDCTR
  694. I2C_write_reg(0x10, 0xFF); // Color1_R
  695. I2C_write_reg(0x11, 0xFF); // Color1_G
  696. I2C_write_reg(0x12, 0xFF); // Color1_B
  697. I2C_write_reg(0x1C, 0xFF); // PWM1
  698. I2C_write_reg(0x1D, 0xFF); // PWM2
  699. I2C_write_reg(0x1E, 0xFF); // PWM3
  700. I2C_write_reg(0x09, 0x07); // PAT_RIN
  701. I2C_write_reg(0x30, 0x00); // PAT_T1 Trise & Ton
  702. I2C_write_reg(0x31, 0x02); // PAT_T2 Tfall & Toff
  703. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  704. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  705. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  706. I2C_write_reg(0x09, 0x07); // PAT_RIN
  707. }
  708. else if(WHITE_DELAY_ON == 1000)
  709. {
  710. I2C_write_reg(0x00, 0x55); // software reset
  711. I2C_write_reg(0x01, 0x03); // GCR
  712. I2C_write_reg(0x03, 0x01); // IMAX
  713. I2C_write_reg(0x04, 0x01); // LCFG1
  714. I2C_write_reg(0x05, 0x01); // LCFG2
  715. I2C_write_reg(0x06, 0x01); // LCFG3
  716. I2C_write_reg(0x07, 0x07); // LEDEN
  717. I2C_write_reg(0x08, 0x08); // LEDCTR
  718. I2C_write_reg(0x10, 0xFF); // Color1_R
  719. I2C_write_reg(0x11, 0xFF); // Color1_G
  720. I2C_write_reg(0x12, 0xFF); // Color1_B
  721. I2C_write_reg(0x1C, 0xFF); // PWM1
  722. I2C_write_reg(0x1D, 0xFF); // PWM2
  723. I2C_write_reg(0x1E, 0xFF); // PWM3
  724. I2C_write_reg(0x09, 0x07); // PAT_RIN
  725. I2C_write_reg(0x30, 0x13); // PAT_T1 Trise & Ton
  726. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  727. I2C_write_reg(0x32, 0x20); // PAT_T3 Tslot & Tdelay
  728. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  729. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  730. I2C_write_reg(0x09, 0x07); // PAT_RIN
  731. }
  732. else if(WHITE_DELAY_ON == 1499)
  733. {
  734. I2C_write_reg(0x00, 0x55); // software reset
  735. I2C_write_reg(0x01, 0x03); // GCR
  736. I2C_write_reg(0x03, 0x01); // IMAX
  737. I2C_write_reg(0x04, 0x01); // LCFG1
  738. I2C_write_reg(0x05, 0x01); // LCFG2
  739. I2C_write_reg(0x06, 0x01); // LCFG3
  740. I2C_write_reg(0x07, 0x07); // LEDEN
  741. I2C_write_reg(0x08, 0x08); // LEDCTR
  742. I2C_write_reg(0x10, 0xFF); // Color1_R
  743. I2C_write_reg(0x11, 0xFF); // Color1_G
  744. I2C_write_reg(0x12, 0xFF); // Color1_B
  745. I2C_write_reg(0x1C, 0xFF); // PWM1
  746. I2C_write_reg(0x1D, 0xFF); // PWM2
  747. I2C_write_reg(0x1E, 0xFF); // PWM3
  748. I2C_write_reg(0x09, 0x07); // PAT_RIN
  749. I2C_write_reg(0x30, 0x80); // PAT_T1 Trise & Ton
  750. I2C_write_reg(0x31, 0x00); // PAT_T2 Tfall & Toff
  751. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  752. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  753. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  754. I2C_write_reg(0x09, 0x07); // PAT_RIN
  755. }
  756. } else if(WHITE_DELAY_ON!=0 &&WHITE_DELAY_OFF!=0)
  757. {
  758. I2C_write_reg(0x00, 0x55); // software reset
  759. I2C_write_reg(0x01, 0x03); // GCR
  760. I2C_write_reg(0x03, 0x01); // IMAX
  761. I2C_write_reg(0x04, 0x01); // LCFG1
  762. I2C_write_reg(0x05, 0x01); // LCFG2
  763. I2C_write_reg(0x06, 0x01); // LCFG3
  764. I2C_write_reg(0x07, 0x07); // LEDEN
  765. I2C_write_reg(0x08, 0x08); // LEDCTR
  766. I2C_write_reg(0x10, 0xFF); // Color1_R
  767. I2C_write_reg(0x11, 0xFF); // Color1_G
  768. I2C_write_reg(0x12, 0xFF); // Color1_B
  769. I2C_write_reg(0x1C, 0xFF); // PWM1
  770. I2C_write_reg(0x1D, 0xFF); // PWM2
  771. I2C_write_reg(0x1E, 0xFF); // PWM3
  772. I2C_write_reg(0x09, 0x07); // PAT_RIN
  773. I2C_write_reg(0x30, 0x14); // PAT_T1 Trise & Ton
  774. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  775. I2C_write_reg(0x32, 0x31); // PAT_T3 Tslot & Tdelay
  776. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  777. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  778. I2C_write_reg(0x09, 0x07); // PAT_RIN
  779. }
  780. else
  781. {
  782. I2C_write_reg(0x00, 0x55); // software reset
  783. I2C_write_reg(0x01, 0x03); // GCR
  784. I2C_write_reg(0x03, 0x01); // IMAX
  785. I2C_write_reg(0x04, 0x00); // LCFG1
  786. I2C_write_reg(0x05, 0x00); // LCFG2
  787. I2C_write_reg(0x06, 0x00); // LCFG3
  788. I2C_write_reg(0x07, 0x07); // LEDEN
  789. I2C_write_reg(0x10, 0xFF); // Color1_R
  790. I2C_write_reg(0x11, 0xFF); // Color1_G
  791. I2C_write_reg(0x12, 0xFF); // Color1_B
  792. I2C_write_reg(0x1C, 0xFF); // PWM1
  793. I2C_write_reg(0x1D, 0xFF); // PWM2
  794. I2C_write_reg(0x1E, 0xFF); // PWM3
  795. I2C_write_reg(0x09, 0x07); // PAT_RIN
  796. }
  797. }
  798. else
  799. {
  800. I2C_write_reg(0x10, 0x00); // Color1_R
  801. I2C_write_reg(0x11, 0x00); // Color1_G
  802. I2C_write_reg(0x12, 0x00); // Color1_B
  803. I2C_write_reg(0x1C, 0x00); // PWM1
  804. I2C_write_reg(0x1D, 0x00); // PWM2
  805. I2C_write_reg(0x1E, 0x00); // PWM3
  806. I2C_write_reg(0x09, 0x07); // PAT_RIN
  807. WHITE_DELAY_ON = 0;
  808. WHITE_DELAY_OFF = 0;
  809. }
  810. return len;
  811. }
  812. static ssize_t AW2015_Set_Gray(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  813. {
  814. unsigned int databuf[16];
  815. sscanf(buf,"%d",&databuf[0]);
  816. I2C_write_reg(0x00, 0x55); // software reset
  817. I2C_write_reg(0x01, 0x03); // GCR
  818. I2C_write_reg(0x03, 0x01); // IMAX
  819. I2C_write_reg(0x04, 0x00); // LCFG1
  820. I2C_write_reg(0x05, 0x00); // LCFG2
  821. I2C_write_reg(0x06, 0x00); // LCFG3
  822. I2C_write_reg(0x07, 0x07); // LEDEN
  823. if(databuf[0]!=0)
  824. {
  825. if(GRAY_DELAY_OFF == 500)
  826. {
  827. if(GRAY_DELAY_ON == 500)
  828. {
  829. I2C_write_reg(0x00, 0x55); // software reset
  830. I2C_write_reg(0x01, 0x03); // GCR
  831. I2C_write_reg(0x03, 0x01); // IMAX
  832. I2C_write_reg(0x04, 0x01); // LCFG1
  833. I2C_write_reg(0x05, 0x01); // LCFG2
  834. I2C_write_reg(0x06, 0x01); // LCFG3
  835. I2C_write_reg(0x07, 0x07); // LEDEN
  836. I2C_write_reg(0x08, 0x08); // LEDCTR
  837. I2C_write_reg(0x10, 0x00); // Color1_R
  838. I2C_write_reg(0x11, 0xFF); // Color1_G
  839. I2C_write_reg(0x12, 0x80); // Color1_B
  840. I2C_write_reg(0x1C, 0xFF); // PWM1
  841. I2C_write_reg(0x1D, 0xFF); // PWM2
  842. I2C_write_reg(0x1E, 0xFF); // PWM3
  843. I2C_write_reg(0x09, 0x07); // PAT_RIN
  844. I2C_write_reg(0x30, 0x00); // PAT_T1 Trise & Ton
  845. I2C_write_reg(0x31, 0x02); // PAT_T2 Tfall & Toff
  846. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  847. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  848. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  849. I2C_write_reg(0x09, 0x07); // PAT_RIN
  850. }
  851. else if(GRAY_DELAY_ON == 1000)
  852. {
  853. I2C_write_reg(0x00, 0x55); // software reset
  854. I2C_write_reg(0x01, 0x03); // GCR
  855. I2C_write_reg(0x03, 0x01); // IMAX
  856. I2C_write_reg(0x04, 0x01); // LCFG1
  857. I2C_write_reg(0x05, 0x01); // LCFG2
  858. I2C_write_reg(0x06, 0x01); // LCFG3
  859. I2C_write_reg(0x07, 0x07); // LEDEN
  860. I2C_write_reg(0x08, 0x08); // LEDCTR
  861. I2C_write_reg(0x10, 0x00); // Color1_R
  862. I2C_write_reg(0x11, 0xFF); // Color1_G
  863. I2C_write_reg(0x12, 0x80); // Color1_B
  864. I2C_write_reg(0x1C, 0xFF); // PWM1
  865. I2C_write_reg(0x1D, 0xFF); // PWM2
  866. I2C_write_reg(0x1E, 0xFF); // PWM3
  867. I2C_write_reg(0x09, 0x07); // PAT_RIN
  868. I2C_write_reg(0x30, 0x13); // PAT_T1 Trise & Ton
  869. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  870. I2C_write_reg(0x32, 0x20); // PAT_T3 Tslot & Tdelay
  871. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  872. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  873. I2C_write_reg(0x09, 0x07); // PAT_RIN
  874. }
  875. else if(GRAY_DELAY_ON == 1499)
  876. {
  877. I2C_write_reg(0x00, 0x55); // software reset
  878. I2C_write_reg(0x01, 0x03); // GCR
  879. I2C_write_reg(0x03, 0x01); // IMAX
  880. I2C_write_reg(0x04, 0x01); // LCFG1
  881. I2C_write_reg(0x05, 0x01); // LCFG2
  882. I2C_write_reg(0x06, 0x01); // LCFG3
  883. I2C_write_reg(0x07, 0x07); // LEDEN
  884. I2C_write_reg(0x08, 0x08); // LEDCTR
  885. I2C_write_reg(0x10, 0x00); // Color1_R
  886. I2C_write_reg(0x11, 0xFF); // Color1_G
  887. I2C_write_reg(0x12, 0x80); // Color1_B
  888. I2C_write_reg(0x1C, 0xFF); // PWM1
  889. I2C_write_reg(0x1D, 0xFF); // PWM2
  890. I2C_write_reg(0x1E, 0xFF); // PWM3
  891. I2C_write_reg(0x09, 0x07); // PAT_RIN
  892. I2C_write_reg(0x30, 0x80); // PAT_T1 Trise & Ton
  893. I2C_write_reg(0x31, 0x00); // PAT_T2 Tfall & Toff
  894. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  895. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  896. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  897. I2C_write_reg(0x09, 0x07); // PAT_RIN
  898. }
  899. }else if(GRAY_DELAY_ON!=0 && GRAY_DELAY_OFF!=0)
  900. {
  901. I2C_write_reg(0x00, 0x55); // software reset
  902. I2C_write_reg(0x01, 0x03); // GCR
  903. I2C_write_reg(0x03, 0x01); // IMAX
  904. I2C_write_reg(0x04, 0x01); // LCFG1
  905. I2C_write_reg(0x05, 0x01); // LCFG2
  906. I2C_write_reg(0x06, 0x01); // LCFG3
  907. I2C_write_reg(0x07, 0x07); // LEDEN
  908. I2C_write_reg(0x08, 0x08); // LEDCTR
  909. I2C_write_reg(0x10, 0x00); // Color1_R
  910. I2C_write_reg(0x11, 0xFF); // Color1_G
  911. I2C_write_reg(0x12, 0x80); // Color1_B
  912. I2C_write_reg(0x1C, 0xFF); // PWM1
  913. I2C_write_reg(0x1D, 0xFF); // PWM2
  914. I2C_write_reg(0x1E, 0xFF); // PWM3
  915. I2C_write_reg(0x09, 0x07); // PAT_RIN
  916. I2C_write_reg(0x30, 0x14); // PAT_T1 Trise & Ton
  917. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  918. I2C_write_reg(0x32, 0x31); // PAT_T3 Tslot & Tdelay
  919. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  920. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  921. I2C_write_reg(0x09, 0x07); // PAT_RIN
  922. }else
  923. {
  924. I2C_write_reg(0x00, 0x55); // software reset
  925. I2C_write_reg(0x01, 0x03); // GCR
  926. I2C_write_reg(0x03, 0x01); // IMAX
  927. I2C_write_reg(0x04, 0x00); // LCFG1
  928. I2C_write_reg(0x05, 0x00); // LCFG2
  929. I2C_write_reg(0x06, 0x00); // LCFG3
  930. I2C_write_reg(0x07, 0x07); // LEDEN
  931. I2C_write_reg(0x10, 0x00); // Color1_R
  932. I2C_write_reg(0x11, 0xFF); // Color1_G
  933. I2C_write_reg(0x12, 0x80); // Color1_B
  934. I2C_write_reg(0x1C, 0xFF); // PWM1
  935. I2C_write_reg(0x1D, 0xFF); // PWM2
  936. I2C_write_reg(0x1E, 0xFF); // PWM3
  937. I2C_write_reg(0x09, 0x07); // PAT_RIN
  938. }
  939. }
  940. else
  941. {
  942. I2C_write_reg(0x10, 0x00); // Color1_R
  943. I2C_write_reg(0x11, 0x00); // Color1_G
  944. I2C_write_reg(0x12, 0x00); // Color1_B
  945. I2C_write_reg(0x1C, 0x00); // PWM1
  946. I2C_write_reg(0x1D, 0x00); // PWM2
  947. I2C_write_reg(0x1E, 0x00); // PWM3
  948. I2C_write_reg(0x09, 0x07); // PAT_RIN
  949. GRAY_DELAY_ON = 0;
  950. GRAY_DELAY_OFF = 0;
  951. }
  952. return len;
  953. }
  954. static ssize_t AW2015_Set_Yellow(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  955. {
  956. unsigned int databuf[16];
  957. sscanf(buf,"%d",&databuf[0]);
  958. I2C_write_reg(0x00, 0x55); // software reset
  959. I2C_write_reg(0x01, 0x03); // GCR
  960. I2C_write_reg(0x03, 0x01); // IMAX
  961. I2C_write_reg(0x04, 0x00); // LCFG1
  962. I2C_write_reg(0x05, 0x00); // LCFG2
  963. I2C_write_reg(0x06, 0x00); // LCFG3
  964. I2C_write_reg(0x07, 0x07); // LEDEN
  965. if(databuf[0]!=0)
  966. {
  967. if(YELLOW_DELAY_OFF == 500)
  968. {
  969. if(YELLOW_DELAY_ON == 500)
  970. {
  971. I2C_write_reg(0x00, 0x55); // software reset
  972. I2C_write_reg(0x01, 0x03); // GCR
  973. I2C_write_reg(0x03, 0x01); // IMAX
  974. I2C_write_reg(0x04, 0x01); // LCFG1
  975. I2C_write_reg(0x05, 0x01); // LCFG2
  976. I2C_write_reg(0x06, 0x01); // LCFG3
  977. I2C_write_reg(0x07, 0x07); // LEDEN
  978. I2C_write_reg(0x08, 0x08); // LEDCTR
  979. I2C_write_reg(0x10, 0xFF); // Color1_R
  980. I2C_write_reg(0x11, 0xFF); // Color1_G
  981. I2C_write_reg(0x12, 0x00); // Color1_B
  982. I2C_write_reg(0x1C, 0xFF); // PWM1
  983. I2C_write_reg(0x1D, 0xFF); // PWM2
  984. I2C_write_reg(0x1E, 0xFF); // PWM3
  985. I2C_write_reg(0x09, 0x07); // PAT_RIN
  986. I2C_write_reg(0x30, 0x00); // PAT_T1 Trise & Ton
  987. I2C_write_reg(0x31, 0x02); // PAT_T2 Tfall & Toff
  988. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  989. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  990. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  991. I2C_write_reg(0x09, 0x07); // PAT_RIN
  992. }
  993. else if(YELLOW_DELAY_ON == 1000)
  994. {
  995. I2C_write_reg(0x00, 0x55); // software reset
  996. I2C_write_reg(0x01, 0x03); // GCR
  997. I2C_write_reg(0x03, 0x01); // IMAX
  998. I2C_write_reg(0x04, 0x01); // LCFG1
  999. I2C_write_reg(0x05, 0x01); // LCFG2
  1000. I2C_write_reg(0x06, 0x01); // LCFG3
  1001. I2C_write_reg(0x07, 0x07); // LEDEN
  1002. I2C_write_reg(0x08, 0x08); // LEDCTR
  1003. I2C_write_reg(0x10, 0xFF); // Color1_R
  1004. I2C_write_reg(0x11, 0xFF); // Color1_G
  1005. I2C_write_reg(0x12, 0x00); // Color1_B
  1006. I2C_write_reg(0x1C, 0xFF); // PWM1
  1007. I2C_write_reg(0x1D, 0xFF); // PWM2
  1008. I2C_write_reg(0x1E, 0xFF); // PWM3
  1009. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1010. I2C_write_reg(0x30, 0x13); // PAT_T1 Trise & Ton
  1011. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1012. I2C_write_reg(0x32, 0x20); // PAT_T3 Tslot & Tdelay
  1013. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1014. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1015. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1016. }
  1017. else if(YELLOW_DELAY_ON == 1499)
  1018. {
  1019. I2C_write_reg(0x00, 0x55); // software reset
  1020. I2C_write_reg(0x01, 0x03); // GCR
  1021. I2C_write_reg(0x03, 0x01); // IMAX
  1022. I2C_write_reg(0x04, 0x01); // LCFG1
  1023. I2C_write_reg(0x05, 0x01); // LCFG2
  1024. I2C_write_reg(0x06, 0x01); // LCFG3
  1025. I2C_write_reg(0x07, 0x07); // LEDEN
  1026. I2C_write_reg(0x08, 0x08); // LEDCTR
  1027. I2C_write_reg(0x10, 0xFF); // Color1_R
  1028. I2C_write_reg(0x11, 0xFF); // Color1_G
  1029. I2C_write_reg(0x12, 0x00); // Color1_B
  1030. I2C_write_reg(0x1C, 0xFF); // PWM1
  1031. I2C_write_reg(0x1D, 0xFF); // PWM2
  1032. I2C_write_reg(0x1E, 0xFF); // PWM3
  1033. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1034. I2C_write_reg(0x30, 0x80); // PAT_T1 Trise & Ton
  1035. I2C_write_reg(0x31, 0x00); // PAT_T2 Tfall & Toff
  1036. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  1037. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  1038. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1039. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1040. }
  1041. }else if(YELLOW_DELAY_ON!=0 && YELLOW_DELAY_OFF!=0)
  1042. {
  1043. I2C_write_reg(0x00, 0x55); // software reset
  1044. I2C_write_reg(0x01, 0x03); // GCR
  1045. I2C_write_reg(0x03, 0x01); // IMAX
  1046. I2C_write_reg(0x04, 0x01); // LCFG1
  1047. I2C_write_reg(0x05, 0x01); // LCFG2
  1048. I2C_write_reg(0x06, 0x01); // LCFG3
  1049. I2C_write_reg(0x07, 0x07); // LEDEN
  1050. I2C_write_reg(0x08, 0x08); // LEDCTR
  1051. I2C_write_reg(0x10, 0xFF); // Color1_R
  1052. I2C_write_reg(0x11, 0xFF); // Color1_G
  1053. I2C_write_reg(0x12, 0x00); // Color1_B
  1054. I2C_write_reg(0x1C, 0xFF); // PWM1
  1055. I2C_write_reg(0x1D, 0xFF); // PWM2
  1056. I2C_write_reg(0x1E, 0xFF); // PWM3
  1057. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1058. I2C_write_reg(0x30, 0x14); // PAT_T1 Trise & Ton
  1059. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1060. I2C_write_reg(0x32, 0x31); // PAT_T3 Tslot & Tdelay
  1061. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1062. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1063. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1064. }else
  1065. {
  1066. I2C_write_reg(0x00, 0x55); // software reset
  1067. I2C_write_reg(0x01, 0x03); // GCR
  1068. I2C_write_reg(0x03, 0x01); // IMAX
  1069. I2C_write_reg(0x04, 0x00); // LCFG1
  1070. I2C_write_reg(0x05, 0x00); // LCFG2
  1071. I2C_write_reg(0x06, 0x00); // LCFG3
  1072. I2C_write_reg(0x07, 0x07); // LEDEN
  1073. I2C_write_reg(0x10, 0xFF); // Color1_R
  1074. I2C_write_reg(0x11, 0xFF); // Color1_G
  1075. I2C_write_reg(0x12, 0x00); // Color1_B
  1076. I2C_write_reg(0x1C, 0xFF); // PWM1
  1077. I2C_write_reg(0x1D, 0xFF); // PWM2
  1078. I2C_write_reg(0x1E, 0xFF); // PWM3
  1079. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1080. }
  1081. }
  1082. else
  1083. {
  1084. I2C_write_reg(0x10, 0x00); // Color1_R
  1085. I2C_write_reg(0x11, 0x00); // Color1_G
  1086. I2C_write_reg(0x12, 0x00); // Color1_B
  1087. I2C_write_reg(0x1C, 0x00); // PWM1
  1088. I2C_write_reg(0x1D, 0x00); // PWM2
  1089. I2C_write_reg(0x1E, 0x00); // PWM3
  1090. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1091. YELLOW_DELAY_ON = 0;
  1092. YELLOW_DELAY_OFF = 0;
  1093. }
  1094. return len;
  1095. }
  1096. static ssize_t AW2015_Set_Pink(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  1097. {
  1098. unsigned int databuf[16];
  1099. sscanf(buf,"%d",&databuf[0]);
  1100. I2C_write_reg(0x00, 0x55); // software reset
  1101. I2C_write_reg(0x01, 0x03); // GCR
  1102. I2C_write_reg(0x03, 0x01); // IMAX
  1103. I2C_write_reg(0x04, 0x00); // LCFG1
  1104. I2C_write_reg(0x05, 0x00); // LCFG2
  1105. I2C_write_reg(0x06, 0x00); // LCFG3
  1106. I2C_write_reg(0x07, 0x07); // LEDEN
  1107. if(databuf[0]!=0)
  1108. {
  1109. if(PINK_DELAY_OFF == 500)
  1110. {
  1111. if(PINK_DELAY_ON == 500)
  1112. {
  1113. I2C_write_reg(0x00, 0x55); // software reset
  1114. I2C_write_reg(0x01, 0x03); // GCR
  1115. I2C_write_reg(0x03, 0x01); // IMAX
  1116. I2C_write_reg(0x04, 0x01); // LCFG1
  1117. I2C_write_reg(0x05, 0x01); // LCFG2
  1118. I2C_write_reg(0x06, 0x01); // LCFG3
  1119. I2C_write_reg(0x07, 0x07); // LEDEN
  1120. I2C_write_reg(0x08, 0x08); // LEDCTR
  1121. I2C_write_reg(0x10, 0xFF); // Color1_R
  1122. I2C_write_reg(0x11, 0x00); // Color1_G
  1123. I2C_write_reg(0x12, 0xFF); // Color1_B
  1124. I2C_write_reg(0x1C, 0xFF); // PWM1
  1125. I2C_write_reg(0x1D, 0xFF); // PWM2
  1126. I2C_write_reg(0x1E, 0xFF); // PWM3
  1127. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1128. I2C_write_reg(0x30, 0x00); // PAT_T1 Trise & Ton
  1129. I2C_write_reg(0x31, 0x02); // PAT_T2 Tfall & Toff
  1130. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  1131. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1132. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1133. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1134. }
  1135. else if(PINK_DELAY_ON == 1000)
  1136. {
  1137. I2C_write_reg(0x00, 0x55); // software reset
  1138. I2C_write_reg(0x01, 0x03); // GCR
  1139. I2C_write_reg(0x03, 0x01); // IMAX
  1140. I2C_write_reg(0x04, 0x01); // LCFG1
  1141. I2C_write_reg(0x05, 0x01); // LCFG2
  1142. I2C_write_reg(0x06, 0x01); // LCFG3
  1143. I2C_write_reg(0x07, 0x07); // LEDEN
  1144. I2C_write_reg(0x08, 0x08); // LEDCTR
  1145. I2C_write_reg(0x10, 0xFF); // Color1_R
  1146. I2C_write_reg(0x11, 0x00); // Color1_G
  1147. I2C_write_reg(0x12, 0xFF); // Color1_B
  1148. I2C_write_reg(0x1C, 0xFF); // PWM1
  1149. I2C_write_reg(0x1D, 0xFF); // PWM2
  1150. I2C_write_reg(0x1E, 0xFF); // PWM3
  1151. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1152. I2C_write_reg(0x30, 0x13); // PAT_T1 Trise & Ton
  1153. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1154. I2C_write_reg(0x32, 0x20); // PAT_T3 Tslot & Tdelay
  1155. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1156. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1157. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1158. }
  1159. else if(PINK_DELAY_ON == 1499)
  1160. {
  1161. I2C_write_reg(0x00, 0x55); // software reset
  1162. I2C_write_reg(0x01, 0x03); // GCR
  1163. I2C_write_reg(0x03, 0x01); // IMAX
  1164. I2C_write_reg(0x04, 0x01); // LCFG1
  1165. I2C_write_reg(0x05, 0x01); // LCFG2
  1166. I2C_write_reg(0x06, 0x01); // LCFG3
  1167. I2C_write_reg(0x07, 0x07); // LEDEN
  1168. I2C_write_reg(0x08, 0x08); // LEDCTR
  1169. I2C_write_reg(0x10, 0xFF); // Color1_R
  1170. I2C_write_reg(0x11, 0x00); // Color1_G
  1171. I2C_write_reg(0x12, 0xFF); // Color1_B
  1172. I2C_write_reg(0x1C, 0xFF); // PWM1
  1173. I2C_write_reg(0x1D, 0xFF); // PWM2
  1174. I2C_write_reg(0x1E, 0xFF); // PWM3
  1175. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1176. I2C_write_reg(0x30, 0x80); // PAT_T1 Trise & Ton
  1177. I2C_write_reg(0x31, 0x00); // PAT_T2 Tfall & Toff
  1178. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  1179. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  1180. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1181. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1182. }
  1183. }else if(PINK_DELAY_ON!=0 &&PINK_DELAY_OFF!=0)
  1184. {
  1185. I2C_write_reg(0x00, 0x55); // software reset
  1186. I2C_write_reg(0x01, 0x03); // GCR
  1187. I2C_write_reg(0x03, 0x01); // IMAX
  1188. I2C_write_reg(0x04, 0x01); // LCFG1
  1189. I2C_write_reg(0x05, 0x01); // LCFG2
  1190. I2C_write_reg(0x06, 0x01); // LCFG3
  1191. I2C_write_reg(0x07, 0x07); // LEDEN
  1192. I2C_write_reg(0x08, 0x08); // LEDCTR
  1193. I2C_write_reg(0x10, 0xFF); // Color1_R
  1194. I2C_write_reg(0x11, 0x00); // Color1_G
  1195. I2C_write_reg(0x12, 0xFF); // Color1_B
  1196. I2C_write_reg(0x1C, 0xFF); // PWM1
  1197. I2C_write_reg(0x1D, 0xFF); // PWM2
  1198. I2C_write_reg(0x1E, 0xFF); // PWM3
  1199. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1200. I2C_write_reg(0x30, 0x14); // PAT_T1 Trise & Ton
  1201. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1202. I2C_write_reg(0x32, 0x31); // PAT_T3 Tslot & Tdelay
  1203. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1204. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1205. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1206. }else
  1207. {
  1208. I2C_write_reg(0x00, 0x55); // software reset
  1209. I2C_write_reg(0x01, 0x03); // GCR
  1210. I2C_write_reg(0x03, 0x01); // IMAX
  1211. I2C_write_reg(0x04, 0x00); // LCFG1
  1212. I2C_write_reg(0x05, 0x00); // LCFG2
  1213. I2C_write_reg(0x06, 0x00); // LCFG3
  1214. I2C_write_reg(0x07, 0x07); // LEDEN
  1215. I2C_write_reg(0x10, 0xFF); // Color1_R
  1216. I2C_write_reg(0x11, 0x00); // Color1_G
  1217. I2C_write_reg(0x12, 0xFF); // Color1_B
  1218. I2C_write_reg(0x1C, 0xFF); // PWM1
  1219. I2C_write_reg(0x1D, 0xFF); // PWM2
  1220. I2C_write_reg(0x1E, 0xFF); // PWM3
  1221. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1222. }
  1223. }
  1224. else
  1225. {
  1226. I2C_write_reg(0x10, 0x00); // Color1_R
  1227. I2C_write_reg(0x11, 0x00); // Color1_G
  1228. I2C_write_reg(0x12, 0x00); // Color1_B
  1229. I2C_write_reg(0x1C, 0x00); // PWM1
  1230. I2C_write_reg(0x1D, 0x00); // PWM2
  1231. I2C_write_reg(0x1E, 0x00); // PWM3
  1232. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1233. PINK_DELAY_ON = 0;
  1234. PINK_DELAY_OFF = 0;
  1235. }
  1236. return len;
  1237. }
  1238. static ssize_t AW2015_Set_Red(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  1239. {
  1240. unsigned int databuf[16];
  1241. sscanf(buf,"%d",&databuf[0]);
  1242. if(databuf[0]!=0)
  1243. {
  1244. if(RED_DELAY_OFF == 500)
  1245. {
  1246. if(RED_DELAY_ON == 500)
  1247. {
  1248. I2C_write_reg(0x00, 0x55); // software reset
  1249. I2C_write_reg(0x01, 0x03); // GCR
  1250. I2C_write_reg(0x03, 0x01); // IMAX
  1251. I2C_write_reg(0x04, 0x01); // LCFG1
  1252. I2C_write_reg(0x05, 0x01); // LCFG2
  1253. I2C_write_reg(0x06, 0x01); // LCFG3
  1254. I2C_write_reg(0x07, 0x07); // LEDEN
  1255. I2C_write_reg(0x08, 0x08); // LEDCTR
  1256. I2C_write_reg(0x10, 0xFF); // Color1_R
  1257. I2C_write_reg(0x11, 0x00); // Color1_G
  1258. I2C_write_reg(0x12, 0x00); // Color1_B
  1259. I2C_write_reg(0x1C, 0xFF); // PWM1
  1260. I2C_write_reg(0x1D, 0x00); // PWM2
  1261. I2C_write_reg(0x1E, 0x00); // PWM3
  1262. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1263. I2C_write_reg(0x30, 0x00); // PAT_T1 Trise & Ton
  1264. I2C_write_reg(0x31, 0x02); // PAT_T2 Tfall & Toff
  1265. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  1266. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1267. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1268. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1269. }
  1270. else if(RED_DELAY_ON == 1000)
  1271. {
  1272. I2C_write_reg(0x00, 0x55); // software reset
  1273. I2C_write_reg(0x01, 0x03); // GCR
  1274. I2C_write_reg(0x03, 0x01); // IMAX
  1275. I2C_write_reg(0x04, 0x01); // LCFG1
  1276. I2C_write_reg(0x05, 0x01); // LCFG2
  1277. I2C_write_reg(0x06, 0x01); // LCFG3
  1278. I2C_write_reg(0x07, 0x07); // LEDEN
  1279. I2C_write_reg(0x08, 0x08); // LEDCTR
  1280. I2C_write_reg(0x10, 0xFF); // Color1_R
  1281. I2C_write_reg(0x11, 0x00); // Color1_G
  1282. I2C_write_reg(0x12, 0x00); // Color1_B
  1283. I2C_write_reg(0x1C, 0xFF); // PWM1
  1284. I2C_write_reg(0x1D, 0x00); // PWM2
  1285. I2C_write_reg(0x1E, 0x00); // PWM3
  1286. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1287. I2C_write_reg(0x30, 0x13); // PAT_T1 Trise & Ton
  1288. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1289. I2C_write_reg(0x32, 0x20); // PAT_T3 Tslot & Tdelay
  1290. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1291. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1292. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1293. }
  1294. else if(RED_DELAY_ON == 1499)
  1295. {
  1296. I2C_write_reg(0x00, 0x55); // software reset
  1297. I2C_write_reg(0x01, 0x03); // GCR
  1298. I2C_write_reg(0x03, 0x01); // IMAX
  1299. I2C_write_reg(0x04, 0x01); // LCFG1
  1300. I2C_write_reg(0x05, 0x01); // LCFG2
  1301. I2C_write_reg(0x06, 0x01); // LCFG3
  1302. I2C_write_reg(0x07, 0x07); // LEDEN
  1303. I2C_write_reg(0x08, 0x08); // LEDCTR
  1304. I2C_write_reg(0x10, 0xFF); // Color1_R
  1305. I2C_write_reg(0x11, 0x00); // Color1_G
  1306. I2C_write_reg(0x12, 0x00); // Color1_B
  1307. I2C_write_reg(0x1C, 0xFF); // PWM1
  1308. I2C_write_reg(0x1D, 0x00); // PWM2
  1309. I2C_write_reg(0x1E, 0x00); // PWM3
  1310. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1311. I2C_write_reg(0x30, 0x80); // PAT_T1 Trise & Ton
  1312. I2C_write_reg(0x31, 0x00); // PAT_T2 Tfall & Toff
  1313. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  1314. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  1315. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1316. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1317. }
  1318. }else if(RED_DELAY_ON!=0 && RED_DELAY_OFF!=0)
  1319. {
  1320. I2C_write_reg(0x00, 0x55); // software reset
  1321. I2C_write_reg(0x01, 0x03); // GCR
  1322. I2C_write_reg(0x03, 0x01); // IMAX
  1323. I2C_write_reg(0x04, 0x01); // LCFG1
  1324. I2C_write_reg(0x05, 0x01); // LCFG2
  1325. I2C_write_reg(0x06, 0x01); // LCFG3
  1326. I2C_write_reg(0x07, 0x07); // LEDEN
  1327. I2C_write_reg(0x08, 0x08); // LEDCTR
  1328. I2C_write_reg(0x10, 0xFF); // Color1_R
  1329. I2C_write_reg(0x11, 0x00); // Color1_G
  1330. I2C_write_reg(0x12, 0x00); // Color1_B
  1331. I2C_write_reg(0x1C, 0xFF); // PWM1
  1332. I2C_write_reg(0x1D, 0x00); // PWM2
  1333. I2C_write_reg(0x1E, 0x00); // PWM3
  1334. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1335. I2C_write_reg(0x30, 0x14); // PAT_T1 Trise & Ton
  1336. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1337. I2C_write_reg(0x32, 0x31); // PAT_T3 Tslot & Tdelay
  1338. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  1339. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1340. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1341. }else
  1342. {
  1343. I2C_write_reg(0x00, 0x55); // software reset
  1344. I2C_write_reg(0x01, 0x03); // GCR
  1345. I2C_write_reg(0x03, 0x01); // IMAX
  1346. I2C_write_reg(0x04, 0x00); // LCFG1
  1347. I2C_write_reg(0x05, 0x00); // LCFG2
  1348. I2C_write_reg(0x06, 0x00); // LCFG3
  1349. I2C_write_reg(0x07, 0x07); // LEDEN
  1350. I2C_write_reg(0x10, 0xFF); // Color1_R
  1351. I2C_write_reg(0x11, 0x00); // Color1_G
  1352. I2C_write_reg(0x12, 0x00); // Color1_B
  1353. I2C_write_reg(0x1C, 0xFF); // PWM1
  1354. I2C_write_reg(0x1D, 0xFF); // PWM2
  1355. I2C_write_reg(0x1E, 0xFF); // PWM3
  1356. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1357. }
  1358. }
  1359. else
  1360. {
  1361. I2C_write_reg(0x00, 0x55); // software reset
  1362. I2C_write_reg(0x01, 0x03); // GCR
  1363. I2C_write_reg(0x03, 0x01); // IMAX
  1364. I2C_write_reg(0x04, 0x00); // LCFG1
  1365. I2C_write_reg(0x05, 0x00); // LCFG2
  1366. I2C_write_reg(0x06, 0x00); // LCFG3
  1367. I2C_write_reg(0x07, 0x07); // LEDEN
  1368. I2C_write_reg(0x10, 0x00); // Color1_R
  1369. I2C_write_reg(0x11, 0x00); // Color1_G
  1370. I2C_write_reg(0x12, 0x00); // Color1_B
  1371. I2C_write_reg(0x1C, 0x00); // PWM1
  1372. I2C_write_reg(0x1D, 0x00); // PWM2
  1373. I2C_write_reg(0x1E, 0x00); // PWM3
  1374. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1375. RED_DELAY_ON = 0;
  1376. RED_DELAY_OFF = 0;
  1377. }
  1378. return len;
  1379. }
  1380. static ssize_t AW2015_Set_Green(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  1381. {
  1382. unsigned int databuf[16];
  1383. sscanf(buf,"%d",&databuf[0]);
  1384. I2C_write_reg(0x00, 0x55); // software reset
  1385. I2C_write_reg(0x01, 0x03); // GCR
  1386. I2C_write_reg(0x03, 0x01); // IMAX
  1387. I2C_write_reg(0x04, 0x00); // LCFG1
  1388. I2C_write_reg(0x05, 0x00); // LCFG2
  1389. I2C_write_reg(0x06, 0x00); // LCFG3
  1390. I2C_write_reg(0x07, 0x07); // LEDEN
  1391. if(databuf[0]!=0)
  1392. {
  1393. if(GREEN_DELAY_OFF == 500)
  1394. {
  1395. if(GREEN_DELAY_ON == 500)
  1396. {
  1397. I2C_write_reg(0x00, 0x55); // software reset
  1398. I2C_write_reg(0x01, 0x03); // GCR
  1399. I2C_write_reg(0x03, 0x01); // IMAX
  1400. I2C_write_reg(0x04, 0x01); // LCFG1
  1401. I2C_write_reg(0x05, 0x01); // LCFG2
  1402. I2C_write_reg(0x06, 0x01); // LCFG3
  1403. I2C_write_reg(0x07, 0x07); // LEDEN
  1404. I2C_write_reg(0x08, 0x08); // LEDCTR
  1405. I2C_write_reg(0x10, 0x00); // Color1_R
  1406. I2C_write_reg(0x11, 0xFF); // Color1_G
  1407. I2C_write_reg(0x12, 0x00); // Color1_B
  1408. I2C_write_reg(0x1C, 0xFF); // PWM1
  1409. I2C_write_reg(0x1D, 0xFF); // PWM2
  1410. I2C_write_reg(0x1E, 0xFF); // PWM3
  1411. I2C_write_reg(0x30, 0x00); // PAT_T1 Trise & Ton
  1412. I2C_write_reg(0x31, 0x02); // PAT_T2 Tfall & Toff
  1413. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  1414. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1415. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1416. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1417. }
  1418. else if(GREEN_DELAY_ON == 1000)
  1419. {
  1420. I2C_write_reg(0x00, 0x55); // software reset
  1421. I2C_write_reg(0x01, 0x03); // GCR
  1422. I2C_write_reg(0x03, 0x01); // IMAX
  1423. I2C_write_reg(0x04, 0x01); // LCFG1
  1424. I2C_write_reg(0x05, 0x01); // LCFG2
  1425. I2C_write_reg(0x06, 0x01); // LCFG3
  1426. I2C_write_reg(0x07, 0x07); // LEDEN
  1427. I2C_write_reg(0x08, 0x08); // LEDCTR
  1428. I2C_write_reg(0x10, 0x00); // Color1_R
  1429. I2C_write_reg(0x11, 0xFF); // Color1_G
  1430. I2C_write_reg(0x12, 0x00); // Color1_B
  1431. I2C_write_reg(0x1C, 0xFF); // PWM1
  1432. I2C_write_reg(0x1D, 0xFF); // PWM2
  1433. I2C_write_reg(0x1E, 0xFF); // PWM3
  1434. I2C_write_reg(0x30, 0x13); // PAT_T1 Trise & Ton
  1435. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1436. I2C_write_reg(0x32, 0x20); // PAT_T3 Tslot & Tdelay
  1437. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1438. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1439. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1440. }
  1441. else if(GREEN_DELAY_ON == 1499)
  1442. {
  1443. I2C_write_reg(0x00, 0x55); // software reset
  1444. I2C_write_reg(0x01, 0x03); // GCR
  1445. I2C_write_reg(0x03, 0x01); // IMAX
  1446. I2C_write_reg(0x04, 0x01); // LCFG1
  1447. I2C_write_reg(0x05, 0x01); // LCFG2
  1448. I2C_write_reg(0x06, 0x01); // LCFG3
  1449. I2C_write_reg(0x07, 0x07); // LEDEN
  1450. I2C_write_reg(0x08, 0x08); // LEDCTR
  1451. I2C_write_reg(0x10, 0x00); // Color1_R
  1452. I2C_write_reg(0x11, 0xFF); // Color1_G
  1453. I2C_write_reg(0x12, 0x00); // Color1_B
  1454. I2C_write_reg(0x1C, 0xFF); // PWM1
  1455. I2C_write_reg(0x1D, 0xFF); // PWM2
  1456. I2C_write_reg(0x1E, 0xFF); // PWM3
  1457. I2C_write_reg(0x30, 0x80); // PAT_T1 Trise & Ton
  1458. I2C_write_reg(0x31, 0x00); // PAT_T2 Tfall & Toff
  1459. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  1460. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  1461. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1462. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1463. }
  1464. }
  1465. else if (GREEN_DELAY_ON!=0 &&GREEN_DELAY_OFF!=0)
  1466. {
  1467. I2C_write_reg(0x00, 0x55); // software reset
  1468. I2C_write_reg(0x01, 0x03); // GCR
  1469. I2C_write_reg(0x03, 0x01); // IMAX
  1470. I2C_write_reg(0x04, 0x01); // LCFG1
  1471. I2C_write_reg(0x05, 0x01); // LCFG2
  1472. I2C_write_reg(0x06, 0x01); // LCFG3
  1473. I2C_write_reg(0x07, 0x07); // LEDEN
  1474. I2C_write_reg(0x08, 0x08); // LEDCTR
  1475. I2C_write_reg(0x10, 0x00); // Color1_R
  1476. I2C_write_reg(0x11, 0xFF); // Color1_G
  1477. I2C_write_reg(0x12, 0x00); // Color1_B
  1478. I2C_write_reg(0x1C, 0xFF); // PWM1
  1479. I2C_write_reg(0x1D, 0xFF); // PWM2
  1480. I2C_write_reg(0x1E, 0xFF); // PWM3
  1481. I2C_write_reg(0x30, 0x14); // PAT_T1 Trise & Ton
  1482. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1483. I2C_write_reg(0x32, 0x31); // PAT_T3 Tslot & Tdelay
  1484. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1485. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1486. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1487. }else
  1488. {
  1489. I2C_write_reg(0x00, 0x55); // software reset
  1490. I2C_write_reg(0x01, 0x03); // GCR
  1491. I2C_write_reg(0x03, 0x01); // IMAX
  1492. I2C_write_reg(0x04, 0x00); // LCFG1
  1493. I2C_write_reg(0x05, 0x00); // LCFG2
  1494. I2C_write_reg(0x06, 0x00); // LCFG3
  1495. I2C_write_reg(0x07, 0x07); // LEDEN
  1496. I2C_write_reg(0x08, 0x08); // LEDCTR
  1497. I2C_write_reg(0x10, 0x00); // Color1_R
  1498. I2C_write_reg(0x11, 0xFF); // Color1_G
  1499. I2C_write_reg(0x12, 0x00); // Color1_B
  1500. I2C_write_reg(0x1C, 0xFF); // PWM1
  1501. I2C_write_reg(0x1D, 0xFF); // PWM2
  1502. I2C_write_reg(0x1E, 0xFF); // PWM3
  1503. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1504. }
  1505. }
  1506. else
  1507. {
  1508. I2C_write_reg(0x10, 0x00); // Color1_R
  1509. I2C_write_reg(0x11, 0x00); // Color1_G
  1510. I2C_write_reg(0x12, 0x00); // Color1_B
  1511. I2C_write_reg(0x1C, 0x00); // PWM1
  1512. I2C_write_reg(0x1D, 0x00); // PWM2
  1513. I2C_write_reg(0x1E, 0x00); // PWM3
  1514. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1515. GREEN_DELAY_ON = 0;
  1516. GREEN_DELAY_OFF = 0;
  1517. }
  1518. return len;
  1519. }
  1520. unsigned char AW2015_Set_Green_on_off(int status)
  1521. {
  1522. I2C_write_reg(0x00, 0x55); // software reset
  1523. I2C_write_reg(0x01, 0x03); // GCR
  1524. I2C_write_reg(0x03, 0x01); // IMAX
  1525. I2C_write_reg(0x04, 0x00); // LCFG1
  1526. I2C_write_reg(0x05, 0x00); // LCFG2
  1527. I2C_write_reg(0x06, 0x00); // LCFG3
  1528. I2C_write_reg(0x07, 0x07); // LEDEN
  1529. if(status!=0)
  1530. {
  1531. I2C_write_reg(0x10, 0x00); // Color1_R
  1532. I2C_write_reg(0x11, 0xFF); // Color1_G
  1533. I2C_write_reg(0x12, 0x00); // Color1_B
  1534. I2C_write_reg(0x1C, 0x00); // PWM1
  1535. I2C_write_reg(0x1D, 0xFF); // PWM2
  1536. I2C_write_reg(0x1E, 0x00); // PWM3
  1537. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1538. }
  1539. else
  1540. {
  1541. I2C_write_reg(0x10, 0x00); // Color1_R
  1542. I2C_write_reg(0x11, 0x00); // Color1_G
  1543. I2C_write_reg(0x12, 0x00); // Color1_B
  1544. I2C_write_reg(0x1C, 0x00); // PWM1
  1545. I2C_write_reg(0x1D, 0x00); // PWM2
  1546. I2C_write_reg(0x1E, 0x00); // PWM3
  1547. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1548. }
  1549. return 0;
  1550. }
  1551. EXPORT_SYMBOL(AW2015_Set_Green_on_off);
  1552. static ssize_t AW2015_Set_Blue(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  1553. {
  1554. unsigned int databuf[16];
  1555. sscanf(buf,"%d",&databuf[0]);
  1556. I2C_write_reg(0x00, 0x55); // software reset
  1557. I2C_write_reg(0x01, 0x03); // GCR
  1558. I2C_write_reg(0x03, 0x01); // IMAX
  1559. I2C_write_reg(0x04, 0x00); // LCFG1
  1560. I2C_write_reg(0x05, 0x00); // LCFG2
  1561. I2C_write_reg(0x06, 0x00); // LCFG3
  1562. I2C_write_reg(0x07, 0x07); // LEDEN
  1563. if(databuf[0]!=0)
  1564. {
  1565. if(BLUE_DELAY_OFF == 500)
  1566. {
  1567. if(BLUE_DELAY_ON == 500)
  1568. {
  1569. I2C_write_reg(0x00, 0x55); // software reset
  1570. I2C_write_reg(0x01, 0x03); // GCR
  1571. I2C_write_reg(0x03, 0x01); // IMAX
  1572. I2C_write_reg(0x04, 0x01); // LCFG1
  1573. I2C_write_reg(0x05, 0x01); // LCFG2
  1574. I2C_write_reg(0x06, 0x01); // LCFG3
  1575. I2C_write_reg(0x07, 0x07); // LEDEN
  1576. I2C_write_reg(0x08, 0x08); // LEDCTR
  1577. I2C_write_reg(0x10, 0x00); // Color1_R
  1578. I2C_write_reg(0x11, 0x00); // Color1_G
  1579. I2C_write_reg(0x12, 0xFF); // Color1_B
  1580. I2C_write_reg(0x1C, 0xFF); // PWM1
  1581. I2C_write_reg(0x1D, 0xFF); // PWM2
  1582. I2C_write_reg(0x1E, 0xFF); // PWM3
  1583. I2C_write_reg(0x30, 0x00); // PAT_T1 Trise & Ton
  1584. I2C_write_reg(0x31, 0x02); // PAT_T2 Tfall & Toff
  1585. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  1586. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1587. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1588. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1589. }
  1590. else if(BLUE_DELAY_ON == 1000)
  1591. {
  1592. I2C_write_reg(0x00, 0x55); // software reset
  1593. I2C_write_reg(0x01, 0x03); // GCR
  1594. I2C_write_reg(0x03, 0x01); // IMAX
  1595. I2C_write_reg(0x04, 0x01); // LCFG1
  1596. I2C_write_reg(0x05, 0x01); // LCFG2
  1597. I2C_write_reg(0x06, 0x01); // LCFG3
  1598. I2C_write_reg(0x07, 0x07); // LEDEN
  1599. I2C_write_reg(0x08, 0x08); // LEDCTR
  1600. I2C_write_reg(0x10, 0x00); // Color1_R
  1601. I2C_write_reg(0x11, 0x00); // Color1_G
  1602. I2C_write_reg(0x12, 0xFF); // Color1_B
  1603. I2C_write_reg(0x1C, 0xFF); // PWM1
  1604. I2C_write_reg(0x1D, 0xFF); // PWM2
  1605. I2C_write_reg(0x1E, 0xFF); // PWM3
  1606. I2C_write_reg(0x30, 0x13); // PAT_T1 Trise & Ton
  1607. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1608. I2C_write_reg(0x32, 0x20); // PAT_T3 Tslot & Tdelay
  1609. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1610. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1611. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1612. }
  1613. else if(BLUE_DELAY_ON == 1499)
  1614. {
  1615. I2C_write_reg(0x00, 0x55); // software reset
  1616. I2C_write_reg(0x01, 0x03); // GCR
  1617. I2C_write_reg(0x03, 0x01); // IMAX
  1618. I2C_write_reg(0x04, 0x01); // LCFG1
  1619. I2C_write_reg(0x05, 0x01); // LCFG2
  1620. I2C_write_reg(0x06, 0x01); // LCFG3
  1621. I2C_write_reg(0x07, 0x07); // LEDEN
  1622. I2C_write_reg(0x08, 0x08); // LEDCTR
  1623. I2C_write_reg(0x10, 0x00); // Color1_R
  1624. I2C_write_reg(0x11, 0x00); // Color1_G
  1625. I2C_write_reg(0x12, 0xFF); // Color1_B
  1626. I2C_write_reg(0x1C, 0xFF); // PWM1
  1627. I2C_write_reg(0x1D, 0xFF); // PWM2
  1628. I2C_write_reg(0x1E, 0xFF); // PWM3
  1629. I2C_write_reg(0x30, 0x80); // PAT_T1 Trise & Ton
  1630. I2C_write_reg(0x31, 0x00); // PAT_T2 Tfall & Toff
  1631. I2C_write_reg(0x32, 0x00); // PAT_T3 Tslot & Tdelay
  1632. I2C_write_reg(0x33, 0x00); // PAT_T4 PAT_CTR & Color
  1633. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1634. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1635. }
  1636. }else if(BLUE_DELAY_ON!=0 &&BLUE_DELAY_OFF!=0)
  1637. {
  1638. I2C_write_reg(0x00, 0x55); // software reset
  1639. I2C_write_reg(0x01, 0x03); // GCR
  1640. I2C_write_reg(0x03, 0x01); // IMAX
  1641. I2C_write_reg(0x04, 0x01); // LCFG1
  1642. I2C_write_reg(0x05, 0x01); // LCFG2
  1643. I2C_write_reg(0x06, 0x01); // LCFG3
  1644. I2C_write_reg(0x07, 0x07); // LEDEN
  1645. I2C_write_reg(0x08, 0x08); // LEDCTR
  1646. I2C_write_reg(0x10, 0x00); // Color1_R
  1647. I2C_write_reg(0x11, 0x00); // Color1_G
  1648. I2C_write_reg(0x12, 0xFF); // Color1_B
  1649. I2C_write_reg(0x1C, 0xFF); // PWM1
  1650. I2C_write_reg(0x1D, 0xFF); // PWM2
  1651. I2C_write_reg(0x1E, 0xFF); // PWM3
  1652. I2C_write_reg(0x30, 0x14); // PAT_T1 Trise & Ton
  1653. I2C_write_reg(0x31, 0x01); // PAT_T2 Tfall & Toff
  1654. I2C_write_reg(0x32, 0x31); // PAT_T3 Tslot & Tdelay
  1655. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1656. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1657. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1658. }else
  1659. {
  1660. I2C_write_reg(0x00, 0x55); // software reset
  1661. I2C_write_reg(0x01, 0x03); // GCR
  1662. I2C_write_reg(0x03, 0x01); // IMAX
  1663. I2C_write_reg(0x04, 0x00); // LCFG1
  1664. I2C_write_reg(0x05, 0x00); // LCFG2
  1665. I2C_write_reg(0x06, 0x00); // LCFG3
  1666. I2C_write_reg(0x07, 0x07); // LEDEN
  1667. I2C_write_reg(0x08, 0x08); // LEDCTR
  1668. I2C_write_reg(0x10, 0x00); // Color1_R
  1669. I2C_write_reg(0x11, 0x00); // Color1_G
  1670. I2C_write_reg(0x12, 0xFF); // Color1_B
  1671. I2C_write_reg(0x1C, 0xFF); // PWM1
  1672. I2C_write_reg(0x1D, 0xFF); // PWM2
  1673. I2C_write_reg(0x1E, 0xFF); // PWM3
  1674. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1675. }
  1676. }
  1677. else
  1678. {
  1679. I2C_write_reg(0x10, 0x00); // Color1_R
  1680. I2C_write_reg(0x11, 0x00); // Color1_G
  1681. I2C_write_reg(0x12, 0x00); // Color1_B
  1682. I2C_write_reg(0x1C, 0x00); // PWM1
  1683. I2C_write_reg(0x1D, 0x00); // PWM2
  1684. I2C_write_reg(0x1E, 0x00); // PWM3
  1685. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1686. BLUE_DELAY_ON = 0;
  1687. BLUE_DELAY_OFF = 0;
  1688. }
  1689. return len;
  1690. }
  1691. ///////////////////////////////////////////////////////////////////////////////////////////
  1692. // |-|_|-|______|-|_|-|______|-|_|-|______
  1693. ///////////////////////////////////////////////////////////////////////////////////////////
  1694. unsigned char AW2015_Multi_Pulse(void)
  1695. {
  1696. I2C_write_reg(0x00, 0x55); // software reset
  1697. I2C_write_reg(0x01, 0x03); // GCR
  1698. I2C_write_reg(0x03, 0x01); // IMAX
  1699. I2C_write_reg(0x04, 0x01); // LCFG1
  1700. I2C_write_reg(0x05, 0x01); // LCFG2
  1701. I2C_write_reg(0x06, 0x01); // LCFG3
  1702. I2C_write_reg(0x07, 0x07); // LEDEN
  1703. I2C_write_reg(0x08, 0x08); // LEDCTR
  1704. I2C_write_reg(0x10, 0xFF); // Color1_R
  1705. I2C_write_reg(0x11, 0x00); // Color1_G
  1706. I2C_write_reg(0x12, 0x00); // Color1_B
  1707. I2C_write_reg(0x1C, 0xFF); // PWM1
  1708. I2C_write_reg(0x1D, 0xFF); // PWM2
  1709. I2C_write_reg(0x1E, 0xFF); // PWM3
  1710. I2C_write_reg(0x30, 0x03); // PAT_T1 Trise & Ton
  1711. I2C_write_reg(0x31, 0x08); // PAT_T2 Tfall & Toff
  1712. I2C_write_reg(0x32, 0x30); // PAT_T3 Tslot & Tdelay
  1713. I2C_write_reg(0x33, 0x10); // PAT_T4 PAT_CTR & Color
  1714. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1715. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1716. return 0;
  1717. }
  1718. //////////////////////////////////////////////////////////////////////////////////////////
  1719. // R -> G -> B -> W -> R ...
  1720. //////////////////////////////////////////////////////////////////////////////////////////
  1721. unsigned char AW2015_Multi_Color(void)
  1722. {
  1723. I2C_write_reg(0x00, 0x55); // software reset
  1724. I2C_write_reg(0x01, 0x03); // GCR
  1725. I2C_write_reg(0x03, 0x01); // IMAX
  1726. I2C_write_reg(0x04, 0x01); // LCFG1
  1727. I2C_write_reg(0x05, 0x01); // LCFG2
  1728. I2C_write_reg(0x06, 0x01); // LCFG3
  1729. I2C_write_reg(0x07, 0x07); // LEDEN
  1730. I2C_write_reg(0x08, 0x08); // LEDCTR
  1731. I2C_write_reg(0x10, 0xFF); // Color1_R
  1732. I2C_write_reg(0x11, 0x00); // Color1_G
  1733. I2C_write_reg(0x12, 0x00); // Color1_B
  1734. I2C_write_reg(0x13, 0x00); // Color2_R
  1735. I2C_write_reg(0x14, 0xFF); // Color2_G
  1736. I2C_write_reg(0x15, 0x00); // Color2_B
  1737. I2C_write_reg(0x16, 0x00); // Color3_R
  1738. I2C_write_reg(0x17, 0x00); // Color3_G
  1739. I2C_write_reg(0x18, 0xFF); // Color3_B
  1740. I2C_write_reg(0x19, 0xFF); // Color4_R
  1741. I2C_write_reg(0x1A, 0xFF); // Color4_G
  1742. I2C_write_reg(0x1B, 0xFF); // Color4_B
  1743. I2C_write_reg(0x1C, 0xFF); // PWM1
  1744. I2C_write_reg(0x1D, 0xFF); // PWM2
  1745. I2C_write_reg(0x1E, 0xFF); // PWM3
  1746. I2C_write_reg(0x30, 0x60); // PAT_T1 Trise & Ton
  1747. I2C_write_reg(0x31, 0x64); // PAT_T2 Tfall & Toff
  1748. I2C_write_reg(0x32, 0x00); // PAT_T3 Tdelay
  1749. I2C_write_reg(0x33, 0x0F); // PAT_T4 PAT_CTR & Color
  1750. I2C_write_reg(0x34, 0x00); // PAT_T5 Timer
  1751. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1752. return 0;
  1753. }
  1754. //////////////////////////////////////////////////////////////////////////////////////////
  1755. // S O S
  1756. // . . . - - - . . .
  1757. // |-|__|-|__|-|_______ |---|__|---|__|---|_______ |-|__|-|__|-|_______
  1758. //////////////////////////////////////////////////////////////////////////////////////////
  1759. unsigned char AW2015_SOS(void)
  1760. {
  1761. I2C_write_reg(0x00, 0x55); // software reset
  1762. I2C_write_reg(0x01, 0x03); // GCR
  1763. I2C_write_reg(0x03, 0x01); // IMAX
  1764. I2C_write_reg(0x04, 0x01); // LCFG1
  1765. I2C_write_reg(0x05, 0x01); // LCFG2
  1766. I2C_write_reg(0x06, 0x01); // LCFG3
  1767. I2C_write_reg(0x07, 0x07); // LEDEN
  1768. I2C_write_reg(0x08, 0x08); // LEDCTR
  1769. I2C_write_reg(0x10, 0xFF); // Color1_R
  1770. I2C_write_reg(0x11, 0x00); // Color1_G
  1771. I2C_write_reg(0x12, 0x00); // Color1_B
  1772. I2C_write_reg(0x1C, 0xFF); // PWM1
  1773. I2C_write_reg(0x1D, 0xFF); // PWM2
  1774. I2C_write_reg(0x1E, 0xFF); // PWM3
  1775. I2C_write_reg(0x30, 0x04); // PAT1_T1 Trise & Ton
  1776. I2C_write_reg(0x31, 0x0B); // PAT1_T2 Tfall & Toff
  1777. I2C_write_reg(0x32, 0x70); // PAT1_T3 Tslot & Tdelay
  1778. I2C_write_reg(0x33, 0xE0); // PAT1_T4 PAT_CTR & Color
  1779. I2C_write_reg(0x34, 0x00); // PAT1_T5 Timer
  1780. I2C_write_reg(0x35, 0x07); // PAT2_T1 Trise & Ton
  1781. I2C_write_reg(0x36, 0x0B); // PAT2_T2 Tfall & Toff
  1782. I2C_write_reg(0x37, 0x70); // PAT2_T3 Tslot & Tdelay
  1783. I2C_write_reg(0x38, 0xE0); // PAT2_T4 PAT_CTR & Color
  1784. I2C_write_reg(0x39, 0x00); // PAT2_T5 Timer
  1785. I2C_write_reg(0x3A, 0x04); // PAT3_T1 Trise & Ton
  1786. I2C_write_reg(0x3B, 0x0B); // PAT3_T2 Tfall & Toff
  1787. I2C_write_reg(0x3C, 0x70); // PAT3_T3 Tslot & Tdelay
  1788. I2C_write_reg(0x3D, 0xE0); // PAT3_T4 PAT_CTR & Color
  1789. I2C_write_reg(0x3E, 0x00); // PAT3_T5 Timer
  1790. I2C_write_reg(0x09, 0x07); // PAT_RIN
  1791. return 0;
  1792. }
  1793. ////////////////////////////////////////////////////////////////////////////////////////////////////////////////
  1794. ////////////////////////////////////////////////////////////////////////////////////////////////////////////////
  1795. static ssize_t AW2015_get_reg(struct device* cd,struct device_attribute *attr, char* buf)
  1796. {
  1797. unsigned char reg_val;
  1798. unsigned char i;
  1799. ssize_t len = 0;
  1800. for(i=0;i<0x3A;i++)
  1801. {
  1802. reg_val = I2C_read_reg(i);
  1803. len += snprintf(buf+len, PAGE_SIZE-len, "reg%2X = 0x%2X, ", i,reg_val);
  1804. }
  1805. return len;
  1806. }
  1807. static ssize_t AW2015_set_reg(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  1808. {
  1809. unsigned int databuf[2];
  1810. if(2 == sscanf(buf,"%x %x",&databuf[0], &databuf[1]))
  1811. {
  1812. I2C_write_reg(databuf[0],databuf[1]);
  1813. }
  1814. return len;
  1815. }
  1816. static ssize_t AW2015_get_debug(struct device* cd,struct device_attribute *attr, char* buf)
  1817. {
  1818. ssize_t len = 0;
  1819. len += snprintf(buf+len, PAGE_SIZE-len, "AW2015_LED_OFF(void)\n");
  1820. len += snprintf(buf+len, PAGE_SIZE-len, "echo 0 > debug\n");
  1821. len += snprintf(buf+len, PAGE_SIZE-len, "\n");
  1822. len += snprintf(buf+len, PAGE_SIZE-len, "AW2015_LED_ON(r, g, b)\n");
  1823. len += snprintf(buf+len, PAGE_SIZE-len, "echo 1 r g b > debug\n");
  1824. len += snprintf(buf+len, PAGE_SIZE-len, "echo 1 255 255 255 > debug\n");
  1825. len += snprintf(buf+len, PAGE_SIZE-len, "\n");
  1826. len += snprintf(buf+len, PAGE_SIZE-len, "AW2015_LED_Blink(r, g, b, trise, ton, tfall, tfall)\n");
  1827. len += snprintf(buf+len, PAGE_SIZE-len, "echo 2 r g b trise ton tfall toff > debug\n");
  1828. len += snprintf(buf+len, PAGE_SIZE-len, "echo 2 255 255 255 1000 0 1000 1000 > debug\n");
  1829. len += snprintf(buf+len, PAGE_SIZE-len, "\n");
  1830. len += snprintf(buf+len, PAGE_SIZE-len, "AW2015_Multi_Pulse(void)\n");
  1831. len += snprintf(buf+len, PAGE_SIZE-len, "echo 3 > debug\n");
  1832. len += snprintf(buf+len, PAGE_SIZE-len, "\n");
  1833. len += snprintf(buf+len, PAGE_SIZE-len, "AW2015_Multi_Color(void)\n");
  1834. len += snprintf(buf+len, PAGE_SIZE-len, "echo 4 > debug\n");
  1835. len += snprintf(buf+len, PAGE_SIZE-len, "\n");
  1836. len += snprintf(buf+len, PAGE_SIZE-len, "AW2015_SOS(void)\n");
  1837. len += snprintf(buf+len, PAGE_SIZE-len, "echo 5 > debug\n");
  1838. len += snprintf(buf+len, PAGE_SIZE-len, "\n");
  1839. return len;
  1840. }
  1841. static ssize_t AW2015_set_debug(struct device* cd, struct device_attribute *attr, const char* buf, size_t len)
  1842. {
  1843. unsigned int databuf[16];
  1844. sscanf(buf,"%d",&databuf[0]);
  1845. if(databuf[0] == 0) { // OFF
  1846. AW2015_LED_OFF();
  1847. } else if(databuf[0] == 1) { //ON
  1848. sscanf(&buf[1], "%d %d %d", &databuf[1], &databuf[2], &databuf[3]);
  1849. AW2015_LED_ON(databuf[1], databuf[2], databuf[3]);
  1850. } else if(databuf[0] == 2) { //Blink
  1851. sscanf(&buf[1], "%d %d %d %d %d %d %d", &databuf[1], &databuf[2], &databuf[3], &databuf[4], &databuf[5], &databuf[6], &databuf[7]);
  1852. AW2015_LED_Blink(databuf[1], databuf[2], databuf[3], databuf[4], databuf[5], databuf[6], databuf[7]);
  1853. } else if(databuf[0] == 3) { //Multi Pulse
  1854. AW2015_Multi_Pulse();
  1855. } else if(databuf[0] == 4) { //Multi Color
  1856. AW2015_Multi_Color();
  1857. } else if(databuf[0] == 5) { //SOS
  1858. AW2015_SOS();
  1859. }
  1860. return len;
  1861. }
  1862. static int AW2015_create_sysfs(struct i2c_client *client)
  1863. {
  1864. int err;
  1865. struct device *dev = &(client->dev);
  1866. err = device_create_file(dev, &dev_attr_reg);
  1867. err = device_create_file(dev, &dev_attr_debug);
  1868. err = device_create_file(dev, &dev_attr_Red);
  1869. err = device_create_file(dev, &dev_attr_Green);
  1870. err = device_create_file(dev, &dev_attr_Blue);
  1871. err = device_create_file(dev, &dev_attr_Red_delay_off);
  1872. err = device_create_file(dev, &dev_attr_Red_delay_on);
  1873. err = device_create_file(dev, &dev_attr_Green_delay_off);
  1874. err = device_create_file(dev, &dev_attr_Green_delay_on);
  1875. err = device_create_file(dev, &dev_attr_Blue_delay_off);
  1876. err = device_create_file(dev, &dev_attr_Blue_delay_on);
  1877. err = device_create_file(dev, &dev_attr_White);
  1878. err = device_create_file(dev, &dev_attr_White_delay_off);
  1879. err = device_create_file(dev, &dev_attr_White_delay_on);
  1880. err = device_create_file(dev, &dev_attr_Gray);
  1881. err = device_create_file(dev, &dev_attr_Gray_delay_off);
  1882. err = device_create_file(dev, &dev_attr_Gray_delay_on);
  1883. err = device_create_file(dev, &dev_attr_Yellow);
  1884. err = device_create_file(dev, &dev_attr_Yellow_delay_off);
  1885. err = device_create_file(dev, &dev_attr_Yellow_delay_on);
  1886. err = device_create_file(dev, &dev_attr_Pink);
  1887. err = device_create_file(dev, &dev_attr_Pink_delay_off);
  1888. err = device_create_file(dev, &dev_attr_Pink_delay_on);
  1889. err = device_create_file(dev, &dev_attr_Orange);
  1890. err = device_create_file(dev, &dev_attr_Orange_delay_off);
  1891. err = device_create_file(dev, &dev_attr_Orange_delay_on);
  1892. err = device_create_file(dev, &dev_attr_Violet);
  1893. err = device_create_file(dev, &dev_attr_Violet_delay_off);
  1894. err = device_create_file(dev, &dev_attr_Violet_delay_on);
  1895. return err;
  1896. }
  1897. ////////////////////////////////////////////////////////////////////////////////////////////////////////////////
  1898. ////////////////////////////////////////////////////////////////////////////////////////////////////////////////
  1899. static int AW2015_i2c_probe(struct i2c_client *client, const struct i2c_device_id *id)
  1900. {
  1901. unsigned char reg_value;
  1902. unsigned char cnt = 5;
  1903. int err = 0;
  1904. //pr_err("AW2015_i2c_probe xmwuwh start\n");
  1905. if (!i2c_check_functionality(client->adapter, I2C_FUNC_I2C)) {
  1906. err = -ENODEV;
  1907. goto exit_check_functionality_failed;
  1908. }
  1909. //client->addr = 0x64;
  1910. AW2015_i2c_client = client;
  1911. while(cnt>0)
  1912. {
  1913. reg_value = I2C_read_reg(0x00);
  1914. printk("AW2015 CHIPID=0x%2x\n", reg_value);
  1915. if(reg_value == 0x31)
  1916. {
  1917. break;
  1918. }
  1919. cnt --;
  1920. msleep(10);
  1921. }
  1922. if(!cnt)
  1923. {
  1924. err = -ENODEV;
  1925. goto exit_create_singlethread;
  1926. }
  1927. AW2015_create_sysfs(client);
  1928. I2C_write_reg(0x00, 0x55); // software reset
  1929. return 0;
  1930. exit_create_singlethread:
  1931. AW2015_i2c_client = NULL;
  1932. exit_check_functionality_failed:
  1933. return err;
  1934. }
  1935. static int AW2015_i2c_remove(struct i2c_client *client)
  1936. {
  1937. AW2015_i2c_client = NULL;
  1938. return 0;
  1939. }
  1940. static const struct i2c_device_id AW2015_i2c_id[] = {
  1941. { AW2015_I2C_NAME, 0 },
  1942. { }
  1943. };
  1944. #ifdef CONFIG_OF
  1945. static const struct of_device_id aw2015_i2c_of_match[] = {
  1946. {.compatible = "awinic,pressure"},
  1947. {},
  1948. };
  1949. #endif
  1950. static struct i2c_driver AW2015_i2c_driver = {
  1951. .driver = {
  1952. .name = AW2015_I2C_NAME,
  1953. #ifdef CONFIG_OF
  1954. .of_match_table = aw2015_i2c_of_match,
  1955. #endif
  1956. },
  1957. .probe = AW2015_i2c_probe,
  1958. .remove = AW2015_i2c_remove,
  1959. .id_table = AW2015_i2c_id,
  1960. };
  1961. static int AW2015_led_remove(struct platform_device *pdev)
  1962. {
  1963. printk("AW2015 remove\n");
  1964. i2c_del_driver(&AW2015_i2c_driver);
  1965. return 0;
  1966. }
  1967. static int AW2015_led_probe(struct platform_device *pdev)
  1968. {
  1969. int ret;
  1970. printk("%s 1 start!\n", __func__);
  1971. ret = i2c_add_driver(&AW2015_i2c_driver);
  1972. if (ret != 0) {
  1973. printk("[%s] failed to register AW2015 i2c driver.\n", __func__);
  1974. return ret;
  1975. } else {
  1976. printk("[%s] Success to register AW2015 i2c driver.\n", __func__);
  1977. }
  1978. return 0;
  1979. }
  1980. #ifdef CONFIG_OF
  1981. static const struct of_device_id aw2015plt_of_match[] = {
  1982. {.compatible = "awinic,aw2015_led"},
  1983. {},
  1984. };
  1985. #endif
  1986. //static void aw2015_led_shutdown(struct platform_device *dev)
  1987. //{
  1988. // AW2015_LED_OFF();
  1989. // pr_err("******** xmwuwh aw2015_led_shutdown!! ********\n");
  1990. //}
  1991. static struct platform_driver AW2015_led_driver = {
  1992. .probe = AW2015_led_probe,
  1993. .remove = AW2015_led_remove,
  1994. //.shutdown = aw2015_led_shutdown,
  1995. .driver = {
  1996. .name = "aw2015_led",
  1997. #ifdef CONFIG_OF
  1998. .of_match_table = aw2015plt_of_match,
  1999. #endif
  2000. }
  2001. };
  2002. static int __init AW2015_led_init(void) {
  2003. int ret;
  2004. //pr_err("%s xmwuwh start\n", __func__);
  2005. ret = platform_driver_register(&AW2015_led_driver);
  2006. if (ret) {
  2007. printk("****[%s] Unable to register driver (%d)\n", __func__, ret);
  2008. return ret;
  2009. }
  2010. return 0;
  2011. }
  2012. static void __exit AW2015_led_exit(void) {
  2013. printk("%s exit\n", __func__);
  2014. platform_driver_unregister(&AW2015_led_driver);
  2015. }
  2016. module_init(AW2015_led_init);
  2017. module_exit(AW2015_led_exit);
  2018. MODULE_AUTHOR("<liweilei@awinic.com.cn>");
  2019. MODULE_DESCRIPTION("AWINIC AW2015 LED Driver");
  2020. MODULE_LICENSE("GPL");