release_notes.txt 350 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045
  1. nRF5 SDK v17.0.0
  2. ------------------------
  3. Release Date: June, 2020
  4. Highlights:
  5. - Added support for a new chip: nRF52820
  6. - Added support for a new SoftDevice: S122
  7. (size-optimized central-only Bluetooth Low Energy SoftDevice)
  8. - Added a driver for the new RF front-end module nRF21540
  9. - Removed IoT components and examples
  10. - Removed Keil 4 support
  11. The following toolchains/devices have been used for testing and verification:
  12. - ARM: MDK-ARM version 5.25
  13. - GCC: GCC ARM Embedded 9.2019q4.major
  14. - IAR: IAR Workbench 7.80.4
  15. - SES: SES 4.50
  16. *****
  17. Note for IAR 8 users:
  18. (Libraries for IAR 8 require wchar_t to be of size 32 bits while IAR 7 requires 16 bits).
  19. To run a project using IAR 8, follow these intructions:
  20. - Open the IAR project in IAR 8. The IAR workbench will automatically generate an IAR 8 compatible project file.
  21. - If the project contains one of the precompiled libraries listed below, replace it
  22. with the IAR 8 compatible alternative (there are no projects targeting nRF51 in this SDK).
  23. - Save the project.
  24. - When building the project, you might get the warning: "The header file 'cmsis_iar.h' is obsolete and should not be used. [...]".
  25. - The problem is described in DevZone post: https://devzone.nordicsemi.com/f/nordic-q-a/31123/iar-ewarm-8-22-1-complains-about-cmsis_iar-h
  26. The solution is to remove all occurrences of #include <cmsis_iar.h>.
  27. The affected libraries are:
  28. - micro-ecc crypto:
  29. - IAR7: Includes library located in the folder named “…_iar\…”.
  30. - IAR8: Switch to using the library from the folder named “…_armgcc\…”.
  31. - nrf_cc310, nrf_cc310_bl, and nrf_oberon:
  32. - IAR7: Link to a library where “short_wchar” is part of the folder name.
  33. - IAR8: Link to a library without “short_wchar” in part of the folder name.
  34. - Gazell, NFC Tag, and 802.15.4:
  35. - IAR7: Includes the library where the file name ends with “_iar”.
  36. - IAR8: Switch to using the library with similar file name that ends with “_gcc”.
  37. *****
  38. Supported SoftDevices:
  39. - S112 v7.x.x
  40. - S113 v7.x.x
  41. - S122 v8.x.x
  42. - S132 v7.x.x
  43. - S140 v7.x.x
  44. - S212 v6.1.x
  45. - S312 v6.1.x
  46. - S332 v6.1.x
  47. - S340 v6.1.x
  48. Supported boards:
  49. - PCA10040
  50. - PCA10040E (nRF52810 emulation on PCA10040)
  51. - PCA10056
  52. - PCA10056E (nRF52811 emulation on PCA10056)
  53. - PCA10100 (support in selected examples)
  54. - PCA10100E (nRF52820 emulation on PCA10100)
  55. - PCA10059 (support in selected examples)
  56. - D52DK1 from Garmin Canada (only for ANT examples)
  57. - PCA10112 (nRF52840 with the nRF2140 front-end chip)
  58. For other devices and boards, see the SDK documentation, section "Using
  59. the SDK with other boards".
  60. *** New features
  61. *****************
  62. ** Drivers and libraries **
  63. - nRF21540 Front-End Module support:
  64. - New driver supporting the nRF21540 RF front-end module
  65. can be found in '.\driver_ext\nrf21540\'
  66. - The DTM and Radio Test examples have been updated
  67. to include the nRF21540 driver (only GPIO control has been tested).
  68. - Workaround handling Errata 1 for nRF21540 is not included as part of
  69. the driver and must be applied separately.
  70. - Radio Test example:
  71. - Extended the 'start_tx_modulated_carrier' command with an additional
  72. option for setting the specific number of packets to transmit.
  73. - Added printing of the received packet statistics in the 'print_rx' command handler.
  74. - nrfx:
  75. - Updated version to 1.8.4.
  76. - Added support of the nRF52820 device.
  77. - Added new SAADC driver backported from nrfx 2.2.0 branch.
  78. - nrf_cc310:
  79. - Updated version to 0.9.13.
  80. - Bugfix release with new mechanism for enabling and disabling the hardware
  81. and for interrupt masking. See Migration Guide for details.
  82. - nrf_cc310_bl
  83. - Updated version to 0.9.13.
  84. - Bugfix release with new mechanism for interrupt masking.
  85. - nrf_oberon
  86. - Updated version to 3.0.5.
  87. - General version update supporting more nRF5 architectures.
  88. - Addition of header files for the mbedcrypto frontend.
  89. See Migration Guide for details.
  90. - USB: added support for nRF52820.
  91. *** Changes
  92. ***********
  93. ** Drivers and libraries **
  94. - Radio Test example: refactored to use the Radio HAL module (nrf_radio.h) functions.
  95. - nrfx: see the nrfx 1.8.4 changelog in modules/nrfx/CHANGELOG.md.
  96. ** Crypto **
  97. - nrf_cc310 library now automates enabling and disabling of CryptoCell hardware
  98. and interrupts. It is no longer done in nrf_crypto. See Migration Guide for details.
  99. ** NFC **
  100. - T4T: allowed dynamic R/W NDEF message buffer changing.
  101. Now you can change the NDEF buffer in any protocol state,
  102. without having to disable the T4T emulation.
  103. - T4T: added pointer to the NDEF message buffer for the 'NDEF Updated' event.
  104. ** Bluetooth Low Energy **
  105. - Scanning Module: removed the 'Scan Request' event
  106. that is irrelevant for the scanner role.
  107. - External Tile library: integrated a new library version.
  108. ** DTM **
  109. - Updated DTM to support the nRF52820 device.
  110. - Added new example targets:
  111. - pca10100e: for nRF52820 emulation on pca10100.
  112. - pca10112: a version for a development kit with the nRF52840 device
  113. and the nRF2140 front-end chip.
  114. *** Bug fixes
  115. ****************
  116. ** Drivers and libraries **
  117. - nrfx: see the nrfx 1.8.4 changelog in modules/nrfx/CHANGELOG.md.
  118. - Fixed a bug where FDS garbage collection ran on more pages than necessary,
  119. causing unnecessary flash wear.
  120. ** ANT **
  121. - ANT Shared Channels example (slave project): fixed array size check.
  122. ** NFC **
  123. - T4T: fixed detecting of the end of reading NDEF message procedure
  124. (NFC_T4T_EVENT_NDEF_READ).
  125. - T4T: fixed an issue where NDEF Read event was triggered even when
  126. NDEF Message was empty.
  127. ** Bluetooth Low Energy **
  128. - Fixed nrf_sd_def.h file contents in all SoftDevices
  129. (in some cases, the definitions in this file were outdated).
  130. - External Tile library: fixed a few minor issues.
  131. - Nordic UART Service: added a null-pointer check in the
  132. notification transmitted handler.
  133. - Fixed a vulnerability issue reported by IOActive where malformed
  134. advertising data could be used to attack a device that does scanning.
  135. The fix is included in ble_advdata_search() in ble_advdata.c where
  136. an extra check has been added to ensure that the length values specified
  137. within the advertising packet are within the boundary of the advertising packet.
  138. ** DFU **
  139. - SES will now return a linker error if the bootloader is too large.
  140. - Fixed a bug that caused SD+BL updates to fail if the SD had signature boot validation.
  141. - Fixed an error in the code that booted the app, which could happen
  142. with certain optimization settings.
  143. - Fixed a false positive assert that could sometimes happen after a reset
  144. during an upgrade.
  145. - Fixed a bug that caused compilation errors when building with a board with no buttons.
  146. ** DTM **
  147. - DTM reports regarding Max Octets are now correct for devices without long range support.
  148. ** USB **
  149. - Fixed issues and optimized app_usbd_string_desc.
  150. - Fixed issues in USB CLI backend when handling a port close.
  151. ** Proprietary **
  152. - Gazell: fixed an assertion that would be sometimes generated after
  153. a packet transmission.
  154. - ESB: fixed a bug in the nrf_esb_pop_tx function where packages would get sent anyway
  155. in certain situations.
  156. *** Known Issues
  157. ****************
  158. ** General **
  159. - The workaround for Anomaly 198 for nRF52840 SPIM3 peripheral
  160. that has been implemented in nrfx_spim cannot be used with a SoftDevice.
  161. Flag NRFX_SPIM3_NRF52840_ANOMALY_198_WORKAROUND_ENABLED must be set to zero.
  162. The workaround based on a dedicated RAM block for SPIM3 must be used instead.
  163. - usbd_msc example has a limitation.
  164. With setting "APP_USBD_CONFIG_EVENT_QUEUE_ENABLE = 0",
  165. when USB cable is unplugged and re-plugged, the application goes into an endless loop.
  166. This is due to an issue in the unsupported block device library.
  167. ** Bluetooth Low Energy **
  168. - GATTC: the ble_gattc_service_t::uuid field is incorrectly populated
  169. in the BLE_GATTC_EVT_PRIM_SRVC_DISC_RSP event if the
  170. sd_ble_gattc_primary_services_discover() or sd_ble_gattc_read()
  171. are called when a Primary Service Discovery by Service UUID is already ongoing.
  172. When the application has called sd_ble_gattc_primary_services_discover(),
  173. it should wait for the BLE_GATTC_EVT_PRIM_SRVC_DISC_RSP event before calling
  174. sd_ble_gattc_primary_services_discover() or sd_ble_gattc_read().
  175. - BLE Interactive CLI example: the command to set a custom ATT MTU only takes
  176. effect on the subsequent connection and the updated MTU parameter is not
  177. maintained in further connections with the same peer, even when bonded.
  178. - ANT Shared Channels example: when testing a Bluetooth Low Energy connection
  179. with an Android device, the link is terminated by Android due to unhandled LL requests.
  180. - Bluetooth ANCS example: when connected from iPhone and pressing DK buttons,
  181. the example may assert before the Bluetooth Low Energy link is authenticated.
  182. ** Crypto **
  183. - The nrf_crypto CLI example may fail when using an ECC private key converted
  184. from raw function for specific curve types.
  185. ** Drivers and libraries **
  186. - The SAADC driver (from nrfx 1.8.x) does not handle detection limits 'high' and 'low'
  187. correctly if SAADC resolution is greater than 10 bits.
  188. SAADC driver ported from nrfx 2.2.x is not affected by this.
  189. - USBD:
  190. - The library may handle Remote Wakeup incorrectly.
  191. - Issuing a SET_ADDRESS(0) request does not cause the device to change
  192. its state to default.
  193. - The device does not STALL when a DATA transaction is received outside of SETUP.
  194. It ACKs instead.
  195. - The following macros defined in boards.h work only with pins on port 0:
  196. - LEDS_OFF
  197. - LEDS_ON
  198. - LED_IS_ON
  199. - LEDS_INVERT
  200. - LEDS_CONFIGURE
  201. - The low_power_pwm library does not correctly initialize GPIOs
  202. that are placed on PORT1 in the low_power_pwm_init function.
  203. This indirectly affects the led_softblink library and can also affect
  204. the DFU open bootloader.
  205. ==============================
  206. nRF5 SDK v16.0.0
  207. ------------------------
  208. Release Date: October, 2019
  209. Highlights:
  210. - Added support for a new chip: nRF52833
  211. - Added support for new BLE SoftDevices version 7, as well as the new SoftDevice S113.
  212. - Added an external Tile BLE library and a corresponding example
  213. demonstrating the "find me" feature.
  214. - App Timer v2 is now out of experimental and replaces the legacy App Timer
  215. in all examples.
  216. The following toolchains/devices have been used for testing and verification:
  217. - ARM: MDK-ARM version 5.25
  218. - GCC: GCC ARM Embedded 7.2018q2.update
  219. - IAR: IAR Workbench 7.80.4
  220. - SES: SES 4.18
  221. *****
  222. Note for IAR 8 users:
  223. (Libraries for IAR 8 require wchar_t to be of size 32 bits while IAR 7 requires 16 bits).
  224. To run a project using IAR 8, follow these intructions:
  225. - Open the IAR project in IAR 8. The IAR workbench will automatically generate an IAR 8 compatible project file.
  226. - If the project contains one of the precompiled libraries listed below, replace it
  227. with the IAR 8 compatible alternative (there are no projects targeting nRF51 in this SDK).
  228. - Save the project.
  229. - When building the project, you might get the warning: "The header file 'cmsis_iar.h' is obsolete and should not be used. [...]".
  230. - The problem is described in DevZone post: https://devzone.nordicsemi.com/f/nordic-q-a/31123/iar-ewarm-8-22-1-complains-about-cmsis_iar-h
  231. The solution is to remove all occurrences of #include <cmsis_iar.h>.
  232. The affected libraries are:
  233. - micro-ecc crypto:
  234. - IAR7: Includes library located in the folder named “…_iar\…”.
  235. - IAR8: Switch to using the library from the folder named “…_armgcc\…”.
  236. - nrf_cc310, nrf_cc310_bl, and nrf_oberon:
  237. - IAR7: Link to a library where “short_wchar” is part of the folder name.
  238. - IAR8: Link to a library without “short_wchar” in part of the folder name.
  239. - Gazell, NFC Tag, and 802.15.4:
  240. - IAR7: Includes the library where the file name ends with “_iar”.
  241. - IAR8: Switch to using the library with similar file name that ends with “_gcc”.
  242. *****
  243. Supported SoftDevices:
  244. - S112 v7.x.x
  245. - S113 v7.x.x
  246. - S132 v7.x.x
  247. - S140 v7.x.x
  248. - S212 v6.1.x
  249. - S312 v6.1.x
  250. - S332 v6.1.x
  251. - S340 v6.1.x
  252. Supported boards:
  253. - PCA10040
  254. - PCA10040E (nRF52810 emulation on PCA10040)
  255. - PCA10056
  256. - PCA10056E (nRF52811 emulation on PCA10056)
  257. - PCA10100 (support in selected examples)
  258. - PCA10059 (support in selected examples)
  259. - D52DK1 from Garmin Canada (only for ANT examples)
  260. For other devices and boards, see the SDK documentation, section "Using
  261. the SDK with other boards".
  262. *** New features
  263. *****************
  264. ** Drivers and libraries **
  265. - nRF52833: added USB support - both USB device hardware driver and USB Device library.
  266. - Radio Test Example: added a project for nRF52833.
  267. ** BLE**
  268. - Added a new library GATT Queue which can be used for buffering GATT procedures when
  269. the SoftDevice cannot process them immediately. It can be used with, for example,
  270. Indications, Read or Write Requests etc. The queued procedure is automatically
  271. retried when events from the SoftDevice indicate that it can be processed.
  272. Most of the GATT Client libraries use this module.
  273. - Added support for the new SoftDevice S113 in selected BLE examples.
  274. - Improved Database Discovery Module design to enable multiple instances,
  275. for example to perform independent discovery on each connection.
  276. - BLE Interactive CLI Example: added discovery of 128-bit UUID Services and
  277. Characteristics at the first attempt.
  278. - Advertising Module: improved dynamic advertising data update, no additional buffer
  279. is needed now - swap buffer was introduced within the module implementation.
  280. - Added a new external BLE library: Tile, and a corresponding example: ble_app_tile.
  281. The project implements proprietary GATT services for demonstrating the
  282. "find me" feature.
  283. The integrated modules include source code as well as a precompiled linkable library.
  284. ** DFU **
  285. - Updated documentation with information on Secure Boot and platform architecture
  286. security.
  287. ** NFC **
  288. - Added support for new chip: nRF52833. Added corresponding projects in selected
  289. examples.
  290. ** USB **
  291. - APP_USBD_BCD_VER_MAKE macro now includes a sub-minor version parameter.
  292. - Feature reports functionality is now supported in HID generic class.
  293. ** Proprietary **
  294. - ESB: added support for the new chip nRF52833.
  295. - Gazell: added support for nRF52810 and nRF52811.
  296. ** DTM **
  297. - Updated Direct Test Mode to support nRF52833.
  298. *** Changes
  299. ***********
  300. ** Drivers and libraries **
  301. - app_timer: App Timer v2 moved out of experimental. It is updated and
  302. API-compatible with the old implementation making it easy to replace.
  303. All SDK examples using App Timer are updated to use the new version.
  304. - libuarte:
  305. - libuarte moved out of experimental.
  306. - nrf_libuarte renamed to nrf_libuarte_drv (file names and API).
  307. - Added option to use an app_timer instance for RX timeout instead of the TIMER or
  308. RTC peripheral.
  309. - nrf_cli: CLI now automatically adds an `\r` character before each printed `\n`
  310. character. This feature can be switched off in sdk_config with flag
  311. `NRF_FPRINTF_FLAG_AUTOMATIC_CR_ON_LF`.
  312. - FDS: FDS-specific error codes have been moved so their values do not overlap with
  313. other error codes.
  314. Also, NRF_SUCCESS is now used instead of FDS_SUCCESS.
  315. ** Crypto **
  316. - Updated OPTIGA Trust X library code and example.
  317. - Updated the nrf_oberon library version to 3.0.1, changing the API prefixes from
  318. occ_* to ocrypto_*.
  319. ** BLE **
  320. - Peer Manager:
  321. - Changed the pm_peer_data_* API to use uint32_t length variables instead of
  322. uint16_t.
  323. - The flash cleaning algorithm in peer_manager_handler now also runs garbage
  324. collection if other users of FDS have deleted data.
  325. - The fds_error member variable has been removed from PM events.
  326. - Added a LESC flag to pm_conn_sec_status_t.
  327. - Add a new function pm_sec_is_sufficient() where the security state of the
  328. connection is checked against a reference security state.
  329. - Function pm_sec_is_sufficient() is now used internally when responding
  330. to slave security requests.
  331. - pm_handler has been augmented with new event handlers based on
  332. pm_sec_is_sufficient().
  333. - Advertising Module: removed obsolete API.
  334. - ble_conn_state: Added a LESC flag to connection state (i.e. whether LESC was used
  335. for bonding/pairing). It can be false even if LESC was used.
  336. See Peer Manager for a completely accurate reporting of LESC.
  337. - BLE Central UART Example: added support for Windows-type line end characters.
  338. - Running Speed and Cadence Example: added handling of the Database Discovery Available
  339. event.
  340. - Heart Rate Example:
  341. - Changed default configuration for nRF52810 and nRF52811.
  342. - Service Change Characteristic disabled.
  343. - Disabled protection against repeated pairing attempts in Peer Manager.
  344. - FDS: Reduced number of virtual flash pages to use.
  345. ** DFU **
  346. - Bootloader start address is now placed in UICR at compile time, and the MBR page is
  347. populated at runtime. This is to mitigate problems with flashing
  348. where the MBR was erased.
  349. - The MBR folders have been merged into a single folder since the MBR is identical for
  350. all nRF52 variants.
  351. - The bootloader now disallows upgrading the SoftDevice to another family
  352. (e.g. s140 -> s113).
  353. - nrf_bootloader_app_start() can no longer be called from an interrupt handler.
  354. - BLE DFU: Disconnect link when aborting DFU (OP_ABORT).
  355. - The bootloader will now wait a configurable number of milliseconds before each chip
  356. reset. Configured with NRF_BL_RESET_DELAY_MS.
  357. - Added a configuration option for disabling a debug port: NRF_BL_DEBUG_PORT_DISABLE.
  358. - When the bootloader is compiled in a configuration where the app does not need access
  359. to the settings page, the page itself, not just the backup, is locked before booting
  360. the app.
  361. ** USB **
  362. - USB driver: all changes listed here:
  363. https://github.com/NordicSemiconductor/nrfx/blob/v1.8.0/CHANGELOG.md
  364. - USB libraries: APP_USBD_AUDIO_AC_IFACE_SUBTYPE_OUTPUT_TERNINAL
  365. has been renamed to APP_USBD_AUDIO_AC_IFACE_SUBTYPE_OUTPUT_TERMINAL.
  366. - bDescriptorSubType field in app_usbd_audio_ac_iface_header_desc_t struct
  367. has been renamed to bDescriptorSubtype.
  368. - bmRequest field in app_usbd_cdc_notify_t struct has been renamed to bRequest.
  369. - bmRequest field in app_usbd_setup_t struct has been renamed to bRequest.
  370. - New values have been added to app_usbd_msc_subclass_t and app_usbd_msc_req_t enums.
  371. - Terminal link in AS Interface Descriptor has been added as a parameter
  372. for the APP_USBD_AUDIO_GLOBAL_DEF macro.
  373. *** Bug fixes
  374. ****************
  375. ** Drivers and libraries **
  376. - FDS: fixed two bugs where a power loss at very specific times during garbage
  377. collection could corrupt the file system, making FDS unable to initialize and return
  378. FDS_ERR_NO_PAGES on initialization.
  379. - FDS: fixed a bug that prevented using the last word of a flash page to save a record.
  380. ** ANT **
  381. - Fixed a bug in ANT-FS Library, where incoming burst frames could be incorrectly
  382. handled due to wrong bitfield checking.
  383. ** NFC **
  384. - Fixed a bug where the Tag could respond to an ALL_REQ frame with incorrect timing when
  385. in the sleep state.
  386. This bug would occur after the Tag received an SLP_REQ frame and when an ALL_REQ frame
  387. was received shortly after - in a time shorter than what was configured
  388. in the NFCT FRAMEDELAYMAX register (in Type 4 Tag default configuration: 4.8 ms).
  389. ** BLE **
  390. - Eddystone: fixed bug for handling 0.625 unit in advertising interval.
  391. - Advertising Module: fixed a bug where a secondary PHY configuration might get
  392. overwritten.
  393. - Advertising Data Encoder: fixed a bug causing underflow of a return value
  394. of the parsing function when malformed data was provided as input.
  395. - Nordic UART Service: fixed a bug where incorrect Characteristic CCCD
  396. was checked on connection event.
  397. - Database Discovery: fixed counting of discovered services.
  398. - Fixed a bug where "available" events (indicating the module is ready
  399. for the next discovery process) were not triggered.
  400. - BLE Interactive CLI Example: fixed a bug where not all
  401. GATT Characteristics and Descriptors were discovered when a short ATT MTU was used.
  402. - Peer Manager:
  403. - Fixed a bug where peer ranks would not work after deleting all peers.
  404. - Fixed a bug where the indications for service changed would be dropped
  405. if they were sent at the same time as an MTU exchange.
  406. ** DFU **
  407. - Fixed a bug where resuming a DFU procedure with a disconnect (but no reset)
  408. in-between could leave the bootloader in a semi-locked state.
  409. - Fixed an issue where write protection of the application was not applied.
  410. *** Known Issues
  411. ****************
  412. ** General **
  413. - The workaround for Anomaly 198 for nRF52840 SPIM3 peripheral
  414. that has been implemented in nrfx_spim cannot be used with a SoftDevice.
  415. Flag NRFX_SPIM3_NRF52840_ANOMALY_198_WORKAROUND_ENABLED must be set to zero.
  416. The workaround based on a dedicated RAM block for SPIM3 must be used instead.
  417. ** BLE **
  418. - GATTC: the ble_gattc_service_t::uuid field is incorrectly populated
  419. in the BLE_GATTC_EVT_PRIM_SRVC_DISC_RSP event if the
  420. sd_ble_gattc_primary_services_discover() or sd_ble_gattc_read()
  421. are called when a Primary Service Discovery by Service UUID is already ongoing.
  422. When the application has called sd_ble_gattc_primary_services_discover(),
  423. it should wait for the BLE_GATTC_EVT_PRIM_SRVC_DISC_RSP event before calling
  424. sd_ble_gattc_primary_services_discover() or sd_ble_gattc_read().
  425. - The TFTP Background DFU example has known instabilities.
  426. - The Tile example disconnects when notifications in the Tile service are on
  427. and the application sends the first Battery Level notification.
  428. - BLE Interactive CLI example: the command to set a custom ATT MTU only takes
  429. effect on the subsequent connection and the updated MTU parameter is not
  430. maintained in further connections with the same peer, even when bonded.
  431. - ANT Shared Channels example: when testing BLE connection with an Android device,
  432. the link is terminated by Android due to unhandled LL requests.
  433. - Bluetooth ANCS example: when connected from iPhone and pressing DK buttons,
  434. the example may assert before the BLE link is authenticated.
  435. ** Crypto **
  436. - The nrf_crypto CLI example may fail when using ecc private key converted
  437. from raw function for specific curve types.
  438. ** Drivers and libraries **
  439. - The SAADC driver does not handle detection limits 'high' and 'low' correctly
  440. if SAADC resolution is greater than 10 bits.
  441. - USBD:
  442. - The library may handle Remote Wakeup incorrectly.
  443. - Issuing a SET_ADDRESS(0) request does not cause the device to change
  444. its state to default.
  445. - The device does not STALL when a DATA transaction is received outside of SETUP.
  446. It ACKs instead.
  447. ** IoT **
  448. - The MQTT example does not compile when run on PCA10040 with commissioning
  449. enabled (COMMISSIONING_ENABLED=1).
  450. - DTLS example: the server and the client application of the DTLS example should
  451. not be run on two kits. Instead, either the server or the client application
  452. should be run against the PC application as described in the documentation.
  453. ===========================================
  454. nRF5 SDK v15.3.0
  455. ------------------------
  456. Release Date: Week 7, 2019
  457. Highlights:
  458. - Added support for a new chip - nRF52811.
  459. - Added support for two new ANT SoftDevices: S312 targeting nRF52810 and nRF52832, and S340 targeting nRF52840.
  460. - Added back support for the ANT SoftDevice S332 v6.1.1, as well as updated the latest SoftDevices S112, S132, S140 and S212 v6.1.1.
  461. - Updated the SDFU solution with ANT transport layer.
  462. - Updated DTM to support nRF52811, and updated the existing code to correctly handle Anomaly 172.
  463. The following toolchains/devices have been used for testing and verification:
  464. - ARM: MDK-ARM version 5.25
  465. - GCC: GCC ARM Embedded 7.2018q2.update
  466. - IAR: IAR Workbench 7.80.4
  467. - SES: SES 4.12
  468. Note: The selected GCC version has shown instabilities when using the Link Time Optimization feature, and using the feature is not recommended.
  469. *****
  470. Note for IAR 8 users:
  471. (Libraries for IAR 8 require wchar_t to be of size 32 bits while IAR 7 requires 16 bits).
  472. To run a project using IAR 8, follow these intructions:
  473. - Open the IAR project in IAR 8. The IAR workbench will automatically generate an IAR 8 compatible project file.
  474. - If the project contains one of the precompiled libraries listed below, replace it with the IAR 8 compatible alternative
  475. (there are no projects targeting nRF51 in this SDK).
  476. - Save the project.
  477. - When building the project, you might get the warning: "The header file 'cmsis_iar.h' is obsolete and should not be used. [...]".
  478. - The problem is described in DevZone post: https://devzone.nordicsemi.com/f/nordic-q-a/31123/iar-ewarm-8-22-1-complains-about-cmsis_iar-h
  479. The solution is to remove all occurrences of #include <cmsis_iar.h>.
  480. The affected libraries are:
  481. - micro-ecc crypto:
  482. - IAR7: Includes library located in the folder named “…_iar\…”.
  483. - IAR8: Switch to using the library from the folder named “…_armgcc\…”.
  484. - nrf_cc310, nrf_cc310_bl, and nrf_oberon:
  485. - IAR7: Link to a library where “short_wchar” is part of the folder name.
  486. - IAR8: Link to a library without “short_wchar” in part of the folder name.
  487. - Gazell, NFC Tag, and 802.15.4:
  488. - IAR7: Includes the library where the file name ends with “_iar”.
  489. - IAR8: Switch to using the library with similar file name that ends with “_gcc”.
  490. *****
  491. Supported SoftDevices:
  492. - S112 v6.1.x
  493. - S132 v6.1.x
  494. - S140 v6.1.x
  495. - S212 v6.1.x
  496. - S312 v6.1.x
  497. - S332 v6.1.x
  498. - S340 v6.1.x
  499. Supported boards:
  500. - PCA10040
  501. - PCA10040E (nRF52810 emulation on PCA10040)
  502. - PCA10056
  503. - PCA10056E (nRF52811 emulation on PCA10056)
  504. - PCA10059 (support in selected examples)
  505. - D52DK1 from Garmin Canada (only for ANT examples)
  506. For other devices and boards, see the SDK documentation, section "Using
  507. the SDK with other boards".
  508. *** New features
  509. *****************
  510. ** ANT **
  511. - Added the new ANT Secure DFU Bootloader example.
  512. The example demonstrates how to use the new ANT transport with Secure DFU components
  513. (with support only for SES and GCC toolchains).
  514. - Removed legacy ANT bootloader solution.
  515. ** Drivers and libraries **
  516. - nrf_cli can now prompt and autocomplete both sorted and unsorted subcommands.
  517. - nrf_libuarte and nrf_libuarte_async now support multiple instances.
  518. ** BLE**
  519. - nrf_ble_lesc (part of the Peer Manager) now supports the LESC OOB pairing mode.
  520. The ble_nfc_pairing_reference_c example demonstrates how to pass the OOB data to the module.
  521. ** DFU **
  522. - Added the option to perform signature validation of the application on each boot.
  523. This functionality requires nrfutil version 5.0.0 or higher.
  524. - The DFU procedure can now mandate strictly increasing application versions.
  525. - Added the option to send applications that will not be activated, but will remain in slot 1 ("external applications").
  526. This functionality requires nrfutil version 5.0.0 or higher.
  527. - Added masking of GPREGRET and GPREGRET2 registers, enabling the upper 3 bytes of each register to be used by the application independently of the bootloader.
  528. ** Crypto **
  529. - Added nrf_crypto backend support for Infineon OPTIGA™ Trust X devices (selected features).
  530. - Added new example to showcase Infineon OPTIGA Trust X functionality: examples/crypto/ifx_optiga_custom_example.
  531. *** Changes
  532. ************
  533. ** DFU **
  534. - Turned off Link Time Optimization in all DFU projects due to instabilities in the supported GCC compiler.
  535. ** Drivers and libraries **
  536. - nrf_cli: CLI will now automatically add the `\r` character before each printed `\n` character.
  537. This feature can be switched off in sdk_config using flag `NRF_FPRINTF_FLAG_AUTOMATIC_CR_ON_LF`.
  538. - USB: A complete list of changes is available under this link: https://github.com/NordicSemiconductor/nrfx/blob/a0dcb1350f6798f12479921a0a376d00e2316fd4/CHANGELOG.md
  539. ** NFC **
  540. - The NFC libraries (nfc_t2t_lib and nfc_t4t_lib) now use the NFCT driver instead of the NFC HAL modules (hal_nfc_t2t and hal_nfc_t4t).
  541. The NFCT driver is a part of nrfx repository.
  542. - Replaced hal_nfc_t2t and hal_nfc_t4t components with the nrfx_nfct driver.
  543. - Added the NFC platform module (nfc_platform) to abstract runtime environment specific implementation from the driver.
  544. HFCLK activation, required for NFC to operate correctly, is managed in this module.
  545. - Removed the nfc_fixes.h file with NFC workaround description. The content of this file was moved to nrfx_nfct.h.
  546. ** Crypto **
  547. - nrf_oberon, nrf_cc310, and nrf_cc310_bl libraries have changed naming and placement compared to the previous release.
  548. They are now available in the following folder scheme:
  549. - GCC and IAR 8.x: lib/<arch>/hard-float/<lib_name>.a
  550. - IAR 7.80.x: lib/<arch>/hard-float/short-wchar/<lib_name>.a
  551. - Keil: lib/<arch>/hard-float/short-wchar/<lib_name>.lib
  552. Due to this naming convention change, updated nrf_cc310 and nrf_cc310_bl library version to 0.9.12.
  553. Due to this naming convention change, updated nrf_oberon library version to 2.0.7.
  554. - Changed ECC Public Key Validation from "Full" to "Partial" in nrf_crypto backend for ARM CC310.
  555. This improves LESC pairing and ECDSA verify timing.
  556. *** Bug fixes
  557. ****************
  558. ** Drivers and libraries **
  559. - nrf_cli: The module can now be used with terminals with no standard background color (for example, white).
  560. - USB: Fixed a bug where USB IRQ was not cleared after unplugging the USB cable.
  561. - Fixed an issue where NRF_LOG_INIT(timestamp, frequency) failed to compile if the logger was disabled.
  562. - Fixed a compilation failure issue when using NRF_LOG_HEXDUMP_WARNING.
  563. - Fixed a scenario where the emulated project delay function (nrfx_coredep_delay_us) did not work correctly.
  564. ** BLE **
  565. - Peer Manager:
  566. - Slave Security Requests received during a pairing or encryption procedure will now be ignored (to align with the BLE specification).
  567. - Fixed a bug where Peer Manager would misinterpret a peer central's ability to resolve resolvable addresses in directed advertisements.
  568. - Fixed a bug where Peer Manager would sometimes give a fatal error if the link disconnected during a pairing procedure.
  569. - Fixed a bug where flash could be full but no Peer Manager event was sent.
  570. - Fixed a bug where Peer Manager would silently drop Service Changed indications if an ATT MTU exchange was happening at the same time.
  571. - Eddystone:
  572. - Fixed a bug where EID was not correctly updated.
  573. - Fixed bug where factory reset would not work correctly when followed by an immediate disconnect.
  574. ** DFU **
  575. - Various security improvements and fixes.
  576. - Fixed various bugs in background DFU.
  577. - Fixed bugs that appeared when combining transports (for example, UART + BLE).
  578. ** DTM **
  579. - Fixed a bug which made the workaround for nRF52840 Anomaly 172 non-functional.
  580. ** Serialization **
  581. - Fixed an issue with HCI transport sending redundant bytes on certain packet payloads containing escape codes.
  582. - Fixes in serialization codecs.
  583. *** Known Issues
  584. ****************
  585. ** General **
  586. - Programming and debugging the nRF52811 chip may require an update of the J-Link firmware in order to recognize the new chip.
  587. - The workaround for Anomaly 198 for nRF52840 SPIM3 peripheral that has been implemented in nrfx_spim cannot be used with a SoftDevice.
  588. Flag NRFX_SPIM3_NRF52840_ANOMALY_198_WORKAROUND_ENABLED must be set to zero.
  589. The workaround based on a dedicated RAM block for SPIM3 must be used instead.
  590. ** BLE **
  591. - GATTC: the ble_gattc_service_t::uuid field is incorrectly populated in the BLE_GATTC_EVT_PRIM_SRVC_DISC_RSP event
  592. if the sd_ble_gattc_primary_services_discover() or sd_ble_gattc_read() are called when a Primary Service Discovery by Service UUID is already ongoing.
  593. When the application has called sd_ble_gattc_primary_services_discover(), it should wait for the BLE_GATTC_EVT_PRIM_SRVC_DISC_RSP event before calling sd_ble_gattc_primary_services_discover() or sd_ble_gattc_read().
  594. - The TFTP Background DFU example has known instabilities.
  595. ** Drivers and libraries **
  596. - The SAADC driver does not handle detection limits 'high' and 'low' correctly if SAADC resolution is greater than 10 bits.
  597. - USBD:
  598. - The library may handle Remote Wakeup incorrectly.
  599. - Issuing a SET_ADDRESS(0) request does not cause the device to change its state to default.
  600. - The device does not STALL when a DATA transaction is received outside of SETUP. It ACKs instead.
  601. ** IoT **
  602. - For Linux kernels >= 4.12, The BLE_6LOWPAN_LEGACY_MODE configuration parameter must be set to 0 (the default is 1).
  603. The default value must be kept for Linux kernels < 4.12.
  604. With this configuration set up incorrectly, the examples do not work and are difficult to debug.
  605. ======================================================================
  606. nRF5 SDK v15.2.0
  607. ------------------------
  608. Release Date: Week 37, 2018
  609. This SDK release is an update replacing the non-published nRF5 SDK release v15.1.0.
  610. The main updates compared to v15.1.0 are summarized in the last three points of the Highlights section.
  611. Highlights:
  612. - Added support for the new SoftDevices S140, S132, and S112 v6.1.0.
  613. - Added new targets for running S112 on nRF52832 (PCA10040).
  614. - Updated ESB library to support all nRF52 devices (nRF52810, nRF52832 (Rev.1 & Rev.2), and nRF52840).
  615. - Updated SDFU to include nRF52810 target (PCA10040E).
  616. - Released nrf_log in production quality.
  617. - Removed the workaround in nrf_sdh.c overriding the default priority level on SWI interrupt SD_EVT_IRQn and RADIO_NOTIFICATION_IRQn used by the SoftDevice.
  618. - Changed the default interrupt priority level for the peripherals from 7 to 6. This is done to be aligned with the priority of the SWI coming from the SoftDevice.
  619. - Fixed an interoperability issue with some Windows 10 versions when bonded and using directed advertising.
  620. Note: Due to compatibility issues, you must run the upgrade using nRF Connect Desktop v2.5.0 or later when testing the Bluetooth examples in nRF5 SDK v15.2.0.
  621. The following toolchains/devices have been used for testing and verification:
  622. - ARM: MDK-ARM version 5.18a
  623. - GCC: GCC ARM Embedded 6.3 2017-q2-update
  624. - IAR: IAR Workbench 7.80.4 (IAR 8 - see note below)
  625. - SES: SES 3.40
  626. *****
  627. Note for IAR 8 users:
  628. (Libraries for IAR 8 require wchar_t to be of size 32 bits while IAR 7 requires 16 bits).
  629. To run a project using IAR 8, follow these intructions:
  630. - Open the IAR project in IAR 8. The IAR workbench will automatically generate an IAR 8 compatible project file.
  631. - If the project contains one of the precompiled libraries listed below, replace it with the IAR 8 compatible alternative
  632. (there are no projects targeting nRF51 in this SDK).
  633. - Save the project.
  634. - When building the project, you might get the warning: "The header file 'cmsis_iar.h' is obsolete and should not be used. [...]".
  635. - The problem is described in DevZone post: https://devzone.nordicsemi.com/f/nordic-q-a/31123/iar-ewarm-8-22-1-complains-about-cmsis_iar-h
  636. The solution is to remove all occurrences of #include <cmsis_iar.h>.
  637. The affected libraries are:
  638. - micro-ecc crypto:
  639. - IAR7: Includes library located in the folder named “…_iar\…”.
  640. - IAR8: Switch to using the library from the folder named “…_armgcc\…”.
  641. - nrf_cc310, nrf_cc310_bl, and nrf_oberon:
  642. - IAR7: Includes the library where “_short_wchar_” is part of the file name.
  643. - IAR8: Switch to using the library with similar naming, but where the “short_wchar” is removed.
  644. - Gazell, NFC Tag, and 802.15.4:
  645. - IAR7: Includes the library where the file name ends with “_iar”.
  646. - IAR8: Switch to using the library with similar file name that ends with “_gcc”.
  647. *****
  648. Supported SoftDevices:
  649. - S112 v6.1.x
  650. - S132 v6.1.x
  651. - S140 v6.1.x
  652. - S212 v5.0.x
  653. Supported boards:
  654. - PCA10040
  655. - PCA10040E (nRF52810 emulation on PCA10040)
  656. - PCA10056
  657. - PCA10059 (support in selected examples)
  658. - D52DK1 from Garmin Canada (only for ANT examples)
  659. For other devices and boards, see the SDK documentation, section "Using
  660. the SDK with other boards".
  661. *** New features
  662. *****************
  663. ** BLE **
  664. - Added new targets to demonstrate the use of S112 on nRF52832 (PCA10040).
  665. - Added "Property Read" for the Object Transfer Service client (ble_app_ots_c).
  666. - Added a Scanning Module to simplify scanning for BLE devices in central role.
  667. - Peer Manager:
  668. - peer_manager_handler.h: There are now standard event handlers available to users of the Peer Manager.
  669. The event handlers provide features like logging, automatically securing the link, and automatically
  670. deleting the oldest bond if the flash is full.
  671. - PM_RA_PROTECTION_ENABLED: The Peer Manager can now be configured to reject repeated security requests
  672. from peers that failed pairing.
  673. - PM_LESC_ENABLED: Improved LESC support.
  674. - PM_LOG_ENABLED: Added error and warning level logging messages to the Peer Manager.
  675. - PM_EVT_FLASH_GARBAGE_COLLECTION_FAILED: Added new event.
  676. - PM_PEER_DATA_ID_CENTRAL_ADDR_RES: Added automatic storing of the peer's Central Address Resolution value during bonding.
  677. - pm_peer_id_list(): Added a new function for creating lists of Peer IDs, including some filtering.
  678. - Added LESC support to the following examples: ble_app_hrs, ble_app_hrs_c, and ble_app_gls.
  679. - Added support for nRF52840 (PCA10056) in the beacon example (ble_app_beacon).
  680. - Added Swift Pair support to the HID mouse example (ble_app_hids_mouse).
  681. - Battery Service: Added the possibility to notify a reconnected, bonded peer of an updated battery level.
  682. This feature is demonstrated in the Immediate Alert Server example.
  683. ** Crypto **
  684. - EdDSA: Added support for Edwards-curve Digital Signature Algorithm (Ed25519).
  685. - In documentation, added a table showing supported nrf_crypto backends for different examples:
  686. http://infocenter.nordicsemi.com/topic/com.nordic.infocenter.sdk5.v15.2.0/nrf_crypto_default_backends.html
  687. ** DFU/Bootloader **
  688. - Added a new target to the SDFU example to demonstrate SDFU running on nRF52810 (PCA10040E). In a single bank update, there is only
  689. about 60 kB of flash available. This restricts what can be updated.
  690. - The bootloader settings page is now backed up before being updated. This increases protection from corruption caused by chance events
  691. (for example, power failure) and malicious apps.
  692. - The advertising interval of BLE DFU can now be configured in sdk_config (NRF_DFU_BLE_ADV_INTERVAL).
  693. - The size of the application data area that is left alone by the bootloader can now be configured
  694. in sdk_config (NRF_DFU_APP_DATA_AREA_SIZE).
  695. - The bootloader code now supports most of nrf_crypto backends. However, the size of the binary will likely be too large if other backends
  696. are used, so you will need to accomodate by increasing the size of the bootloader.
  697. ** USB **
  698. - Added response/no response to an IN token on ISO IN endpoint with a ZLP when no data is ready. This can be set with USBD_CONFIG_ISO_IN_ZLP.
  699. - Added support for configuration string ID.
  700. - Added an option to give priority to isochronous transfers using USBD_CONFIG_DMASCHEDULER_ISO_BOOST.
  701. - Implemented SOF event callback in interrupt for classes.
  702. - Added an enum and get function for a selected protocol (boot or report) in HID. Implemented a SET_PROTOCOL propagation mechanism using
  703. on_set_protocol methods. Buffers can now be cleared after the SET_PROTOCOL command using clear_buffer methods.
  704. - Redesigned the idle report mechanism in HID. It now allows a callback function and handles multiple report IDs.
  705. - Added an option to send a ZLP on write with the same size as the endpoint in CDC ACM class using APP_USBD_CDC_ACM_ZLP_ON_EPSIZE_WRITE.
  706. - Implemented macros to set interval for individual endpoints. See APP_USBD_EP_WITH_INTERVAL.
  707. - Transfers in Audio class can now be started in SOF interrupt set in the app_usbd_audio_sof_interrupt_register function.
  708. *** Changes
  709. ************
  710. ** BLE **
  711. - Increased the length of the advertising name for the Running Speed and Cadence sensor example (ble_app_rscs) to make it easy to verify
  712. that it is using the extended advertising.
  713. - Included the Scanning module into all BLE examples. This aligns how scanning is performed in these examples.
  714. - Updated the NFC pairing examples (ble_app_hids_keyboard_pairing_nfc, ble_app_hrs_nfc_pairing, ble_nfc_pairing_reference) to start using
  715. the LESC functionality in the Peer Manager (which uses the nrf_ble_lesc module).
  716. - Removed the manual handling of credits for the Object Transfer Service (ble_app_ots and ble_app_ots_c). Most use cases now work faster
  717. and simpler when the SoftDevice is controlling it.
  718. - Updated the API documentation for advertising_init in the Advertising module (ble_advertising). It was clarified that UUID arrays were not
  719. copied into the Advertising module.
  720. - Advertising module (ble_advertising) is no longer dependent on the fstorage module.
  721. - Changed the ANCS example (ble_app_ancs_c) so that it no longer performs service discovery after connecting to an already bonded peer.
  722. - Lowered the advertising interval in the Eddystone example (ble_app_eddystone), because some advertising packets would be lost when combined
  723. with the timeslot API.
  724. - Reduced the maximum supported value for advertising interval in Eddystone from 20000 to 16384. If a higher value is set, the SoftDevice returns
  725. an error code that asserts the application.
  726. - Peer Manager:
  727. - Various improvements to documentation.
  728. - The Peer Manager will now take less space for the same features.
  729. - To decrease complexity, the Peer Manager no longer uses the 'reserve' functionality in FDS, meaning that PM_EVT_STORAGE_FULL
  730. events will come slightly later if bonds cannot be stored during bonding.
  731. - Error event parameters now specify whether the error code is to be interpreted as an FDS_ error or an NRF_ error.
  732. - Peers without a stored rank are now never returned from pm_peer_ranks_get().
  733. - The function pm_peer_data_load() now fills the array even when returning NRF_ERROR_DATA_SIZE.
  734. - Enabled internal LESC key handling through PM_LESC_ENABLED. Function pm_lesc_public_key_set() is now deprecated because of this change.
  735. - All examples using the Peer Manager now use the new standard event handlers.
  736. While some examples implement custom behavior, all examples do the following:
  737. - Log Peer Manager events (at different log levels).
  738. - Encrypt immediately on connection with bonded peers.
  739. - Delete old bonds to make room for new peer data.
  740. - Some examples supporting central mode disconnect when link encryption fails. Look for functions calling pm_handler_disconnect_on_sec_failure().
  741. - The ble_app_bms example will now request for security procedure to be initiated if the Central does not initiate it.
  742. - Updated examples with directed advertisement to take into account Central Address Resolution value.
  743. ** IEEE 802.15.4 **
  744. - Updated the radio test example to support 802.15.4 radio modes.
  745. ** Crypto **
  746. - Updated documentation about RAM requirements on mbed TLS.
  747. - Added endianness change Curve25519 (to little endian).
  748. - Removed the following defines. A compile error is shown if they are enabled in a configuration:
  749. - NRF_CRYPTO_BACKEND_CC310_BL_HASH_LITTLE_ENDIAN_DIGEST_ENABLED
  750. - NRF_CRYPTO_BACKEND_CC310_BL_ECC_LITTLE_ENDIAN_ENABLED
  751. - NRF_CRYPTO_BACKEND_MICRO_ECC_LITTLE_ENDIAN_ENABLED
  752. - NRF_CRYPTO_BACKEND_NRF_SW_HASH_LITTLE_ENDIAN_DIGEST_ENABLED
  753. - nrf_crypto micro-ecc backend: Moved ECDH public key validation from the key convert function to ECDH compute
  754. (moved from nrf_crypto_backend_micro_ecc_public_key_from_raw to nrf_crypto_backend_micro_ecc_ecdh_compute).
  755. - Upgraded nrf_cc310 and nrf_cc310_bl to version 0.9.10 including minor changes to some default configurations.
  756. - Removed micro-ecc library/mbed TLS from BLE LESC examples for better user experience.
  757. - micro-ecc library prevented a working compilation in a fresh LESC example (requires external download).
  758. - mbed TLS significantly increases compilation time in the project, even if it is not configured as the enabled nrf_crypto backend.
  759. ** DFU and Bootloader **
  760. - Updated documentation about how to change the existing SDFU project, so that the application can be uploaded without signature verification,
  761. but at the same time to keep the signature verification when updating a SoftDevice and/or bootloader.
  762. - The bootloader now does not use app_timer, which saves flash space.
  763. - The bootloader now does the endian-conversion in code, instead of relying on endian-conversion in nrf_crypto.
  764. ** Drivers and libraries **
  765. - Changed the peripherals' default interrupt priority level from 7 to 6.
  766. - Included new version of nrfx (v1.1.0). For the nrfx changelog, see https://github.com/NordicSemiconductor/nrfx/blob/master/CHANGELOG.md
  767. - nrf_log:
  768. - Updated to production quality.
  769. - You can now store/load the filtering configuration in FDS.
  770. - You can now control one backend from another.
  771. - nrf_cli: Added support for terminal meta keys.
  772. ** Proprietary **
  773. - Updated ESB library to support all current variants of nRF52. This mainly involves adding proper handling of Errata related to the radio.
  774. - Added a function to skip the next packet in the TX queue. This was previously a function used internally in the module under another name.
  775. ** USB **
  776. - Moved USBD strings configuration to sdk_config.
  777. - Rebuilt MSC class write procedure.
  778. - Moved APP_USBD_CONFIG_LOG_ENABLED to nrf_log settings.
  779. - HID report protocol is now default after reset.
  780. - HID default idle rate after reset can now be defined.
  781. - OUT transfers are now dropped when clearing stall on endpoint.
  782. - SET_ADDRESS command is now defined as a separate event in app_usbd. It does not change the state of the device anymore.
  783. - EP0 is now disabled until USB RESET condition is detected.
  784. - HID OUT reports are now limited to 63 bytes of data + 1 byte reserved for report ID.
  785. *** Bug fixes
  786. ****************
  787. ** BLE **
  788. - Fixed a bug in the BLE UART client (ble_app_uart_c) where it would check the wrong error code when issuing multiple write commands.
  789. - Fixed a bug in the ANCS example (ble_app_ancs) where app_timer was included too many times.
  790. - Fixed a bug in the Advertising module (ble_advertising) where a comment referred to seconds instead of 10 ms.
  791. - Fixed a bug in the LESC connection example (ble_app_multirole_lesc) where the procedure for connection parameter update would not be started
  792. immediately upon connection.
  793. - Fixed a bug where a precompiled hex was missing for Immediate Alert Server (ble_app_ias) and Service Changed server (ble_app_gatts) examples.
  794. - Fixed a bug in the Radio Notification Event Handler (ble_radio_notification) where a missing include stopped it from compiling.
  795. - Fixed a bug in the BLE Interactive Command Line Interface Example in service discovery procedure.
  796. - Fixed a bug in the Alert Notification Service, where it was not possible to enable notifications for an unread alert.
  797. - Peer Manager:
  798. - Fixed a bug where the event PM_EVT_FLASH_GARBAGE_COLLECTED was also sent when garbage collection failed.
  799. - Fixed a bug in pm_next_peer_id_get() where it could report a peer with no data attached to it if used during bonding.
  800. - Fixed a bug where peer data would not be written because the internal retry mechanism failed after two attempts.
  801. - Fixed a bug where pairing (no bonding) could happen with an already bonded peer without triggering a PM_EVT_CONN_SEC_CONFIG_REQ event.
  802. - Fixed several documentation bugs related to error codes.
  803. - Eddystone:
  804. - Fixed a bug where the default TX power was set to 0 instead of using the DEFAULT_FRAME_TX_POWER define.
  805. - Fixed a bug where an invalid reference of a variable could cause incorrect data to be sent.
  806. ** IEEE 802.15.4 **
  807. - Adjusted CCA threshold value to be correct for nRF52840 Rev. 1 (different from what was available on the Engineering sample).
  808. - Implemented a fix for Anomaly 153 (temperature correction of RSSI measurement): added an API in RAL module for calculating the corrected RSSI value.
  809. ** Drivers and libraries **
  810. - Fixed a bug in the SPI manager where app_timer was included too many times.
  811. - Fixed a wrapping issue in the Ring Buffer library.
  812. ** DFU/Bootloader **
  813. - Fixed a bug where the watchdog feeding in the bootloader did not happen during a certain FW activation.
  814. ** DTM **
  815. - Added support for 8 dB on nRF52840 targets.
  816. - Implemented the workaround for nRF52840 Anomaly 172 which caused the device to fail a test with interference in co-channels (RF-PHY/RCV/BV-29-C).
  817. ** Proprietary **
  818. - Fixed a bug in bytewise_bit_swap where it was harder to backport the implementation to nRF51.
  819. - Fixed a bug in nrf_esb_pop_tx where the packet queue would occasionally be corrupted.
  820. - Added shutdown of the system timer as the workaround for Anomaly 78 and to save energy.
  821. ** NFC **
  822. - Integrated fixes from EMVCo test suite (improved interoperability).
  823. - Added automatic fix for Anomaly 181.
  824. - Fixed a bug where HFCLK was requested too early for nRF52840 Rev. 1 chip.
  825. - Changed the way the fixes for chip errata are switched: use chip defines from MDK instead of board defines (simplifying usage of custom boards).
  826. ** USB **
  827. - Removed redundant barriers in USBD HAL.
  828. - Fixed a bug in HID library where the report descriptor was limited to 64 bytes.
  829. - Fixed a bug where USBD was not able to wake up after SOF event.
  830. - Fixed a bug where the SET_ADDRESS command was not processed in time.
  831. - USB application library (stack) now properly supports a situation when the HOST requests a descriptor but sets wLength Setup field to 0.
  832. *** Known Issues
  833. ****************
  834. ** BLE **
  835. - Peer Manager:
  836. - When a link is already secured and the peer sends a slave security request for a higher level of security, the request will not be honored.
  837. - Service Changed indications might be silently dropped without being sent if the attempt to send them happens during an ATT MTU exchange.
  838. - Service Changed indications might be silently dropped if the flash is full when the Service Changed flag is being stored in flash.
  839. ** BLE IOT **
  840. - Neighbor discovery module for lwIP requires the on-link flag in the router advertisement to be set to create a SLAAC address from the prefix.
  841. However, RFC 7668 (https://tools.ietf.org/html/rfc7668) requires this bit to be zero. Therefore, the nd6.c from lwIP source has been modified
  842. to relax this check.
  843. - There are some issues when using the IoT examples against Linux Kernel 4.12+ that cause the kernel to only work with one 6LoWPAN connection.
  844. If more than one kit is connected using 6LoWPAN, none of the nodes will be accessible.
  845. - Scheduler has been included in most IoT examples to avoid race conditions found when using the lwIP stack, more precisely the TCP examples.
  846. The issue was that the TCP client would stop working after about 15 hours. However, when using mbed TLS, the use of scheduler is not possible.
  847. Therefore, the MQTT client examples might be affected by this issue.
  848. - The use of security, both with TLS and DTLS, should be treated as experimental.
  849. - MQTT examples cannot be used with commissioning on nRF52832. There is not enough RAM to accommodate both TLS and the commissioning service.
  850. - If enabled, RTT logs in IoT bootloader might not be printed before resetting.
  851. - The background_dfu example does not work.
  852. ** Drivers and libraries **
  853. - SAADC driver is not handling detection limits: high and low correctly if SAADC resolution is greater than 10 bits.
  854. - In the radio test example, modulated packets will only have the requested content in the first two bytes.
  855. Further bytes have random values.
  856. - In the radio test example, start_duty_cycle_modulated_tx is not working as intended.
  857. The actual duty cycle on air is not what was requested in the command.
  858. ** USBD **
  859. - Due to Anomaly 199, the USBD driver blocks code execution during EasyDMA transfer (for stability).
  860. - USBD BLE UART FreeRTOS example is not working when combined with Nordic UART Service Client example.
  861. ========================================================================
  862. nRF5 SDK v15.1.0
  863. ------------------------
  864. Release Date: Week 34, 2018
  865. Highlights:
  866. - Added support for the new SoftDevices S140, S132, and S112 v6.1.0.
  867. - Added new targets for running S112 on nRF52832 (PCA10040).
  868. - Updated ESB library to support all nRF52 devices (nRF52810, nRF52832 (Rev.1 & Rev.2), and nRF52840).
  869. - Updated SDFU to include nRF52810 target (PCA10040E).
  870. - Released nrf_log in production quality.
  871. Note: Due to compatibility issues, you must run the upgrade using nRF Connect Desktop v2.5.0 or later when testing the Bluetooth examples in nRF5 SDK v15.1.0.
  872. The following toolchains/devices have been used for testing and verification:
  873. - ARM: MDK-ARM version 5.18a
  874. - GCC: GCC ARM Embedded 6.3 2017-q2-update
  875. - IAR: IAR Workbench 7.80.4 (IAR 8 - see note below)
  876. - SES: SES 3.40
  877. *****
  878. Note for IAR 8 users:
  879. (Libraries for IAR 8 require wchar_t to be of size 32 bits while IAR 7 requires 16 bits).
  880. To run a project using IAR 8, follow these intructions:
  881. - Open the IAR project in IAR 8. The IAR workbench will automatically generate an IAR 8 compatible project file.
  882. - If the project contains one of the precompiled libraries listed below, replace it with the IAR 8 compatible alternative
  883. (there are no projects targeting nRF51 in this SDK).
  884. - Save the project.
  885. - When building the project, you might get the warning: "The header file 'cmsis_iar.h' is obsolete and should not be used. [...]".
  886. - The problem is described in DevZone post: https://devzone.nordicsemi.com/f/nordic-q-a/31123/iar-ewarm-8-22-1-complains-about-cmsis_iar-h
  887. The solution is to remove all occurrences of #include <cmsis_iar.h>.
  888. The affected libraries are:
  889. - micro-ecc crypto:
  890. - IAR7: Includes library located in the folder named “…_iar\…”.
  891. - IAR8: Switch to using the library from the folder named “…_armgcc\…”.
  892. - nrf_cc310, nrf_cc310_bl, and nrf_oberon:
  893. - IAR7: Includes the library where “_short_wchar_” is part of the file name.
  894. - IAR8: Switch to using the library with similar naming, but where the “short_wchar” is removed.
  895. - Gazell, NFC Tag, and 802.15.4:
  896. - IAR7: Includes the library where the file name ends with “_iar”.
  897. - IAR8: Switch to using the library with similar file name that ends with “_gcc”.
  898. *****
  899. Supported SoftDevices:
  900. - S112 v6.1.x
  901. - S132 v6.1.x
  902. - S140 v6.1.x
  903. - S212 v5.0.x
  904. Supported boards:
  905. - PCA10040
  906. - PCA10040E (nRF52810 emulation on PCA10040)
  907. - PCA10056
  908. - PCA10059 (support in selected examples)
  909. - D52DK1 from Garmin Canada (only for ANT examples)
  910. For other devices and boards, see the SDK documentation, section "Using
  911. the SDK with other boards".
  912. *** New features
  913. *****************
  914. ** BLE **
  915. - Added new targets to demonstrate the use of S112 on nRF52832 (PCA10040).
  916. - Added "Property Read" for the Object Transfer Service client (ble_app_ots_c).
  917. - Added a Scanning Module to simplify scanning for BLE devices in central role.
  918. - Peer Manager:
  919. - peer_manager_handler.h: There are now standard event handlers available to users of the Peer Manager.
  920. The event handlers provide features like logging, automatically securing the link, and automatically
  921. deleting the oldest bond if the flash is full.
  922. - PM_RA_PROTECTION_ENABLED: The Peer Manager can now be configured to reject repeated security requests
  923. from peers that failed pairing.
  924. - PM_LESC_ENABLED: Improved LESC support.
  925. - PM_LOG_ENABLED: Added error and warning level logging messages to the Peer Manager.
  926. - PM_EVT_FLASH_GARBAGE_COLLECTION_FAILED: Added new event.
  927. - Added LESC support to the following examples: ble_app_hrs, ble_app_hrs_c, and ble_app_gls.
  928. - Added support for nRF52840 (PCA10056) in the beacon example (ble_app_beacon).
  929. - Added Swift Pair support to the HID mouse example (ble_app_hids_mouse).
  930. - Battery Service: Added the possibility to notify a reconnected, bonded peer of an updated battery level.
  931. This feature is demonstrated in the Immediate Alert Server example.
  932. ** Crypto **
  933. - EdDSA: Added support for Edwards-curve Digital Signature Algorithm (Ed25519).
  934. - In documentation, added a table showing supported nrf_crypto backends for different examples:
  935. http://infocenter.nordicsemi.com/topic/com.nordic.infocenter.sdk5.v15.1.0/nrf_crypto_default_backends.html
  936. ** DFU/Bootloader **
  937. - Added a new target to the SDFU example to demonstrate SDFU running on nRF52810 (PCA10040E). In a single bank update, there is only
  938. about 60 kB of flash available. This restricts what can be updated.
  939. - The bootloader settings page is now backed up before being updated. This increases protection from corruption caused by chance events
  940. (for example, power failure) and malicious apps.
  941. - The advertising interval of BLE DFU can now be configured in sdk_config (NRF_DFU_BLE_ADV_INTERVAL).
  942. - The size of the application data area that is left alone by the bootloader can now be configured
  943. in sdk_config (NRF_DFU_APP_DATA_AREA_SIZE).
  944. - The bootloader code now supports most of nrf_crypto backends. However, the size of the binary will likely be too large if other backends
  945. are used, so you will need to accomodate by increasing the size of the bootloader.
  946. ** USB **
  947. - Added response/no response to an IN token on ISO IN endpoint with a ZLP when no data is ready. This can be set with USBD_CONFIG_ISO_IN_ZLP.
  948. - Added support for configuration string ID.
  949. - Added an option to give priority to isochronous transfers using USBD_CONFIG_DMASCHEDULER_ISO_BOOST.
  950. - Implemented SOF event callback in interrupt for classes.
  951. - Added an enum and get function for a selected protocol (boot or report) in HID. Implemented a SET_PROTOCOL propagation mechanism using
  952. on_set_protocol methods. Buffers can now be cleared after the SET_PROTOCOL command using clear_buffer methods.
  953. - Redesigned the idle report mechanism in HID. It now allows a callback function and handles multiple report IDs.
  954. - Added an option to send a ZLP on write with the same size as the endpoint in CDC ACM class using APP_USBD_CDC_ACM_ZLP_ON_EPSIZE_WRITE.
  955. - Implemented macros to set interval for individual endpoints. See APP_USBD_EP_WITH_INTERVAL.
  956. - Transfers in Audio class can now be started in SOF interrupt set in the app_usbd_audio_sof_interrupt_register function.
  957. *** Changes
  958. ************
  959. ** BLE **
  960. - Increased the length of the advertising name for the Running Speed and Cadence sensor example (ble_app_rscs) to make it easy to verify
  961. that it is using the extended advertising.
  962. - Included the Scanning module into all BLE examples. This aligns how scanning is performed in these examples.
  963. - Updated the NFC pairing examples (ble_app_hids_keyboard_pairing_nfc, ble_app_hrs_nfc_pairing, ble_nfc_pairing_reference) to start using
  964. the LESC functionality in the Peer Manager (which uses the nrf_ble_lesc module).
  965. - Removed the manual handling of credits for the Object Transfer Service (ble_app_ots and ble_app_ots_c). Most use cases now work faster
  966. and simpler when the SoftDevice is controlling it.
  967. - Updated the API documentation for advertising_init in the Advertising module (ble_advertising). It was clarified that UUID arrays were not
  968. copied into the Advertising module.
  969. - Advertising module (ble_advertising) is no longer dependent on the fstorage module.
  970. - Changed the ANCS example (ble_app_ancs_c) so that it no longer performs service discovery after connecting to an already bonded peer.
  971. - Lowered the advertising interval in the Eddystone example (ble_app_eddystone), because some advertising packets would be lost when combined
  972. with the timeslot API.
  973. - Reduced the maximum supported value for advertising interval in Eddystone from 20000 to 16384. If a higher value is set, the SoftDevice returns
  974. an error code that asserts the application.
  975. - Peer Manager:
  976. - Various improvements to documentation.
  977. - The Peer Manager will now take less space for the same features.
  978. - To decrease complexity, the Peer Manager no longer uses the 'reserve' functionality in FDS, meaning that PM_EVT_STORAGE_FULL
  979. events will come slightly later if bonds cannot be stored during bonding.
  980. - Error event parameters now specify whether the error code is to be interpreted as an FDS_ error or an NRF_ error.
  981. - Peers without a stored rank are now never returned from pm_peer_ranks_get().
  982. - The function pm_peer_data_load() now fills the array even when returning NRF_ERROR_DATA_SIZE.
  983. - Enabled internal LESC key handling through PM_LESC_ENABLED. Function pm_lesc_public_key_set() is now deprecated because of this change.
  984. - All examples using the Peer Manager now use the new standard event handlers.
  985. While some examples implement custom behavior, all examples do the following:
  986. - Log Peer Manager events (at different log levels).
  987. - Encrypt immediately on connection with bonded peers.
  988. - Delete old bonds to make room for new peer data.
  989. - Some examples supporting central mode disconnect when link encryption fails. Look for functions calling pm_handler_disconnect_on_sec_failure().
  990. - The ble_app_bms example will now request for security procedure to be initiated if the Central does not initiate it.
  991. ** IEEE 802.15.4 **
  992. - Updated the radio test example to support 802.15.4 radio modes.
  993. ** Crypto **
  994. - Updated documentation about RAM requirements on mbed TLS.
  995. - Added endianness change Curve25519 (to little endian).
  996. - Removed the following defines. A compile error is shown if they are enabled in a configuration:
  997. - NRF_CRYPTO_BACKEND_CC310_BL_HASH_LITTLE_ENDIAN_DIGEST_ENABLED
  998. - NRF_CRYPTO_BACKEND_CC310_BL_ECC_LITTLE_ENDIAN_ENABLED
  999. - NRF_CRYPTO_BACKEND_MICRO_ECC_LITTLE_ENDIAN_ENABLED
  1000. - NRF_CRYPTO_BACKEND_NRF_SW_HASH_LITTLE_ENDIAN_DIGEST_ENABLED
  1001. - nrf_crypto micro-ecc backend: Moved ECDH public key validation from the key convert function to ECDH compute
  1002. (moved from nrf_crypto_backend_micro_ecc_public_key_from_raw to nrf_crypto_backend_micro_ecc_ecdh_compute).
  1003. - Upgraded nrf_cc310 and nrf_cc310_bl to version 0.9.10 including minor changes to some default configurations.
  1004. ** DFU and Bootloader **
  1005. - Updated documentation about how to change the existing SDFU project, so that the application can be uploaded without signature verification,
  1006. but at the same time to keep the signature verification when updating a SoftDevice and/or bootloader.
  1007. - The bootloader now does not use app_timer, which saves flash space.
  1008. - The bootloader now does the endian-conversion in code, instead of relying on endian-conversion in nrf_crypto.
  1009. ** Drivers and libraries **
  1010. - Included new version of nrfx (v1.1.0). For the nrfx changelog, see https://github.com/NordicSemiconductor/nrfx/blob/master/CHANGELOG.md
  1011. - nrf_log:
  1012. - Updated to production quality.
  1013. - You can now store/load the filtering configuration in FDS.
  1014. - You can now control one backend from another.
  1015. - nrf_cli: Added support for terminal meta keys.
  1016. ** Proprietary **
  1017. - Updated ESB library to support all current variants of nRF52. This mainly involves adding proper handling of Errata related to the radio.
  1018. - Added a function to skip the next packet in the TX queue. This was previously a function used internally in the module under another name.
  1019. ** USB **
  1020. - Moved USBD strings configuration to sdk_config.
  1021. - Rebuilt MSC class write procedure.
  1022. - Moved APP_USBD_CONFIG_LOG_ENABLED to nrf_log settings.
  1023. - HID report protocol is now default after reset.
  1024. - HID default idle rate after reset can now be defined.
  1025. - OUT transfers are now dropped when clearing stall on endpoint.
  1026. - SET_ADDRESS command is now defined as a separate event in app_usbd. It does not change the state of the device anymore.
  1027. - EP0 is now disabled until USB RESET condition is detected.
  1028. - HID OUT reports are now limited to 63 bytes of data + 1 byte reserved for report ID.
  1029. *** Bug fixes
  1030. ****************
  1031. ** BLE **
  1032. - Fixed a bug in the BLE UART client (ble_app_uart_c) where it would check the wrong error code when issuing multiple write commands.
  1033. - Fixed a bug in the Eddystone example (ble_app_eddystone) where the default TX power was set to 0 directly
  1034. instead of using the DEFAULT_FRAME_TX_POWER define.
  1035. - Fixed a bug in the ANCS example (ble_app_ancs) where app_timer was included too many times.
  1036. - Fixed a bug in the Advertising module (ble_advertising) where a comment referred to seconds instead of 10 ms.
  1037. - Fixed a bug in the LESC connection example (ble_app_multirole_lesc) where the procedure for connection parameter update would not be started
  1038. immediately upon connection.
  1039. - Fixed a bug where a precompiled hex was missing for Immediate Alert Server (ble_app_ias) and Service Changed server (ble_app_gatts) examples.
  1040. - Fixed a bug in the Radio Notification Event Handler (ble_radio_notification) where a missing include stopped it from compiling.
  1041. - Fixed a bug in the BLE Interactive Command Line Interface Example in service discovery procedure.
  1042. - Fixed a bug in the Alert Notification Service, where it was not possible to enable notifications for an unread alert.
  1043. - Peer Manager:
  1044. - Fixed a bug where the event PM_EVT_FLASH_GARBAGE_COLLECTED was also sent when garbage collection failed.
  1045. - Fixed a bug in pm_next_peer_id_get() where it could report a peer with no data attached to it if used during bonding.
  1046. - Fixed a bug where peer data would not be written because the internal retry mechanism failed after two attempts.
  1047. - Fixed several documentation bugs related to error codes.
  1048. ** IEEE 802.15.4 **
  1049. - Adjusted CCA threshold value to be correct for nRF52840 Rev. 1 (different from what was available on the Engineering sample).
  1050. - Implemented a fix for Anomaly 153 (temperature correction of RSSI measurement): added an API in RAL module for calculating the corrected RSSI value.
  1051. ** Drivers and libraries **
  1052. - Fixed a bug in the SPI manager where app_timer was included too many times.
  1053. - Fixed a wrapping issue in the Ring Buffer library.
  1054. ** DTM **
  1055. - Added support for 8 dB on nRF52840 targets.
  1056. - Implemented the workaround for nRF52840 Anomaly 172 which caused the device to fail a test with interference in co-channels (RF-PHY/RCV/BV-29-C).
  1057. ** Proprietary **
  1058. - Fixed a bug in bytewise_bit_swap where it was harder to backport the implementation to nRF51.
  1059. - Fixed a bug in nrf_esb_pop_tx where the packet queue would occasionally be corrupted.
  1060. - Added shutdown of the system timer as the workaround for Anomaly 78 and to save energy.
  1061. ** NFC **
  1062. - Integrated fixes from EMVCo test suite (improved interoperability).
  1063. - Added automatic fix for Anomaly 181.
  1064. - Fixed a bug where HFCLK was requested too early for nRF52840 Rev. 1 chip.
  1065. - Changed the way the fixes for chip errata are switched: use chip defines from MDK instead of board defines (simplifying usage of custom boards).
  1066. ** USB **
  1067. - Removed redundant barriers in USBD HAL.
  1068. - Fixed a bug in HID library where the report descriptor was limited to 64 bytes.
  1069. - Fixed a bug where USBD was not able to wake up after SOF event.
  1070. - Fixed a bug where the SET_ADDRESS command was not processed in time.
  1071. *** Known Issues
  1072. ****************
  1073. ** BLE **
  1074. - Peer Manager:
  1075. - When a link is already secured and the peer sends a slave security request for a higher level of security, the request will not be honored.
  1076. - Service Changed indications might be silently dropped without being sent if the attempt to send them happens during an ATT MTU exchange.
  1077. ** BLE IOT **
  1078. - Neighbor discovery module for lwIP requires the on-link flag in the router advertisement to be set to create a SLAAC address from the prefix.
  1079. However, RFC 7668 (https://tools.ietf.org/html/rfc7668) requires this bit to be zero. Therefore, the nd6.c from lwIP source has been modified
  1080. to relax this check.
  1081. - There are some issues when using the IoT examples against Linux Kernel 4.12+ that cause the kernel to only work with one 6LoWPAN connection.
  1082. If more than one kit is connected using 6LoWPAN, none of the nodes will be accessible.
  1083. - Scheduler has been included in most IoT examples to avoid race conditions found when using the lwIP stack, more precisely the TCP examples.
  1084. The issue was that the TCP client would stop working after about 15 hours. However, when using mbed TLS, the use of scheduler is not possible.
  1085. Therefore, the MQTT client examples might be affected by this issue.
  1086. - The use of security, both with TLS and DTLS, should be treated as experimental.
  1087. - MQTT examples cannot be used with commissioning on nRF52832. There is not enough RAM to accommodate both TLS and the commissioning service.
  1088. - If enabled, RTT logs in IoT bootloader might not be printed before resetting.
  1089. - The background_dfu example does not work.
  1090. ** Drivers and libraries **
  1091. - SAADC driver is not handling detection limits: high and low correctly if SAADC resolution is greater than 10 bits.
  1092. - In the radio test example, modulated packets will only have the requested content in the first two bytes.
  1093. Further bytes have random values.
  1094. - In the radio test example, start_duty_cycle_modulated_tx is not working as intended.
  1095. The actual duty cycle on air is not what was requested in the command.
  1096. ** USBD **
  1097. - Due to Anomaly 199, the USBD driver blocks code execution during EasyDMA transfer (for stability).
  1098. ========================================================================
  1099. nRF5 SDK v15.0.0
  1100. ------------------------
  1101. Release Date: Week 12, 2018
  1102. Highlights:
  1103. - Full support for nRF52840 and production quality of libraries and examples for this device.
  1104. - Support for the new SoftDevices S140, S132, and S112 v6.0.0.
  1105. - Peripheral drivers now use nrfx.
  1106. - Extensive rework of the DFU functionality.
  1107. - Extensive rework of the cryptography library (nrf_crypto).
  1108. - USB firmware is now in production quality.
  1109. - Serialization of SoftDevices S140, S132, and S112 v6.0.0.
  1110. - IEEE 802.15.4 protocol in production quality.
  1111. - Included nrf_oberon crypto library with standard Nordic 5-clause license.
  1112. The following toolchains/devices have been used for testing and
  1113. verification:
  1114. - ARM: MDK-ARM version 5.18a
  1115. - GCC: GCC ARM Embedded 6.3 2017-q2-update
  1116. - IAR: IAR Workbench 7.80.4 (IAR 8 - see note below)
  1117. - SES: SES 3.34
  1118. - Linux: Ubuntu 17.04, Kernel 4.10.0.
  1119. - Jlink: 6.22g
  1120.     
  1121. *****
  1122. Note for IAR 8 users:
  1123. Libraries for IAR 8 require wchar_t to be of size 32 bits while IAR 7 requires 16 bits.
  1124. To run a project using IAR 8, follow these intructions:
  1125.  - Open the IAR project in IAR 8. The IAR workbench will automatically generate an IAR 8 compatible project file.
  1126.  - If the project contains one of the precompiled libraries listed below, replace it with the IAR 8 compatible alternative
  1127.    (there are no projects targeting nRF51 in this SDK).
  1128.  - Save the project.
  1129.  - When building the project, you might get the warning: "The header file 'cmsis_iar.h' is obsolete and should not be used. ....".
  1130.    The problem is described in DevZone post: https://devzone.nordicsemi.com/f/nordic-q-a/31123/iar-ewarm-8-22-1-complains-about-cmsis_iar-h
  1131.    The solution is to remove all occurrences of #include <cmsis_iar.h>.
  1132. The affected libraries are
  1133. - micro-ecc crypto:
  1134.     - IAR 7: Includes the library located in the folder named "…_iar\…".
  1135.     - IAR 8: Switch to using the library from the folder named "…_armgcc\…".
  1136. - nrf_cc310, nrf_cc310_bl, and nrf_oberon:
  1137.     - IAR 7: Includes the library where "_short_wchar_" is part of the file name.
  1138.     - IAR 8: Switch to using the library with similar naming, but where the "short_wchar" is removed.
  1139. - Gazell, NFC Tag, and 802.15.4:
  1140.     - IAR 7: Includes the library where the file name ends with "_iar".
  1141.     - IAR 8: Switch to using the library with similar file name that ends with "_gcc".
  1142. *****
  1143.  
  1144. Supported SoftDevices:
  1145. - S112 v6.0.x
  1146. - S132 v6.0.x
  1147. - S140 v6.0.0
  1148. - S212 v5.0.x
  1149.      
  1150. Supported boards:
  1151. - PCA10040
  1152. - PCA10040E (nRF52810 emulation on PCA10040)
  1153. - PCA10056
  1154. - PCA10059 (support in selected examples)
  1155. - Dynastream's D52DK1 (only for ANT examples)
  1156.      
  1157. For other devices and boards, see the SDK documentation, section "Using
  1158. the SDK with other boards".
  1159.      
  1160.  
  1161. *** New features
  1162. *****************
  1163.  
  1164. ** IEEE 802.15.4 **
  1165. - Added support for SES toolchain.
  1166.  
  1167. ** ANT **
  1168. - Added support for SES and GCC toolchains in the following examples:
  1169.     - ANT-FS Client
  1170.     - ANT Bootloader/DFU
  1171.  
  1172. ** BLE **
  1173. - Added support for the new SoftDevices S140, S132, and S112 v6.0.0. For more information about SoftDevice v6.0.0, refer to the SoftDevice documentation.
  1174. - Extended advertising and selection of advertising PHYs can now be configured using the advertising module (ble_advertising).
  1175. - Running Speed and Cadence Service Application (ble_app_rscs) now advertises using extended advertising. Note that this makes it incompatible with devices that do not support extended advertising.
  1176. - Added multilink support for a selected group of BLE services (including separate GATT context for each connected client).
  1177.     - Affected services:
  1178.         - Human Interface Device Service: ble_hids.
  1179.         - Nordic UART Service: ble_nus.
  1180.         - Immediate Alert Service: ble_ias.
  1181.         - Battery Service: ble_bas.
  1182.     - Added BLE Link Context Manager module
  1183.     - Modified the Immediate Alert Application to show this feature.
  1184. - Added a new application: BLE Interactive Command Line Interface Example.
  1185. - Added Device Information Service client. This module can be used to read any characteristic of Device Information Service.
  1186.     - Modified the Running Speed and Cadence Collector example application (ble_app_rscs) to show the use of this module.
  1187. - Immediate Alert Service client example application (ble_app_ias_c) is no longer experimental.
  1188. - Immediate Alert Service server example application (ble_app_ias) is no longer experimental.
  1189. - GATT Service Client Example Application (ble_app_gatts_c) is no longer experimental.
  1190. - GATT Service Server Example Application (ble_app_gatts) is no longer experimental.
  1191. - Improved the test description documentation for Continuous Glucose Monitoring Service Example Application (ble_app_cgms). It now showcases more capabilities of the application and how to test them.
  1192. - ble_conn_state: Added new function ble_conn_state_for_each_set_user_flag() which calls a function for each flag in a collection that is set.
  1193. - Peer Manager:
  1194.     - Two new configuration parameters to disable functionality to save space:
  1195.         - PM_SERVICE_CHANGED_ENABLED to enable/disable Service Changed sending. This must be enabled if Service Changed is enabled in the GATT database.
  1196.         - PM_PEER_RANKS_ENABLED to enable/disable the tracking of peer ranks.
  1197.     - The relevant APIs have gained the error code NRF_ERROR_NOT_SUPPORTED if the function is called when the configuration is disabled.
  1198. - Added NRF_SDH_BLE_GAP_DATA_LENGTH configuration (under nrf_sdh_ble) to configure BLE data length negotiated by the nrf_ble_gatt module.
  1199. - Added BLE LESC module as experimental.
  1200.  
  1201. ** BLE IOT **
  1202.  - Added support for the nRF52840 (PCA10056 board) with the use of the S140 SoftDevice.
  1203.  
  1204. ** NFC **
  1205.  - Added support for SES toolchain in the Adafruit Tag Reader Example.
  1206. ** Crypto **
  1207.  - Production quality nrf_crypto interface that supports software and hardware backends (using the CC310 hardware accelarator in nRF52840 devices).
  1208.  - nrf_crypto API supports the following cryptographic family of algorithms (subject to support in nrf_crypto backends):
  1209.     - AES (CBC, CTR, CFB, ECB, CBC_MAC, CMAC)
  1210.     - AEAD (CCM, CCM*, EAX, GCM, ChaCha-Poly)
  1211.     - ECC (Elliptic Curve Cryptography)
  1212.         - Key generation
  1213.         - Key validation
  1214.         - Key conversions (from/to raw format)
  1215.     - ECDH (multiple curves)
  1216.     - ECDSA (multiple curves)
  1217.     - SHA-2 family hash
  1218.     - HMAC
  1219.     - HKDF
  1220.     - RNG using AES CTR or through dedicated hardware/sofware (on nRF52840)
  1221.     - Experimental Ed25519 support (available through the nrf_crypto_ecdsa API)
  1222.  - nrf_crypto API support for dynamic memory management by configuration:
  1223.     - User-specified macros to NRF_CRYPTO_ALLOC and NRF_CRYPTO_FREE
  1224.     - Stack allocation (using alloca)
  1225.     - C dynamic allocation (malloc)
  1226.     - SDK Memory Manager (nrf_malloc)
  1227.  - nrf_crypto backends include the following:
  1228.     - Cifra
  1229.     - mbed TLS
  1230.     - micro-ecc
  1231.     - nrf_cc310
  1232.     - nrf_cc310_bl (code size optimized, to use in Secure DFU)
  1233.     - nRF HW (for RNG)
  1234.     - nrf_oberon
  1235.     - nRF software (legacy)
  1236.  - Examples of nrf_crypto usage with the option to change the nrf_crypto backends.
  1237.  - Test example to verify the cryptographic routines and APIs through standardized test vectors.
  1238.  
  1239. ** DFU/Bootloader **
  1240.  - SoftDevice independence:
  1241.      - Only the BLE bootloader is now dependent on the SoftDevice. The others depend only on the MBR (which is now part of the SDK).
  1242.      - The DFU now supports updating applications that do not use the SoftDevice. Such an application must be compiled to be placed above the MBR.
  1243.  - The DFU protocol has been extended to support new messages:
  1244.      - Protocol version - To retrieve information about the protocol version.
  1245.      - Firmware version - To retrieve information (size, version) about each piece of firmware on the chip.
  1246.      - Hardware version - To retrieve information (flash/RAM size, page size) about the hardware.
  1247.      - DFU Abort - To instruct the bootloader to abort the DFU procedure and reset the device.
  1248.  - Configurable security: New configuration parameters to turn on and off version checking and signature checking of application transfers. Added a new example using the new configurations (open_bootloader).
  1249.  - DFU Trigger (USB): Added a library to allow DFU mode to be triggered through USB in the application. The library is used in the new ble_connectivity example that uses USB CDC ACM.
  1250.  - Added optional skipping of application CRC check. CRC check can be skipped on wakeup from System Off or on special value written to GPREGRET2 register.
  1251.  - Added watchdog support to the bootloader. If application had enabled watchdog before resetting to the bootloader, it is fed in the bootloader.
  1252.  
  1253.  ** Drivers and libraries **
  1254.  - Added support for wildcards in the CLI module.
  1255.  - Added TWI sensor module.
  1256.  - Added drivers for sensors on Thingy:52 (LPS22HB, BH1745, HTS221, CCS811, SX1509B, LIS2DH12).
  1257.  - Added the nrfx project as a set of default drivers and provided a legacy layer for supporting deprecated API.
  1258.  - Added support for filtering log messages on instance level in the logger module. Instance level logging added to nrf_balloc, nrf_queue, and nrf_atfifo.
  1259.  - Added new logger backends for writing logs to flash: flashlog backend for storing logs in standard operation, crashlog backend for dumping logs on error condition. Added CLI commands for controlling data stored in flash.
  1260.  - Added optional timestamp formatting in the logger. 
  1261.  - Added new implementation of app_timer (libraries/timer/experimental/app_timer2.c) which does not use SWI, uses less RAM and flash, and has modular, simpler design. It shares the same API as the legacy implementation. The new implementation is used by bootloaders and peripheral/CLI.
  1262.  - Added bsp_cli module to send BSP events through CLI.
  1263.  - Added nrf_atflags module for atomic manipulation of bit fields.
  1264.  - Added improved CLI UART backend called libUARTE. This backend is recommended when the CLI must exchange big amounts of data fast, for example when CLI is used with a script.
  1265.  
  1266. ** Serialization **
  1267. - Added serialization of the S112, S132, and S140 v6.0.0 SoftDevices.
  1268. - Added serialization connectivity application for PCA10059 using USB CDC ACM as the transport layer.
  1269.  
  1270. ** USB **
  1271. - Added example with the SoftDevice and USB (usbd_ble_uart).
  1272. - Added configuration of the self-powered descriptor bit (APP_USBD_CONFIG_SELF_POWERED).
  1273. - Added buffering of transfers in CDC.
  1274. - Added configuration of power in a descriptor (APP_USBD_CONFIG_MAX_POWER).
  1275. - Added option to specify the CDC ACM protocol.
  1276. - Added dummy interface class.
  1277. - Implemented USBD power event processing in app_usbd event queue.
  1278. - Implemented different ways of processing SOF events:
  1279.     - Normal - SOF events are pushed normally into the event queue.
  1280.     - Compress - SOF events are counted and bound with other events or executed when the queue is empty. This prevents the queue from filling up with SOF events.
  1281.     - Interrupt - SOF events are processed in the interrupt.
  1282. - Implemented Get Output Report in HID class.
  1283. - New SoftDevice API used for USB power events.
  1284. - Button events can now be sent through CLI in the usbd_cdc_acm, usbd_hid_composide, and usbd_hid generic examples.
  1285.  
  1286.  
  1287. *** Changes
  1288. ************
  1289.  
  1290. ** ANT **
  1291.  - Added welcome message to all ANT examples. Logging is enabled by default in all of them.
  1292.  - Removed obsolete module: ant_stack_config. The ANT SoftDevice Handler module has taken over its functionality.
  1293.  
  1294. ** BLE **
  1295.  - Minor improvements to consistency of BLE examples main functions (comments, function call ordering, function names).
  1296.  - BLE examples changed to use the Queued Write module (nrf_ble_qwr). Applications must explicitly configure characteristics to accept long writes. See app_ble_qwr for an example of this. This fixes a problem where peers could cause our devices to assert by issuing long writes.
  1297.  - BLE examples changed to use the Power Management library. Most examples now call nrf_pwr_mgmt_run() instead of sd_app_evt_wait().
  1298.  - Eddystone modules have been moved from components/libraries to components/ble.
  1299.  - ble_app_uart changed to have 247-byte MTU, up from 64.
  1300.  - Peer Manager:
  1301.      - The members of pm_conn_sec_procedure_t have been renamed from PM_LINK_SECURED_PROCEDURE_* to PM_CONN_SEC_PROCEDURE_*.
  1302.      - The following functions have gained new error codes:
  1303.          - pm_conn_secure()
  1304.          - pm_peer_data_store()
  1305.          - pm_peer_ranks_get()
  1306.          - pm_peer_rank_highest()
  1307.  
  1308. ** BLE IOT **
  1309.  - Minor updates in TFTP background DFU modules to align with changed DFU libraries.
  1310.  
  1311. ** Crypto **
  1312.  - nrf_crypto APIs have been changed to use big-endian only.
  1313.     - Previous versions of nrf_crypto used little-endian ordering to conform to BLE requirements in LESC.
  1314.       This has now been changed to big-endian everywhere. There are conversion functions available to
  1315.       change between little-endian and big-endian input/output.
  1316.     - See the Migration Guide for details.
  1317.  - nrf_crypto memory management has changed extensively.
  1318.     - See the Migration Guide for details.
  1319.  - nrf_crypto configuration of frontends and backends is now primarily done through sdk_config.h.
  1320.     - See the Migration Guide for details.
  1321.  
  1322. ** DFU/Bootloader **
  1323.  - Configuration parameters (sdk_config) have changed. See the Migration Guide for details.
  1324.  - Refactoring: The DFU/bootloader code has been extensively refactored.
  1325.      - The split between DFU and bootloader has been improved.
  1326.         - New events from DFU.
  1327.         - Resetting has been moved from DFU to bootloader, based on DFU events.
  1328.         - Much of the code in nrf_dfu_utils has been extracted into the new nrf_bootloader_fw_activation and nrf_bootloader_dfu_timers modules.
  1329.      - Request handling module:
  1330.         - The dfu_req_handling module has been renamed to nrf_dfu_req_handler and moved to components/libraries/bootloader/dfu.
  1331.         - The request handling now uses app_scheduler and is entirely asynchronous and executed in the main context.
  1332.         - The init command validation was refactored out and into two new modules nrf_dfu_validation and nrf_dfu_ver_validation.
  1333.      - The Serial transport is now called UART.
  1334.      - The shared parts of the USB and UART transports have been placed in a separate module nrf_dfu_serial.
  1335.      - Most of the assembly code in bootloader_app_start has been replaced with C code and extracted into a separate file nrf_bootloader_app_start_final.
  1336.      - Examples:
  1337.         - The secure bootloader examples have been moved into a 'secure_bootloader' folder.
  1338.         - The experimental ANT bootloader has been moved into an 'experimental' folder.
  1339.         - The USB secure bootloader is no longer experimental.
  1340.  - Bootloader examples have been reorganized. Examples "bootloader_secure_ble", "bootloader_secure_serial", and "experimental_bootloader_secure_usb" have been merged into "secure_bootloader" with projects for each transport and board.
  1341.  - Write protection of the bootloader: Before booting the app, the bootloader will write-protect the flash areas of the bootloader and MBR (using BPROT on nRF52832/nRF52810 and ACL on nRF52840).
  1342.      - The BLE Buttonless SVCI interface needs access to the bootloader settings page from the application, so there is a new configuration parameter to specify whether that page should be part of the protection.
  1343.      - The SVCI interface will now return NRF_ERROR_FORBIDDEN if using the interface when the page is protected.
  1344.  - WDT compatibility: The bootloader will feed the WDT if the app has started it.
  1345.  - BLE DFU:
  1346.      - The BLE DFU bootloader now explicitly requests the preferred connection interval upon connection. The minimum and maximum connection intervals can be set in sdk_config.h.
  1347.      - The BLE DFU bootloader will use long ATT MTUs and data length extension when the host supports these features. This increases DFU transfer speed considerably.
  1348.      - Several stability improvements over different transport configurations.
  1349.  - USB serial number: The serial number of the USB bootloaders has changed to be the same as the default BLE address (found under DEVICEADDR in FICR).
  1350.  - New crypto backend for nRF52840: The bootloaders for nRF52840 use the hardware crypto backend (CC310) instead of micro-ecc.
  1351.  
  1352. ** Drivers and libraries **
  1353.  - The way peripheral drivers are handled in the SDK has been reorganized:
  1354.      - Replaced existing drivers with the "external" drivers from nrfx project. See https://github.com/NordicSemiconductor/nrfx/blob/master/README.md for more information on nrfx.
  1355.      - New drivers from nrfx are located in "..\modules\nrfx".
  1356.      - Drivers replaced by nrfx are removed from "..\components\driver_nrf".
  1357.      - A glue layer is added to make the nrfx driver compatible with SDK and the SoftDevice.
  1358.  - Refactored I2S driver.
  1359.  - New reliable delay implementation.
  1360.  - Added CLI commands to nrf_balloc and nrf_queue which print out the status of all instances present in the system.
  1361.  - CLI built-in root commands: cli_stats, colors, and echo have been changed to subcommands: cli colors, cli echo, and cli stats.
  1362. - The CMSIS-SVD files with device descriptions have been moved from the "..\svd" folder to the "..\modules\nrfx\mdk" folder.
  1363.  - Infineon OPTIGA:
  1364.      - Replaced "crypto\ifx_optiga_auth" example with the new one: "crypto\ifx_optiga_ecdsa_simple".
  1365.      - Updated related libraries from the "external\infineon" directory.
  1366.      - Replaced support for Infineon OPTIGA Trust E HSM with Infineon OPTIGA Trust X HSM.
  1367.      - Added support for IAR toolchain.
  1368.  
  1369. ** Proprietary **
  1370.  - New Gazell functionalities:
  1371.      - Transmission statistics gathering - counts successful packet transactions and timeouts on each of the RF channels.
  1372.      - External analog frontend module control - generates TX/RX signals during transmission/receiving, which can be used to control the external PA/LNA module.
  1373.  - Updated gzll_ack_payload examples with the example usage of the new Gazell features.
  1374.  - Dynamic changes of TX attempts and TX power parameters are now allowed when the Gazell stack is enabled.
  1375. - Removed the nRF52840 project from ble_app_gzll example (removed "pca10056" folder).
  1376.  
  1377. ** NFC **
  1378.  - Type 2 Tag Library:
  1379.     - Modified Dynamic Memory structure of the Tag. Added Terminator TLV to indicate that there is no more relevant user data after NDEF TLV.
  1380.  - Type 4 Tag HAL:
  1381.     - Modified Frame Wait Time setting to support full range available on the nRF52840 Rev. 1 chip.
  1382.  - Type 4 Tag Library:
  1383.     - Modified behavior of the NFC_T4T_EVENT_NDEF_READ event: the event is always triggered when the last byte of the NDEF File is sent to an NFC Reader device - even if the Reader repeats the read operation multiple times in one session, i.e. before the Reader sends a DESELECT or SLP_REQ frame.
  1384.  - NFC BLE pairing library: modified to support multiple connections.
  1385.  - BLE/NFC examples: updated application behavior to comply with NFC Forum user experience recommendations.
  1386.  - NFC libraries which can enable nrf_log independently (using sdk_config.h) register the logger instance conditionally, i.e. only if nrf_log is enabled in the sdk_config.h
  1387.  
  1388. ** USB **
  1389.  - app_usbd_init: when called with NULL configuration structure or NULL ev_handler member of a structure, the default event handler will be used.
  1390.  - app_usbd_init: removed clock initialization.
  1391.  - Descriptors are now generated on the fly using simple stackless thread code.
  1392.  - Added a warning for wrong interface order.
  1393.  - Combined USB CDC ACM driver for all examples into one.
  1394.  
  1395.    
  1396. *** Bugfixes
  1397. ****************
  1398.  
  1399. ** ANT **
  1400.  - Added missing logger backends to all examples.
  1401.  
  1402. ** BLE **
  1403.   - Fixed a bug in ble_app_uart where Data Length update requests would be handled twice.
  1404.   - Fixed a bug in ble_app_uart and ble_app_uart_c where the "start" message in the main function was not followed by a line feed. This could make the applications seem unresponsive.
  1405.   - Fixed a bug in ble_app_cgms where properties of the characteristics were not configured.
  1406.   - Fixed a bug in ble_app_cgms where directed advertising was enabled by the advertising module but was ignored by the application. Directed advertising is now disabled.
  1407.   - Fixed a bug in ble_app_cgms where advertising was triggered twice when deleting bonds. The second call to advertising start would cause the example to assert on the busy error.
  1408.   - Fixed a bug in ble_app_gls  where the seconds field of the glucose measurement was never updated.
  1409.   - Fixed a bug in ble_tps where documentation for ble_tps_tx_power_level_set() was describing another unrelated function.
  1410.   - Fixed a bug in most main.c files where fds garbage collection fds_gc() would retry upon returning FDS_ERR_BUSY. However, this function call will never return FDS_ERR_BUSY.
  1411.   - Fixed a bug in nrf_ble_gatts_c where setting NRF_LOG_DEFAULT_LEVEL to debug (4) would cause an assert because it was not registered with the logger module (NRF_LOG_MODULE_REGISTER();)
  1412.   - Added missing Errata workaround to Direct Test Mode (DTM) on nRF52840.
  1413.   - Peer Manager:
  1414.       - Fixed the bonded flag in pm_conn_sec_status_get().
  1415.       - Fixed a performance bug in peer_database.c.
  1416.       - Split the error code NRF_ERROR_INVALID_STATE from pm_conn_secure() that could have two different meanings.
  1417.  
  1418. ** BLE IOT **
  1419.   - Corrected logging module name, such that logs could be enabled in the LWIP platform module.
  1420.   - Fixed a reassembly bug in BSD socket module.
  1421.   - Fixed flushing of ports when the kit disconnects. Added API to flush the ports.
  1422.   - Added handling of BLE_L2CAP_EVT_CH_SDU_BUF_RELEASED event to generate the BLE_IPSP_EVT_CHANNEL_DATA_TX_COMPLETE in case link disconnection occured before the TX was complete.
  1423.   - Resolved an issue with MQTT/lwIP packets stuck in a TX queue. Now forcing out enqueued data before close.
  1424.   - Conformed to MQTT specification in the use of QoS flag in MQTT connect.
  1425.  
  1426. ** DFU/Bootloader **
  1427.   - Bootloaders for nRF52840 now support bootloader updates (if used with the new MBR or SoftDevice).
  1428.   
  1429. ** Drivers and libraries **
  1430.   - Extended input pin configuration in the GPIOTE driver: configuration of GPIOTE INPUT pin added, which does not change the current GPIO configuration.
  1431.   - CLI module - fixed echo command behavior. When echo is off, the command will not be printed after log print.
  1432.   - Logger modules - stability fixes (including https://devzone.nordicsemi.com/f/nordic-q-a/31178/bug-nrf_log_frontend-m_log_data-buffer-overflow).
  1433.   - More changes in drivers can be found in the modules/nrfx directory in the CHANGELOG.md file.
  1434. ** Proprietary **
  1435.  - Gazell stack:
  1436.     - Fixed a bug with high current consumption in disabled state, related with TIMER issue 78.
  1437.     - Fixed a bug with reenabling Gazell stack after the SoftDevice activity.
  1438.  - Gazell Pairing Library:
  1439.     - Fixed a bug with unreserved flash memory region for the Host ID.
  1440.     - Fixed a bug with wrong initialization of database flash memory page on nRF52 chips.
  1441.  
  1442. ** NFC **
  1443.  - Type 2 Tag Library:
  1444.     - Modified Dynamic Memory content of the Tag. Dynamic Lock Bytes use proper values now.
  1445.     - Updated CC1 byte setting (one of the Type 2 Tag Reserved bytes) according to the new NFC Forum Type 2 Tag Technical Specification v1.0.
  1446.  - Type 2 Tag HAL:
  1447.     - Handling of erroneous NFC-A data frames (with parity and CRC errors) has been improved.
  1448. ** USB **
  1449.  - Fixed a bug in USB CDC ACM class where the APP_USBD_CDC_ACM_USER_EVT_PORT_OPEN event was not raised.
  1450.  - Fixed a bug in USB CDC ACM class where RX stopped working after the port was closed or the cable was detached.
  1451.  - Fixed a bug in USB MSC where it could not satisfy the number of required bytes by the host.
  1452.  - Fixed a bug in app_usbd.c where APP_USBD_EVT_DRV_RESUME event was raised after a reset instead of APP_USBD_EVT_DRV_RESET.
  1453.  - Fixed a bug in HID class where Remote Wake Up was not properly handled.
  1454.  - Fixed a bug in nrf_drv_usbd_transfer_out_drop() where it was clearing an isochronous endpoint.
  1455.  - Fixed a bug in app_usbd_core.c where transfer status was not checked during EP0 processing.
  1456.  - FTPAN-171 workaround has been implemented.
  1457.  - FTPAN-199 workaround has been implemented.
  1458.  - Fixed minor issues.
  1459.  
  1460. *** Known Issues
  1461. ****************
  1462.  
  1463. ** Missing feature on nRF52840 **
  1464.   - ANT protocol support is missing due to ANT SoftDevices not available for this device.
  1465.   - FreeRTOS
  1466.   - ESB
  1467.  
  1468. ** BLE **
  1469.  - BLE LESC module should be treated as experimental, even though it has not been marked as such.
  1470. - Eddystone example should be treated as experimental on nRF52840.
  1471.  
  1472. ** BLE IOT **
  1473.  - Neighbor discovery module for lwIP requires the on-link flag in the
  1474.    router advertisement to be set in order to create a SLAAC address
  1475.    from the prefix. However, RFC 7668 (https://tools.ietf.org/html/rfc7668)
  1476.    requires this bit to be zero. Therefore, the nd6.c from lwIP source
  1477.    has been modified to relax this check.
  1478.  - There are some issues when using the IoT examples against Linux
  1479.    Kernel 4.12+ which causes the kernel to only work with one 6LoWPAN
  1480.    connection. If more than one kit is connected using 6LoWPAN, none of
  1481.    the nodes will be accessible.
  1482.  - Scheduler has been included in most IoT examples to avoid race
  1483.    conditions found when using the lwIP stack, more precisely the TCP
  1484.    examples.
  1485.    The issue was that the TCP client stopped working after about 15
  1486.    hours. However, when using mbed TLS, the use of scheduler is not
  1487.    possible.
  1488.    Therefore, the MQTT client examples might be affected by this issue.
  1489.  - The use of security, both with TLS and DTLS, should be treated as
  1490.    experimental.
  1491.  - MQTT examples cannot be used with commissioning on nRF52832. There is not enough
  1492.    RAM to accommodate both TLS and the commissioning service.
  1493.  - If enabled, RTT logs in IoT bootloader might not be printed before resetting.
  1494.  
  1495. ** DFU/Bootloader **
  1496.  - Changing the backend for nrf_crypto in sdk_config.h alone is not sufficient
  1497.    because the relevant files are not included in the build and include paths.
  1498.    See the Migration Guide for a walkthrough of changing from the µECC to the
  1499.    Oberon backend.
  1500.  - ble_app_buttonless_dfu will silently hang during bootup if a compatible
  1501.    bootloader, i.e. the BLE bootloader, is not present.
  1502. - SES will not detect whether the debug bootloader is too large, instead it will place the code in the MBR params page. To make SES detect this, add the following line in flash_placement.xml:
  1503.   <ProgramSection load="no" name=".reserved_flash_tail" start="$(FLASH_START)+$(FLASH_SIZE)" size="$(FLASH_PH_SIZE)-$(FLASH_START)-$(FLASH_SIZE)" />
  1504. Place this line immediately after:
  1505. <ProgramSection alignment="4" load="Yes" runin=".tdata_run" name=".tdata" />
  1506. The production bootloader is not affected by this issue.
  1507. - nrfutil version 3.5.0 has an optional argument to increase the time delay "--connect-delay <seconds>".
  1508. It is recommended to set this value to 10 when Serial DFU (UART / USB) is performed for large images (SoftDevice + Application or SoftDevice + Bootloader + Application).
  1509. - You may experience some instability with the µECC library in IAR due to faulty decoding of symbol information. Compile the µECC library without symbol information to fix these issues.
  1510. ** Proprietary **
  1511.  - Gazell stack for all devices is working with sensitivity reduced by 3 dB due to the RADIO issues 102, 106, 107, and 143.
  1512.  
  1513. ** NFC **
  1514.  - NFC Type 2 and Type 4 Tag HAL modules require using TIMER 4 on nRF52840 and nRF52832 chips.
  1515.  
  1516. ** USBD **
  1517.  - For the sake of stability, the USBD driver blocks code execution during EasyDMA transfer.
  1518.  - Isochronous transfers must be processed as fast as possible, but using the event queue may postpone SOF processing too long if the CPU is busy. In such situations, isochronous transfers should be started inside a SOF interrupt. Configure APP_USBD_CONFIG_SOF_HANDLING_MODE as interrupt. The implementation of special SOF interrupt callbacks is subject of the future updates.
  1519.  
  1520. ** Drivers and Libraries **
  1521.  - SAADC driver is not handling detection limits: high and low correctly if SAADC resolution is greater than 10 bits.
  1522. - The following examples do not have Keil 4 support: nrf_cc310, nrf_cc310_bl, ifx_optiga_ecdsa_simple.
  1523. ========================================================================
  1524. nRF5 SDK v14.2.0
  1525. ------------------------
  1526. Release Date: Week 46, 2017
  1527. Highlights:
  1528. - Support for the new S112 SoftDevice v5.1.0.
  1529. The following toolchains/devices have been used for testing and
  1530. verification:
  1531. - ARM: MDK-ARM version 5.18a
  1532. - GCC: GCC ARM Embedded 4.9 2015q3
  1533. - IAR: IAR Workbench 7.80.4
  1534. - SES: SES 3.30
  1535. - Linux: Ubuntu 17.04, Kernel 4.10.0.
  1536. - Jlink: 6.20d
  1537. Supported SoftDevices:
  1538. - S112 v5.1.x
  1539. - S132 v5.0.x (for v5.1.x, see the note below)
  1540. - S140 v5.0.0-2.alpha
  1541. - S212 v5.0.x
  1542. - S332 v5.0.x
  1543. S132 compatibility:
  1544. The newly released S132 SoftDevice v5.1.0 is drop-in compatible with
  1545. S132 v5.0.0, which is included in this SDK release.
  1546. However, there are some limitations that you must be aware of when
  1547. replacing the included SoftDevice with the new one:
  1548. - In S132 v5.1.0, the SoftDevice RAM usage is reduced. Examples that are
  1549. optimized on RAM usage return a warning that the application RAM start
  1550. address can be lowered. The examples work as before but are not fully
  1551. optimized on RAM usage.
  1552. - The test images in examples\dfu\secure_dfu_test_images are tightly
  1553. connected with the precompiled HEX files located in
  1554. examples\dfu\bootloader_secure_ble\hex. Therefore, they cannot be used
  1555. in combination with the new SoftDevice.
  1556. Supported boards:
  1557. - PCA10040E (nRF52810 emulation on PCA10040)
  1558. - PCA10040
  1559. - PCA10056 (limited support; see the "Scope for the nRF52840 chip" section)
  1560. - Dynastream's D52DK1 (only for ANT examples)
  1561. For other devices and boards, see the SDK documentation, section "Using
  1562. the SDK with other boards".
  1563. *** Scope for the nRF52840 chip
  1564. ********************************
  1565. All examples and libraries for the new chip must be treated as
  1566. experimental.
  1567. Some examples have not been ported to run on nRF52840. Check the
  1568. existing example projects to see which targets are supported.
  1569. The following SDK features are supported on the new nRF52840 chip:
  1570. - IEEE 802.15.4 stack library with an example
  1571. - Most BLE, hardware peripheral, and NFC examples (with some
  1572. exceptions; see the available example projects for details)
  1573. - Peripheral HAL and drivers (both for existing and new peripherals)
  1574. - Cryptography library including CryptoCell CC310 backend
  1575. - NFC Type 2 Tag and Type 4 Tag
  1576. - Secure DFU (only with micro-ecc backend)
  1577. - DTM including support for the new Bluetooth 5 features
  1578. - Gazell
  1579. The following SDK features are not supported on the new nRF52840 chip:
  1580. - ANT
  1581. - Eddystone
  1582. - ESB
  1583. - FreeRTOS
  1584. - IoT components
  1585. - Serialization of the S140 SoftDevice v5.0.0-2.alpha
  1586. *** New features
  1587. *****************
  1588. ** BLE **
  1589. - Added support for the S112 SoftDevice v5.1.0.
  1590. ** Crypto **
  1591. - Added a makefile for compiling the micro-ecc library with a "soft"
  1592. FPU ABI (required for nRF52810, which does not have hardware FPU
  1593. support).
  1594. ** Drivers and libraries **
  1595. - Added support for a "soft" FPU ABI in the Task Manager library
  1596. (required for nRF52810, which does not have hardware FPU support).
  1597. *** Changes
  1598. ************
  1599. ** Drivers and libraries **
  1600. - TWI Transaction Manager: Added support for passing the TWI
  1601. configuration in function nrf_twi_mngr_perform(). Pass NULL if you do
  1602. not want to use this new feature.
  1603. - Command Line Interface: Added support for commands longer than 255
  1604. characters.
  1605. *** Bugfixes
  1606. ****************
  1607. ** Drivers and libraries **
  1608. - Fixed "echo" command behavior in nrf_cli.
  1609. - Fixed a bug in nrf_ringbuf where allocation protection failed on a
  1610. second attempt to allocate a buffer in use.
  1611. - Fixed a compile error in the Task Manager library when stack guard is
  1612. off.
  1613. - Fixed invalid module names in logger output when LTO was used in the
  1614. GCC compiler.
  1615. - Fixed a bug in the logger where output could get corrupted when
  1616. logging was interrupted by NRF_LOG_PROCESS() (for example, flushing
  1617. in error handler).
  1618. ** DTM **
  1619. - Fixed a bug preventing certain TX power values to be set.
  1620. - Set the PDU header payload type field of coded PHY 0xFF packets to
  1621. 0x04 instead of 0x03 to make the 0xFF packets valid.
  1622. *** Known Issues
  1623. ****************
  1624. ** BLE **
  1625. - When working on the emulated nRF52810 target, if you change the
  1626. optimization level and/or add the logging functionality, the project
  1627. might not compile or fail at runtime due to not enough flash
  1628. available for FDS or Peer Manager.
  1629. - All Bluetooth applications not using the nrf_queued_write module will
  1630. assert when a peer sends a Write request with the opcode 'cancel all
  1631. operations' (BLE_GATTS_OP_EXEC_WRITE_REQ_CANCEL), after the
  1632. SoftDevice call to sd_ble_gatts_rw_authorize_reply. This SoftDevice
  1633. call, for the opcode 'cancel all operations', returns
  1634. NRF_INVALID_PARAMS if the gatt_status is not BLE_GATT_STATUS_SUCCESS.
  1635. ** BLE IOT **
  1636. - Neighbor discovery module for lwIP requires the on-link flag in the
  1637. router advertisement to be set in order to create a SLAAC address
  1638. from the prefix. However, RFC 7668 (https://tools.ietf.org/html/rfc7668)
  1639. requires this bit to be zero. Therefore, the nd6.c from lwIP source
  1640. has been modified to relax this check.
  1641. - There are some issues when using the IoT examples against Linux
  1642. Kernel 4.12+ which causes the kernel to only work with one 6LoWPAN
  1643. connection. If more than one kit is connected using 6LoWPAN, none of
  1644. the nodes will be accessible.
  1645. - Scheduler has been included in most IoT examples to avoid race
  1646. conditions found when using lwIP stack, more precisely the TCP
  1647. examples.
  1648. The issue was that the TCP client stopped working after about 15
  1649. hours. However, when using mbedTLS, the use of scheduler is not
  1650. possible.
  1651. Therefore, the MQTT client examples might be affected by this issue.
  1652. - The use of security, both with TLS and DTLS, should be treated as
  1653. experimental.
  1654. - MQTT examples cannot be used with commissioning. There is not enough
  1655. RAM to accommodate both TLS and the commissioning service.
  1656. ** NFC **
  1657. - NFC Type 2 and Type 4 Tag HAL modules require using TIMER 4 on
  1658. nRF52832.
  1659. - Some mobile phone apps cannot write Type 4 Tag ("NFC Tools" and
  1660. "TagWriter" v4.1 seem to be okay to use).
  1661. ** USB (experimental) **
  1662. - MSC implementation does not stall when the host requires more bytes
  1663. than are available in the selected descriptor. It is not a problem
  1664. for any tested driver on Windows and Linux, but still violates the
  1665. specification.
  1666. - During high USB traffic, in rare cases, communication might hang or
  1667. the endpoint data might be transferred twice. See PAN 104.
  1668. ** Drivers and libraries **
  1669. - SAADC driver is not handling detection limits 'high' and 'low'
  1670. correctly if SAADC resolution is greater than 10 bits.
  1671. ========================================================================
  1672. nRF5 SDK v14.1.0
  1673. ------------------------
  1674. Release Date: Week 42, 2017
  1675. Highlights:
  1676. - Integrated nRF5 IoT SDK into nRF5 SDK. Subsequent updates of IoT components will be available through nRF5 SDK.
  1677. This release marks IoT SDK v1.0.0. The IoT SDK is no longer prototype.
  1678. - Added Segger Embedded Studio (SES) IDE support.
  1679. - The new SoC nRF52810 supported for the BLE examples using the new S112 SoftDevice and for a few peripheral examples.
  1680. Examples targeting this new device are located in the 'PCA10040E' folder.
  1681. For more details, see 'Developing for nRF52810' in the SDK documentation.
  1682. - Support for the new S112 SoftDevice.
  1683. Added new S112 target for most of the Bluetooth Peripheral examples.
  1684. - The NFC library includes an API change that may need extra attention. See Changes -> NFC BLE Pairing Library.
  1685. The following toolchains/devices have been used for testing and
  1686. verification:
  1687. - SES: SES 3.30
  1688. - ARM: MDK-ARM version 5.18a
  1689. - GCC: GCC ARM Embedded 4.9 2015q3
  1690. - IAR: IAR Workbench 7.80.4
  1691. - Linux: Ubuntu 17.04, Kernel 4.10.0. (for the 6LoWPAN Border Router)
  1692. - J-link: 6.20d
  1693. Supported SoftDevices:
  1694. - S112 v5.1.0-2.alpha
  1695. - S132 v5.0.x
  1696. - S140 v5.0.0-2.alpha
  1697. - S212 v5.0.x
  1698. - S332 v5.0.x
  1699. Supported boards:
  1700. - PCA10040E (nRF52810 emulation on PCA10040)
  1701. - PCA10040
  1702. - PCA10056 (limited support; see the "Scope for the nRF52840 chip" section)
  1703. - Dynastream's D52DK1 (only for ANT examples)
  1704. For other devices and boards, see the SDK documentation, section "Using
  1705. the SDK with other boards".
  1706. *** Scope for the nRF52840 chip
  1707. ********************************
  1708. All examples and libraries for the new chip must be treated as
  1709. experimental.
  1710. Some examples have not been ported to run on nRF52840. Check the
  1711. existing example projects to see which targets are supported.
  1712. The following SDK features are supported on the new nRF52840 chip:
  1713. - IEEE 802.15.4 stack library with an example
  1714. - Most BLE, hardware peripheral, and NFC examples (with some
  1715. exceptions; see the available example projects for details)
  1716. - Peripheral HAL and drivers (both for existing and new peripherals)
  1717. - Cryptography library including CryptoCell CC310 backend
  1718. - NFC Type 2 Tag and Type 4 Tag
  1719. - Secure DFU (only with micro-ecc backend)
  1720. - DTM including support for the new Bluetooth 5 features
  1721. - Gazell
  1722. The following SDK features are not supported on the new nRF52840 chip:
  1723. - ANT
  1724. - Eddystone
  1725. - ESB
  1726. - FreeRTOS
  1727. - IoT components
  1728. - Serialization of the S140 SoftDevice v5.0.0-2.alpha
  1729. *** New features
  1730. *****************
  1731. ** Common **
  1732. - Added support for the new chip nRF52810.
  1733. - New example flash_fstorage added to examples\peripheral\flash_fstorage.
  1734. This example shows how to use the nrf_fstorage library.
  1735. - New example flash_fds added to examples\peripheral\flash_fds.
  1736. This example shows how to use the FDS library.
  1737. - Added support in Segger Embedded Studio and armgcc for editing the sdk_config.h file in the external graphical editor (CMSIS Configuration Wizard).
  1738. ** BLE **
  1739. - Bluetooth Peripheral examples now support the S112 SoftDevice.
  1740. S112 is designed to work with the new SoC nRF52810. Examples targeting this new device are located in folder 'PCA10040E'.
  1741. See SDK documentation for more details.
  1742. - Added support for IPSP (Internet Protocol Support Profile).
  1743. IPSP is now based on production-quality SoftDevice S132 v5.0.0. The IPSP is, also, a qualified profile.
  1744. The IPSP service uses L2CAP Connection Oriented Channels to transfer data between devices.
  1745. - The profile implementation added to components\ble\ble_services.
  1746. - The IPSP Acceptor example added to examples\ble_peripheral\ble_app_ipsp_acceptor.
  1747. - The IPSP Initiator example added to examples\ble_central\ble_app_ipsp_initiator.
  1748. - Added all IoT components, including BLE 6LoWPAN, Nordic's IPv6 Stack, CoAP, MQTT, DFU over TFTP, lwIP port on nRF platform, and others.
  1749. - Changes in these components in comparison to IoT SDK v0.9.0 are described in the Changes section of the release notes.
  1750. - The SDK now supports firmware upgrade over TFTP (IPv6).
  1751. - This mechanism for updating the firmware was earlier available in the IoT SDK, and is now a part of the nRF SDK.
  1752. - New example app_ble_gatts added to examples\ble_central\experimental\ble_app_gatts.
  1753. This application can be used to test the Service Changed indications together with app_ble_gatts_c.
  1754. - Added S332 projects in Heart Rate Sensor and Heart Rate Collector examples.
  1755. ** ANT **
  1756. - Added support for the new SoftDevices: S212 v5.0.x and S332 v5.0.x.
  1757. - Added S332 examples: 'Ant Shared Channels' and 'ANT and BLE Heart Rate Monitor Relay Application'.
  1758. - Added S332 projects in ANT Message Types and ANT Bootloader examples.
  1759. ** NFC **
  1760. - Dynamic NFCID1 configuration in Type 2 and Type 4 Tag libraries.
  1761. ** USB (Experimental) **
  1762. NOTE: The USB implementation is currently experimental and work in progress. Because of this, the code base and APIs
  1763. will change in-between SDK versions and will not necessarily be backwards compatible. This also applies to minor and
  1764. bugfix versions. Migration notes might not be complete for these changes.
  1765. - nrf_drv_usbd:
  1766. - New API function nrf_drv_usbd_ep_dtoggle_clear() implemented.
  1767. - app_usbd:
  1768. - Added a new function app_usbd_sof_timestamp_get() and its configuration APP_USBD_PROVIDE_SOF_TIMESTAMP.
  1769. This function may be used to stamp the timing of the logger messages.
  1770. - Interface selection mechanism provided.
  1771. Currently, every class that contains alternate interface settings requires the class methods
  1772. iface_select, iface_deselect, and iface_selection_get to be implemented.
  1773. No action is required if only the classes provided in the SDK are used.
  1774. - New event implemented:
  1775. APP_USBD_EVT_STATE_CHANGED – called when the state of USB interface is updated.
  1776. ** DTM **
  1777. - Added support for the new SoC nRF52810.
  1778. ** Serialization **
  1779. - Added solution for serialization of the combined BLE and ANT SoftDevice, using the ble_ant_app_hrm example as the use case.
  1780. - Added BLE connectivity (S132) support for nRF52810 (emulated on PCA10040).
  1781. ** Drivers and libraries **
  1782. - Added examples: UART and SAADC for nRF52810.
  1783. Examples targeting this new chip are located in the 'PCA10040E' folder. See SDK documentation for more details.
  1784. - Added the sorted list module (nrf_sortlist).
  1785. ** IOT **
  1786. - Added experimental examples under the "examples\iot" folder and libraries in the "components\iot" folder.
  1787. They show the usage of IPv6 over Bluetooth low energy using IPSP and 6LoWPAN. The demonstrated protocols include:
  1788. - BSD Sockets,
  1789. - UDP and TCP,
  1790. - DTLS and TLS,
  1791. - CoAP and Secure CoAP,
  1792. - MQTT and Secure MQTT,
  1793. - TFTP and LWM2M,
  1794. - Device Firmware Upgrade (DFU) over TFTP,
  1795. - DNS, ICMP, and SNTP.
  1796. *** Changes
  1797. ************
  1798. ** BLE **
  1799. - BLE event handler priorities have changed (BLE_OBSERVER_PRIO).
  1800. - The order of some module BLE event handlers has been changed. This means that compiling
  1801. new sdk_config.h files with old modules might lead to crashes.
  1802. - A new priority has been added, and all BLE applications have been changed to have
  1803. the new priority (NRF_SDH_BLE_OBSERVER_PRIO_LEVELS has been changed from 3 to 4).
  1804. This means that compiling new main files with old sdk_config.h files will not work
  1805. unless NRF_SDH_BLE_OBSERVER_PRIO_LEVELS is set to 4 or more.
  1806. - Peer Manager
  1807. - Added a new event PM_EVT_CONN_SEC_PARAMS_REQ and a new function pm_conn_sec_params_reply()
  1808. to allow setting security parameters for individual security procedures. Calling
  1809. pm_conn_sec_params_reply() is optional.
  1810. - Added a new configuration parameter PM_CENTRAL_ENABLED which removes the pairing functionality
  1811. for the central role when turned off, saving code size.
  1812. - Added a new informational event PM_EVT_SLAVE_SECURITY_REQ. No further Peer Manager action is
  1813. expected from the user in response to this event.
  1814. - Added a new event PM_EVT_FLASH_GARBAGE_COLLECTED which indicates that garbage collection has happened
  1815. in the flash storage, possibly freeing up space for new bonds.
  1816. - Added new function pm_address_resolve() for resolving BLE addresses.
  1817. - NFC BLE Pairing Library
  1818. - Added library support for the PM_EVT_CONN_SEC_PARAMS_REQ event from the Peer Manager.
  1819. NOTE:
  1820. ----------------------------------------
  1821. After the change in Peer Manager priority, this change in API was necessary to properly support all pairing modes.
  1822. Action: Call the nfc_ble_pair_on_pm_params_req() function inside the Peer Manager event handler in response to the
  1823. PM_EVT_CONN_SEC_PARAMS_REQ event:
  1824. case PM_EVT_CONN_SEC_PARAMS_REQ:
  1825. {
  1826. // Send event to the NFC BLE pairing library as it may dynamically alternate
  1827. // security parameters to achieve highest possible security level.
  1828. err_code = nfc_ble_pair_on_pm_params_req(p_evt);
  1829. APP_ERROR_CHECK(err_code);
  1830. } break;
  1831. ------------------------------------------
  1832. - The Heart Rate Application with BLE Pairing Using NFC Pairing Library now requires LESC
  1833. pairing to enable Heart Rate notifications.
  1834. - The LESC example now generates the DH key in the main thread so as not to hold up the
  1835. SoftDevice's BLE event queue.
  1836. ** BLE IoT **
  1837. - Changes from the previous IoT SDK v0.9.0 release:
  1838. - The 6LoWPAN library has been rewritten to adopt the new S132 v5.0.0 SoftDevice providing L2CAP Connection Oriented Channels feature.
  1839. The library is now distributed in source code format and not as a precompiled library.
  1840. - API breakers in many of the components including BLE IPSP, BLE 6LoWPAN, MQTT, nRF lwIP driver port, and background DFU.
  1841. - Deprecated the cloud examples. Cloud services used in them were not suitable any more.
  1842. The protocol features required to connect to a cloud are included and supported.
  1843. - lwIP external component has been updated to version 2.0.2.
  1844. - mbedTLS external component has been updated to version 2.4.2.
  1845. ** NFC **
  1846. - Removed the SoftDevice from the Writable NDEF Message example.
  1847. This example no longer requires the SoftDevice.
  1848. - All NFC libraries now have static configuration in the sdk_config.h file.
  1849. ** USB (experimental) **
  1850. - nrf_drv_usbd:
  1851. - Endpoint transfers are no longer aborted inside the USB RESET handler,
  1852. any transfer is now aborted when an endpoint is disabled.
  1853. - The nrf_drv_usbd_transfer_out_drop() function now does not start any dummy transfer – the endpoint is cleared by
  1854. writing correct values to SIZE.EPOUT registers or backdoor interface for the sample chip.
  1855. - Transfer can be started on a stalled endpoint.
  1856. In the previous version, NRF_ERROR_FORBIDDEN error was returned.
  1857. However, the possibility to stall the endpoint and prepare the answer that will be sent
  1858. after the stall is cleared by the HOST appeared to be widely used in MSC.
  1859. - Function rename: usbd_drv_ep_abort -> nrf_drv_usbd_ep_abort.
  1860. - app_usbd:
  1861. - All endpoints but 0 are disabled when the device is not configured.
  1862. This matches USB requirements.
  1863. - Function app_usbd_active_check provided – this allows to check whether
  1864. there is any active USB traffic or interface is suspended.
  1865. The macros APP_USB_STATE_BASE and APP_USBD_STATE_SUSPENDED_MASK removed.
  1866. The app_usbd_state_t enumeration now provides no information about suspended states.
  1867. Use app_usbd_active_check function whenever the SUSPEND state was checked via app_usbd_core_state_get function.
  1868. - The SETUP event processing cleaned up, normalized, and documented.
  1869. Clear rules for the order in which a class and default handlers are called.
  1870. - Functions app_usbd_core_ep_(handled_)transfer() and app_usbd_core_setup_data_(handled_)transfer()
  1871. unified and replaced by app_usbd_ep_(handled_)transfer functions:
  1872. app_usbd_core_ep_transfer() -> app_usbd_ep_transfer()
  1873. app_usbd_core_ep_handled_transfer() -> app_usbd_ep_handled_transfer()
  1874. app_usbd_core_setup_data_transfer() -> app_usbd_ep_transfer()
  1875. app_usbd_core_setup_data_handled_transfer() -> app_usbd_ep_handled_transfer()
  1876. - Classes implementation:
  1877. - Audio class implementation aligned to use the new alternate interface selection functionality.
  1878. - MSC class implementation error handling totally rebuilt to match the specification.
  1879. Now, it is stable and passes all USB precertification tests (with one small warning to be corrected in the future).
  1880. ** Crypto **
  1881. - Infineon Optiga Trust E communication library and authentication example are now in production quality.
  1882. ** Drivers and libraries **
  1883. - Command Line Interface (CLI) library is now in production quality.
  1884. - Logger (nrf_log) can process logs after panic mode.
  1885. - app_twi modules renamed to nrf_twi_mngr. Translation layer (app_twi.h) kept for backward compatibility.
  1886. *** Bugfixes
  1887. ****************
  1888. ** BLE **
  1889. - Peer Manager:
  1890. - Fixed a bug where a bonded and encrypted link could have invalid peer ID when the
  1891. Central uses a random non-resolvable address.
  1892. - Fixed a bug where the Service Changed state was always reported as "true" when
  1893. changed.
  1894. - Fixed a bug where peer rank was not written during pm_peer_rank_highest() if the
  1895. highest ranked peer was deleted and the peer ID was reused, or if the peer rank
  1896. value was manually changed or deleted.
  1897. - Fixed a bug where pm_conn_sec_status() would incorrectly return false for bonded field when
  1898. called during the PM_EVT_CONN_SEC_SUCCEEDED event for a reconnected bonded peer.
  1899. - Fixed a bug where pm_conn_secure() would return an undocumented error code if called
  1900. multiple times before the first procedure has completed.
  1901. - Fixed the ordering of events from pm_peers_delete(). The PM_EVT_PEERS_DELETE_SUCCEEDED
  1902. will now arrive after all PM_EVT_PEER_DELETE_SUCCEEDED events.
  1903. - Fixed a bug in ble_app_queued_writes where the characteristic would use the BLE UUID type
  1904. instead of a vendor type.
  1905. - Fixed a bug in ble_app_gls where the connection handle would be unassigned before the
  1906. disconnect call is issued (The connection handle is needed for the disconnect call).
  1907. - Fixed a bug in ble_app_gls where the Record Access Control Point indications would not be retried if an indication procedure was already in progress.
  1908. - Fixed a bug in ble_app_ancs_c where a missing C++ guard prevented it from compiling
  1909. correctly using C++.
  1910. - Fixed the LESC example so that it properly handles simultaneous security operations on both
  1911. links (numeric match and DHKEY generation).
  1912. - Fixed a bug in ble_app_ias_c where receiving a "Mild Alert" would print "No Alert" on the log, and "No Alert" would print "Mild Alert".
  1913. - Fixed a bug in ble_app_cgms where the connection handle would be set to invalid before calling sd_ble_gap_disconnect(). This would cause the call to fail and the app would assert.
  1914. - Fixed a bug in ble_app_hids_keyboard and ble_app_hids_mouse where the battery reading done before the connection was secured could cause the app to assert.
  1915. - Fixed a bug in ble_app_multirole_lesc where it would not handle PHY update requests.
  1916. - Fixed a bug that could prevent FDS from working properly when using the new nrf_fstorage_nvmc backend.
  1917. - Fixed a bug that could prevent FDS from working properly when using the nrf_fstorage_sd backend with the SoftDevice disabled.
  1918. - Keil will no longer delete the SoftDevice HEX file if the flash_softdevice target is compiled.
  1919. ** Crypto **
  1920. - Enforced the alignment on nrf_crypto buffers for signature types.
  1921. - Removed an unused file (nrf_crypto.c) that would cause compilation errors for some users.
  1922. ** DFU **
  1923. - Added a workaround for updating SoftDevices with changed size (from SDK 12.x.y -> 14.1.x). See configuration parameter NRF_DFU_WORKAROUND_PRE_SDK_14_1_0_SD_BL_UPDATE.
  1924. ** NFC **
  1925. - Type 4 Tag HAL:
  1926. - Handling of erroneous NFC-A data frames (with parity and CRC errors) has been
  1927. improved.
  1928. ** USB (Experimental) **
  1929. - HAL:
  1930. - Function nrf_usbd_dtoggle_set() is fixed. The previous version was not functional.
  1931. It was working in the examples thanks to the fact that nrf_usbd_dtoggle_get()
  1932. function was called before every nrf_usbd_dtoggle_set().
  1933. ** Drivers and libraries **
  1934. - Fixed a bug where SPI MISO was missing a pulldown.
  1935. Currently, the pulldown status can be configured with the SDK configuration parameter: NRF_SPI_DRV_MISO_PULLUP_CFG.
  1936. - Fixed a bug where the length parameters passed to macro NRF_LOG_HEXDUMP_DEBUG were not calculated correctly.
  1937. - Fixed a bug where a user could receive a "wrong configuration" error during the compilation of SPI driver.
  1938. - Fixed a bug where extern "C" was not terminated correctly in the Logger module.
  1939. - Fixed a bug in the PPI example where Timer 2 was not generating a CC event every odd second.
  1940. - Fixed the header guard in the ble_l2cap_conn.h file.
  1941. - Fixed a bug where nrf_log could crash when heavily loaded.
  1942. - Fixed the pwm_library example which was not working correcly when compiled with highest optimization on IAR.
  1943. ** Serialization **
  1944. - Fixed encoding of ble_gap_data_length_params_t and ble_gap_data_length_limitation_t structures.
  1945. - Fixed encoding of ble_gap_evt_auth_status_t::lesc.
  1946. - Fixed serialization of GATT MTU value
  1947. (https://devzone.nordicsemi.com/question/165596/scanner-doesnt-work-on-nrf52832sdk-14/)
  1948. - Fixed improper configuration of scheduler event size in serialized examples
  1949. (https://devzone.nordicsemi.com/question/166657/serialization-for-s132-5x-triggers-buffer-overflow-in-event-scheduling/)
  1950. *** Known Issues
  1951. ****************
  1952. ** BLE **
  1953. - When working on the emulated nRF52810 target, if you change the optimization level and/or add the logging functionality, the project might not compile or fail at runtime due to not enough flash available for FDS or Peer Manager.
  1954. - All Bluetooth applications not using the nrf_queued_write module will assert when a peer sends a Write request with the opcode 'cancel all operations' (BLE_GATTS_OP_EXEC_WRITE_REQ_CANCEL), after the SoftDevice call to sd_ble_gatts_rw_authorize_reply. This SoftDevice call, for the opcode 'cancel all operations', returns NRF_INVALID_PARAMS if the gatt_status is not BLE_GATT_STATUS_SUCCESS.
  1955. ** BLE IOT **
  1956. - Neighbor discovery module for lwIP requires the on-link flag in the router advertisement to be set in order to create a SLAAC address from the prefix. However, RFC 7668 (https://tools.ietf.org/html/rfc7668) requires this bit to be zero. Therefore, the nd6.c from lwIP source has been modified to relax this check.
  1957. - There are some issues when using the IoT examples against Linux Kernel 4.12+ which causes the kernel to only work with one 6LoWPAN connection. If more than one kit is connected using 6LoWPAN, none of the nodes will be accessible.
  1958. - Scheduler has been included in most IoT examples to avoid race conditions found when using lwIP stack, more precisely the TCP examples.
  1959. The issue was that the TCP client stopped working after about 15 hours. However, when using mbedTLS, the use of scheduler is not possible.
  1960. Therefore, the MQTT client examples might be affected by this issue.
  1961. - The use of security, both with TLS and DTLS, should be treated as experimental.
  1962. - MQTT examples cannot be used with commissioning. There is not enough RAM to accommodate both TLS and the commissioning service.
  1963. ** NFC **
  1964. - NFC Type 2 and Type 4 Tag HAL modules require using TIMER 4 on nRF52832.
  1965. - Some mobile phone apps cannot write Type 4 Tag ("NFC Tools" and "TagWriter" v4.1
  1966. seem to be okay to use).
  1967. ** USB (experimental) **
  1968. - MSC implementation does not stall when the host requires more bytes than are available in the selected descriptor. It is not a problem for any tested driver on Windows and Linux, but still violates the specification.
  1969. - During high USB traffic, in rare cases, communication might hang or the endpoint data might be transferred twice. See PAN 104.
  1970. ** Drivers and libraries **
  1971. - SAADC driver is not handling detection limits 'high' and 'low' correctly if SAADC resolution is greater than 10 bits.
  1972. ========================================================================
  1973. nRF5 SDK v14.1.0-1.alpha
  1974. ------------------------
  1975. Release Date: Week 32, 2017
  1976. Highlights:
  1977. - Integrated what was previously known as nRF5 IoT SDK into nRF5 SDK. Subsequent updates of IoT components will be available through nRF5 SDK.
  1978. - Migrated IoT components to use L2CAP Connection Oriented Channels feature of S132 v5.0.0.
  1979. The following toolchains/devices have been used for testing and
  1980. verification:
  1981. - ARM: MDK-ARM version 5.18a
  1982. - GCC: GCC ARM Embedded 4.9 2015q3
  1983. - IAR: IAR Workbench 7.80.4
  1984. - Linux: Ubuntu 17.04, Kernel 4.10.0.
  1985. Supported SoftDevices:
  1986. - S132 v5.0.x
  1987. - S140 v5.0.0-2.alpha
  1988. - S212 v4.0.x
  1989. Supported boards:
  1990. - PCA10040
  1991. - PCA10056 (limited support; see the "Scope for the nRF52840 chip" section)
  1992. - Dynastream's D52DK1 (only for ANT examples)
  1993. For other devices and boards, see the SDK documentation, section "Using
  1994. the SDK with other boards".
  1995. *** Scope for the nRF52840 chip
  1996. ********************************
  1997. All examples and libraries for the new chip must be treated as
  1998. experimental.
  1999. Some examples have not been ported to run on nRF52840. Check the
  2000. existing example projects to see which targets are supported.
  2001. The following SDK features are supported on the new nRF52840 chip:
  2002. - IEEE 802.15.4 stack library with an example
  2003. - Most BLE, hardware peripheral, and NFC examples (with some
  2004. exceptions; see the available example projects for details)
  2005. - Peripheral HAL and drivers (both for existing and new peripherals)
  2006. - Cryptography library including CryptoCell CC310 backend
  2007. - NFC Type 2 Tag and Type 4 Tag
  2008. - Secure DFU (only with micro-ecc backend)
  2009. - DTM including support for the new Bluetooth 5 features
  2010. The following SDK features are not supported on the new nRF52840 chip:
  2011. - ANT
  2012. - ESB and Gazell
  2013. - FreeRTOS
  2014. - Eddystone
  2015. - Serialization of the S140 SoftDevice v5.0.0-2.alpha
  2016. *** New features
  2017. *****************
  2018. ** BLE **
  2019. - Added support for IPSP (Internet Protocol Support Profile). The IPSP service uses L2CAP Connection Oriented Channels to transfer data between devices.
  2020. - Implementation added to components\ble\ble_services.
  2021. - IPSP Acceptor example added to examples\ble_peripheral\ble_app_ipsp_acceptor.
  2022. - IPSP Initiator example added to examples\ble_central\ble_app_ipsp_initiator.
  2023. ** Drivers and libraries **
  2024. - Added experimental examples under the "examples\iot" folder and libraries in the "components\iot" folder that show the usage of IPv6 over Bluetooth Smart using IPSP and 6LoWPAN. The demonstrated protocols include:
  2025. - BSD Sockets,
  2026. - UDP and TCP,
  2027. - DTLS and TLS,
  2028. - CoAP and Secure CoAP,
  2029. - MQTT and Secure MQTT,
  2030. - TFTP and LWM2M,
  2031. - Device Firmware Upgrade (DFU) over TFTP,
  2032. - DNS, ICMP, and SNTP.
  2033. *** Changes
  2034. ************
  2035. ** BLE IOT **
  2036. - Changes from the previous nRF5 IoT SDK 0.9.0 release
  2037. - The 6LoWPAN library has been rewritten to adopt the new S132 v5.0.0 SoftDevice providing L2CAP Connection Oriented Channels. The library is now distributed in source code format and not as a precompiled library.
  2038. - LWIP external component has been updated to version 2.0.2.
  2039. - mbedTLS external component has been updated to version 2.4.2.
  2040. *** Known Issues
  2041. ****************
  2042. ** Overall **
  2043. - In the UART peripheral example, only a line feed (LF) is output on startup and when resetting the board.
  2044. - Serialized Direct Test Mode does not report RX packet count correctly.
  2045. ** BLE **
  2046. - It is possible that the Peer Manager may return corrupt data when attempting to read the GATT attributes table under some circumstances when FDS CRC checks are enabled.
  2047. - In the Multiperipheral Example, LED 3 will toggle when writing any non-zero value to it. Also, two notifications instead of one are received on the Button Characteristic (0x1524) when pressing Button 1.
  2048. - For all serialized applications, the MTU size (NRF_SDH_BLE_GATT_MAX_MTU_SIZE in sdk_config.h) should be kept at the default level. Changing this value makes the application non-functional as the connectivity application uses static size buffers.
  2049. - Eddystone Beacon Application - LED indication might differ from what is described in documentation under the Testing section.
  2050. ** BLE IOT **
  2051. - Neighbor discovery module for lwIP requires the on-link flag in the router advertisement to be set in order to create a SLAAC address from the prefix. However, RFC 7668 (https://tools.ietf.org/html/rfc7668) requires this bit to be zero. Therefore, the nd6.c from lwIP source has been modified to relax this check.
  2052. - There are some issues using the IoT examples against Linux Kernel 4.12+ which causes the kernel to only work with one 6LoWPAN connection. If more than one kit is connected using 6LoWPAN, none of the nodes will be accessible.
  2053. ** ANT **
  2054. - Most ANT examples do not have the nrf_log backend in the project files, so enabling logging does not have any effect.
  2055. ** NFC **
  2056. - NFC Type 2 and Type 4 Tag HAL modules require using TIMER4 on nRF52832.
  2057. - Some mobile phone apps cannot write Type 4 Tag (the "NFC Tools" app seems to
  2058. be okay to use).
  2059. - BLE peripheral examples with NFC pairing work as expected only with Android 7.1.2.
  2060. ** DFU **
  2061. - Downgrading from nRF5 SDK v14.0.0 to nRF5 SDK v13.0.0 has been observed to cause the v13.0.0 bootloader to corrupt itself (Upgrading works as expected).
  2062. - The S140 SoftDevice currently does not support updating of the bootloader.
  2063. - The CTX pin (P0.07) should be grounded to run the Serial Secure DFU on both nRF52832 and nRF52840 boards.
  2064. - BLE/Serial Secure DFU only supports nrfutil 2.3.0.
  2065. - For nRF52840, a combined SoftDevice and application update on Serial transport fails when using nrfutil 2.3.0. Running a single SoftDevice and application update sequentially works as expected.
  2066. ** USB **
  2067. - USB driver Anomaly 104 solution is very unstable in IAR compilation with high optimization level.
  2068. ========================================================================
  2069. nRF5 SDK v14.0.0
  2070. ------------------------
  2071. Release Date: Week 31, 2017
  2072. Highlights:
  2073. - Added nRF52810 peripheral driver support.
  2074. - Added support for the latest SoftDevice (S132 v5.0.0).
  2075. - Added a new BLE example, Object Transfer Service, that shows how to set up and use the L2CAP Connection Oriented Channels feature of S132 v5.0.0.
  2076. - Updated Direct Test Mode (DTM) to support the new features of Bluetooth 5.
  2077. - Added a new NFC example: ISO-DEP raw mode.
  2078. - Buttonless DFU feature is now in production quality.
  2079. - Added USB CDC as a transport layer for DFU (Experimental, only nRF52840).
  2080. - Added a library and examples that show how to integrate and use the Infineon OPTIGA Trust E hardware security module.
  2081. - Refactored the logging system (nrf_log) to support multiple independent backends and dynamic logs filtering.
  2082. - Refactored the console (nrf_cli). The console can now act as one of the logger backends. Bluetooth UART is now a supported transport (using the ble_nus service).
  2083. The following toolchains/devices have been used for testing and
  2084. verification:
  2085. - ARM: MDK-ARM version 5.18a
  2086. - GCC: GCC ARM Embedded 4.9 2015q3
  2087. - IAR: IAR Workbench 7.80.4
  2088. Supported SoftDevices:
  2089. - S132 v5.0.x
  2090. - S140 v5.0.0-2.alpha
  2091. - S212 v4.0.x
  2092. Supported boards:
  2093. - PCA10040
  2094. - PCA10056 (limited support; see the "Scope for the nRF52840 chip" section)
  2095. - Dynastream's D52DK1 (only for ANT examples)
  2096. For other devices and boards, see the SDK documentation, section "Using
  2097. the SDK with other boards".
  2098. *** Scope for the nRF52840 chip
  2099. ********************************
  2100. All examples and libraries for the new chip must be treated as
  2101. experimental.
  2102. Some examples have not been ported to run on nRF52840. Check the
  2103. existing example projects to see which targets are supported.
  2104. The following SDK features are supported on the new nRF52840 chip:
  2105. - IEEE 802.15.4 stack library with an example
  2106. - Most BLE, hardware peripheral, and NFC examples (with some
  2107. exceptions; see the available example projects for details)
  2108. - Peripheral HAL and drivers (both for existing and new peripherals)
  2109. - Cryptography library including CryptoCell CC310 backend
  2110. - NFC Type 2 Tag and Type 4 Tag
  2111. - Secure DFU (only with micro-ecc backend)
  2112. - DTM including support for the new Bluetooth 5 features
  2113. The following SDK features are not supported on the new nRF52840 chip:
  2114. - ANT
  2115. - ESB and Gazell
  2116. - FreeRTOS
  2117. - Eddystone
  2118. - Serialization of the S140 SoftDevice v5.0.0-2.alpha
  2119. *** New features
  2120. *****************
  2121. ** Common **
  2122. - SoftDevice Handler:
  2123. - Can now register 'state event observers' that are notified when the SoftDevice state changes.
  2124. - Can now register 'request event observers' that are notified when a change of the SoftDevice state is requested.
  2125. - Console:
  2126. - Advanced cooperation with the Logger module (nrf_log). Console can work as a logger backend.
  2127. - Added support for static and dynamic subcommands.
  2128. - Easy-to-use macros for creating commands and subcommands.
  2129. - Added a smart auto-completion feature for commands and subcommands.
  2130. - Added a convenient help handler.
  2131. - Added support for multiline commands.
  2132. - Added support for text edition using the following keys: Left, Right, End, Home, and Insert.
  2133. - Implemented transport layers include: Bluetooth, USB CDC ACM, UART, RTT.
  2134. ** BLE **
  2135. - Added support the for the latest SoftDevice (S132 v5.0.0).
  2136. - Object Transfer Service added as experimental. The Object Transfer service uses L2CAP Connection Oriented Channels to transfer data between devices.
  2137. - Client implementation added to components\ble\ble_services.
  2138. - Server implementation added to components\ble\ble_services.
  2139. - Central client example application added to examples\ble_central\experimental\ble_ots_c.
  2140. - Peripheral server example application added to examples\ble_peripheral\experimental\ble_app_ots.
  2141. - GATT Service client added as experimental. The GATT Service client is used to receive Service Changed indications from the connected peer.
  2142. - Services featured in the Proximity example are now also accessible as stand-alone service examples.
  2143. - Immediate Alert Service client example application added as experimental.
  2144. - Immediate Alert Service server example application added as experimental.
  2145. - Link Loss Service server example application added as experimental.
  2146. - Added BLE transport Command Line Interface. An example "ble_app_cli" can be found in the 'experimental' folder.
  2147. ** NFC **
  2148. - Added a new example showing how to use the NFC Type 4 Tag library in raw ISO-DEP mode: NFC UART Example.
  2149. - Added a new pairing mode in the NFC BLE pairing library that supports OOB pairing in both "Secure Connections" and "Legacy" modes.
  2150. - Added flash support in the Writable NDEF Message Example - after the NDEF update operation, the new tag content is stored in flash.
  2151. ** DFU **
  2152. - Added production quality buttonless bootloader with support for bond sharing.
  2153. - Added configurable inactivity timeout timer that automatically resets the device in case no new commands are received before the timeout triggers. Default value is 120 seconds.
  2154. - Added support for USB CDC as a new transport layer for DFU (Experimental, only for nRF52840).
  2155. ** DTM **
  2156. - Added support for new Bluetooth 5 features LE 2M and LE Coded PHY.
  2157. - Added support for nRF52840 devices.
  2158. ** Drivers and libraries **
  2159. - Added a new example that demonstrates strong cryptographic authentication using the Infineon OPTIGA Trust E hardware security module.
  2160. This example uses the following two new libraries located in the 'external' folder:
  2161. - Infineon OPTIGA Trust E command library that provides a high-level API to access cryptographic and security-related functions.
  2162. - Infineon I2C Protocol Stack library that enables communication with Infineon OPTIGA Trust E and is placed on top of the TWI transaction manager (app_twi).
  2163. - Added Stack guard module that allows for enabling stack violation control.
  2164. - Added Task Manager module, a simple co-operative scheduler.
  2165. - Added fprintf module that can be used for writing C strings.
  2166. - Added Ring Buffer module that provides functions to manage a ring buffer.
  2167. - Added Memory Object module that allows for creating and managing memory object pools.
  2168. *** Changes
  2169. ************
  2170. ** Common **
  2171. - All examples are modified to use the new SoftDevice Handler (nrf_sdh).
  2172. ** BLE **
  2173. - BLE Connection Parameter module supports multiple peripheral links.
  2174. - BLE ATT MTU example uses nrf_cli for the user interface.
  2175. ** NFC **
  2176. - Improved the Type 4 Tag library interoperability (added support for fragmented command APDUs and fixed DID field handling).
  2177. - NDEF record and message definition macros are defined as automatic data (used to be static).
  2178. ** DFU **
  2179. - Serial DFU has been updated to be production quality.
  2180. ** Proprietary **
  2181. - ESB: Added workarounds for several anomalies that were impacting performance for certain addresses.
  2182. - ESB: Added functionality to update certain radio parameters while ESB is running:
  2183. - uint32_t nrf_esb_set_retransmit_delay(uint16_t delay);
  2184. - uint32_t nrf_esb_set_retransmit_count(uint16_t count);
  2185. - uint32_t nrf_esb_set_bitrate(nrf_esb_bitrate_t bitrate);
  2186. - uint32_t nrf_esb_reuse_pid(uint8_t pipe);
  2187. - Gazell: Released in production quality, added workarounds for RADIO anomalies.
  2188. ** Serialization **
  2189. - Added S132 v5.0.0 support. Removed support for S140 5.0.0-2.alpha.
  2190. ** Drivers and libraries **
  2191. - Reworked and improved the fstorage library (now called nrf_fstorage).
  2192. - Now supports operation with no SoftDevice.
  2193. - Now supports operation when the SoftDevice is present and its state changes.
  2194. - Refactored nrf_log to support multiple backends. Each backend has independent, dynamic filtering of logs.
  2195. - Refactored nrf_cli to act as the logger backend. Improved user interface with smart auto-completion and easy commands addition.
  2196. - Updated drivers to work with the nRF52810 device.
  2197. - Updated Flash data storage (FDS).
  2198. - Can now work with no SoftDevice by using the nrf_fstorage_nvmc backend.
  2199. - The 'Chunk' functionality has been removed.
  2200. *** Bugfixes
  2201. ****************
  2202. ** BLE **
  2203. - Fixed a bug where the multiperipheral example would not be able to connect to more than one link.
  2204. ** NFC **
  2205. - Implemented several fixes in Type 2 and Type 4 libraries (fixed nfc_t4t_parameter_set function, removed nRF52 startup code and FPU support from library compilation).
  2206. ** Drivers and libraries **
  2207. - Fixed potential overflow in the watchdog timer (WDT) driver initialization.
  2208. - Fixed wrong header guard in nrf_nvic.h (https://devzone.nordicsemi.com/question/121041/incorrect-header-guard-in-nrf_nvich/).
  2209. - Fixed a bug where nrf_drv_spi_uninit did not clear an event (https://devzone.nordicsemi.com/question/116308/spi-init-triggers-old-nrf_spim_event_end).
  2210. - Implemented a fix for nrf_drv_spi - no pulldown on MISO line.
  2211. *** Known Issues
  2212. ****************
  2213. ** Overall **
  2214. - In the UART peripheral example, only a line feed (LF) is output on startup and when resetting the board.
  2215. - Serialized Direct Test Mode does not report RX packet count correctly.
  2216. ** BLE **
  2217. - It is possible that the Peer Manager may return corrupt data when attempting to read the GATT attributes table under some circumstances when FDS CRC checks are enabled.
  2218. - In the Multiperipheral Example, LED 3 will toggle when writing any non-zero value to it. Also, two notifications instead of one are received on the Button Characteristic (0x1524) when pressing Button 1.
  2219. - For all serialized applications, the MTU size (NRF_SDH_BLE_GATT_MAX_MTU_SIZE in sdk_config.h) should be kept at the default level. Changing this value makes the application non-functional as the connectivity application uses static size buffers.
  2220. - Eddystone Beacon Application - LED indication might differ from what is described in documentation under the Testing section.
  2221. ** ANT **
  2222. - Most ANT examples do not have the nrf_log backend in the project files, so enabling logging does not have any effect.
  2223. ** NFC **
  2224. - NFC Type 2 and Type 4 Tag HAL modules require using TIMER4 on nRF52832.
  2225. - Some mobile phone apps cannot write Type 4 Tag (the "NFC Tools" app seems to
  2226. be okay to use).
  2227. - BLE peripheral examples with NFC pairing work as expected only with Android 7.1.2.
  2228. ** DFU **
  2229. - Downgrading from nRF5 SDK v14.0.0 to nRF5 SDK v13.0.0 has been observed to cause the v13.0.0 bootloader to corrupt itself (Upgrading works as expected).
  2230. - The S140 SoftDevice currently does not support updating of the bootloader.
  2231. - The CTX pin (P0.07) should be grounded to run the Serial Secure DFU on both nRF52832 and nRF52840 boards.
  2232. - BLE/Serial Secure DFU only supports nrfutil 2.3.0.
  2233. - For nRF52840, a combined SoftDevice and application update on Serial transport fails when using nrfutil 2.3.0. Running a single SoftDevice and application update sequentially works as expected.
  2234. ** USB **
  2235. - USB driver Anomaly 104 solution is very unstable in IAR compilation with high optimization level.
  2236. ========================================================================
  2237. nRF5 SDK v13.1.0
  2238. ------------------------
  2239. Release Date: Week 27, 2017
  2240. Highlights:
  2241. - Added support for the SoftDevice S332 v4.0.x.
  2242. - Added serialization solution for the combined BLE and ANT SoftDevice.
  2243. The following toolchains/devices have been used for testing and
  2244. verification:
  2245. - ARM: MDK-ARM version 5.18a
  2246. - GCC: GCC ARM Embedded 4.9 2015q3
  2247. - IAR: IAR Workbench 7.80.4
  2248. Supported SoftDevices:
  2249. - S132 v4.0.x
  2250. - S140 v5.0.0-2.alpha
  2251. - S212 v4.0.x
  2252. - S332 v4.0.x
  2253. Supported boards:
  2254. - PCA10040
  2255. - PCA10056 (limited support; see the "Scope for the nRF52840 chip" section)
  2256. - Dynastream's D52DK1 (only for ANT examples)
  2257. For other devices and boards, see the SDK documentation, section "Using
  2258. the SDK with other boards".
  2259. *** Scope for the nRF52840 chip
  2260. ********************************
  2261. All examples and libraries for the new chip must be treated as
  2262. experimental.
  2263. Some examples have not been ported to run on nRF52840. Check the
  2264. existing example projects to see which targets are supported.
  2265. The following SDK features are supported on the new nRF52840 chip:
  2266. - New 804.15.4 stack library with an example
  2267. - Most BLE, hardware peripheral, and NFC examples (with some
  2268. exceptions; see the available example projects for details)
  2269. - Peripheral HAL and drivers (both for existing and new peripherals)
  2270. - Cryptography library including CryptoCell CC310 backend
  2271. - NFC Type 2 Tag and Type 4 Tag
  2272. - Secure DFU (only with micro-ecc backend)
  2273. - Serialization of the S140 SoftDevice v5.0.0-2.alpha with UART
  2274. The following SDK features are not supported on the new nRF52840 chip yet:
  2275. - ANT
  2276. - DTM
  2277. - ESB and Gazell
  2278. - FreeRTOS
  2279. - Eddystone
  2280. *** New features
  2281. *****************
  2282. ** BLE **
  2283. - Added S332 projects in Heart Rate Sensor and Heart Rate Collector examples.
  2284. ** ANT **
  2285. - Added support the for the new SoftDevice S332 v4.0.x.
  2286. - Added S332 examples: 'Ant Shared Channels' and 'ANT and BLE Heart Rate Monitor Relay Application'.
  2287. - Added an S332 project for the D52DK1 Development Kit in the ANT Message Types example.
  2288. ** Serialization **
  2289. - Added a solution for serialization of combined BLE and ANT SoftDevice
  2290. using the ble_ant_app_hrm example as the use case.
  2291. *** Changes
  2292. ************
  2293. ** ANT **
  2294. - Removed the nrf_sd_def.h file. It will be now distributed just like the rest of SoftDevice header files through
  2295. https://www.thisisant.com
  2296. *** Bugfixes
  2297. *************
  2298. ** Drivers and libraries **
  2299. - Fixed a potential overflow in watchdog timer (WDT) driver initialization.
  2300. *** Known Issues
  2301. *****************
  2302. ** Overall **
  2303. - Updating the MDK requires to manually copy the header and linker files
  2304. into the SDK folder (ARM Keil uVision 4, IAR Workbench, ARMGCC).
  2305. - When uploading an application to an nRF52 IC using nrfjprog, you must
  2306. provide the "--reset/-r" argument or powercycle the board.
  2307. ** BLE **
  2308. - Some examples might have excessively verbose logging.
  2309. - Examples that use the Peer Manager might assert when deleting bonds,
  2310. because advertising is started twice.
  2311. - In the Proximity Application, writing "High Alert" to the AlertLevel
  2312. characteristic of the Link Loss Service does not trigger a high alert
  2313. when the link is lost.
  2314. - When an Android device is used as a peripheral, it sends slave
  2315. security request with the MITM bit set. The central applications in
  2316. the SDK will reject the security request (Pairing Failed) because
  2317. they do not support MITM.
  2318. - Advertisement intervals in the Eddystone Beacon Application are not
  2319. verified. Clients must ensure that the configured advertisement
  2320. interval is within the valid range. Note that EID/eTLM configurations
  2321. might require advertisement intervals to be larger than the default value.
  2322. ** NFC **
  2323. - NFC Type 2 and Type 4 Tag HAL modules require using TIMER4 on nRF52832.
  2324. - Type 2 Tag on nRF52840 chips might fail unpredictably.
  2325. - Some mobile phone apps cannot write Type 4 Tag ("NFC Tool" seems to
  2326. be okay to use).
  2327. ========================================================================
  2328. nRF5 SDK v13.0.0
  2329. ------------------------
  2330. Release Date: Week 11, 2017
  2331. Highlights:
  2332. - Implemented a new license scheme for the SDK distribution. See the
  2333. documentation folder for details.
  2334. - Updated the Bluetooth and ANT examples to support the newest
  2335. SoftDevices S132 v4.0.2, S140 v5.0.0-2.alpha, and S212 v4.0.0.
  2336. - Included a new 804.15.4 stack library with an example.
  2337. - Released the Eddystone example and the NFC Type 4 Tag stack in
  2338. production quality.
  2339. - Added workarounds for the nRF52832 anomaly 109 (DMA: DMA access
  2340. transfers might be corrupted).
  2341. - Added serialization of the ANT S212 SoftDevice v4.0.0 (experimental).
  2342. - Added an example showing secure DFU with UART transport layer.
  2343. - This release does not support nRF51.
  2344. - This release does not support the S332 SoftDevice.
  2345. The following toolchains/devices have been used for testing and
  2346. verification:
  2347. - ARM: MDK-ARM version 5.18a
  2348. - GCC: GCC ARM Embedded 4.9 2015q3
  2349. - IAR: IAR Workbench 7.60.2
  2350. Supported SoftDevices:
  2351. - S132 v4.0.2
  2352. - S140 v5.0.0-2.alpha
  2353. - S212 v4.0.0
  2354. Supported boards:
  2355. - PCA10040
  2356. - PCA10056 (limited support; see the "Scope for the nRF52840 chip" section)
  2357. - Dynastream's D52DK1 (only for ANT examples)
  2358. For other devices and boards, see the SDK documentation, section "Using
  2359. the SDK with other boards".
  2360. *** Scope for the nRF52840 chip
  2361. ********************************
  2362. All examples and libraries for the new chip must be treated as
  2363. experimental.
  2364. Some examples have not been ported to run on nRF52840. Check the
  2365. existing example projects to see which targets are supported.
  2366. The following SDK features are supported on the new nRF52840 chip:
  2367. - New 804.15.4 stack library with an example
  2368. - Most BLE, hardware peripheral, and NFC examples (with some
  2369. exceptions; see the available example projects for details)
  2370. - Peripheral HAL and drivers (both for existing and new peripherals)
  2371. - Cryptography library including CryptoCell CC310 backend
  2372. - NFC Type 2 Tag and Type 4 Tag
  2373. - Secure DFU (only with micro-ecc backend)
  2374. - Serialization of the S140 SoftDevice v5.0.0-2.alpha with UART
  2375. The following SDK features are not supported on the new nRF52840 chip yet:
  2376. - ANT
  2377. - DTM
  2378. - ESB and Gazell
  2379. - FreeRTOS
  2380. - Eddystone
  2381. *** New features
  2382. *****************
  2383. ** BLE **
  2384. - Added an experimental BLE Multiperipheral example
  2385. (experimental_ble_app_multiperipheral) that uses the proprietary LED
  2386. Button Service to show how a peripheral device can manage connections
  2387. with multiple peers simultaneously.
  2388. ** ANT **
  2389. - Added serialization for S212 v4.0.0. With this solution, an ANT
  2390. application can run on any architecture, without the SoftDevice. All
  2391. SoftDevice API calls are transported via UART to an nRF52 device that
  2392. runs the ANT connectivity application (examples\connectivity\experimental_ant)
  2393. and the S212 SoftDevice. The ANT I/O example demonstrates the new
  2394. serialization solution (examples\ant\ant_io_demo, see targets:
  2395. "ser_s212_uart"). Note that the serialized solution does not support
  2396. the new API calls added in S212 v4.0.0.
  2397. The SDK folders with the ANT serialization implementation are not
  2398. marked as experimental, because the paths would be too long.
  2399. - Added a new ANT Frequency Agility example
  2400. (examples\ant\experimental\ant_frequency_agility).
  2401. ** 804.15.4 **
  2402. - Added a full 802.15.4 stack implementation to the SDK. The library
  2403. (components\experimental_802_15_4) is available only for nRF52840
  2404. devices. The MAC layer API is located in
  2405. components\experimental_802_15_4\api\MAC. The example application is
  2406. located in examples\802_15_4\experimental\wireless_uart.
  2407. - Added an experimental Wireless UART example (wireless_uart) that shows
  2408. how to use the new 804.15.4 stack.
  2409. ** NFC **
  2410. - Added two experimental examples that show NFC pairing (BLE Pairing
  2411. Using NFC - experimental_ble_nfc_pairing_reference and
  2412. ble_nfc_pairing_reference_c).
  2413. ** DFU **
  2414. - Added support for serial/UART and an example for a secure DFU
  2415. bootloader using UART (experimental).
  2416. - Implemented SoftDevice major version checks for certain upgrade types.
  2417. - Implemented a delayed reset after the DFU: After a SoftDevice,
  2418. bootloader, or SoftDevice and bootloader update, a timer will start.
  2419. If no new update is initiated before its expiration, the device will
  2420. look for a valid application and launch it.
  2421. - Added a new set of error codes (extended error codes) that the DFU
  2422. target may send as a response to the DFU controller to convey the
  2423. reason for a failure.
  2424. ** Serialization **
  2425. - Added serialization support for the ANT S212 SoftDevice v4.0.0
  2426. (experimental). See the ANT section for details.
  2427. ** Drivers and libraries **
  2428. - Added workarounds for the nRF52832 anomaly 109 (DMA: DMA access
  2429. transfers might be corrupted). Affected drivers: PWM, SPIM, TWIM,
  2430. SPIS, and TWIS.
  2431. - Added several new libraries:
  2432. - Command line interface (CLI) library: Console that supports
  2433. various serial interfaces (UART, RTT, USB CDC ACM).
  2434. See the usage example in examples/peripheral/cli.
  2435. - GFX library: Graphics library that supports simple operations like
  2436. drawing circles, lines, rectangles, or bitmaps and printing
  2437. strings. GFX uses an LCD driver interface. Two implementations for
  2438. popular TFTs have been added (ILI9341, ST7735).
  2439. See the usage example in examples/peripheral/gfx.
  2440. - Serial port library: Module for handling UART communication. It
  2441. supports multibyte transfers, time-outs, and buffering of data.
  2442. The module is a replacement for app_uart.
  2443. See the usage example in examples/peripheral/serial.
  2444. - SPI transaction manager: Module for managing thread-safe access to
  2445. the SPI driver. The module supports scheduling transactions that
  2446. consist of multiple transfers. See the usage example in
  2447. examples/peripheral/spi_master_using_nrf_spi_mngr.
  2448. - Error code to string converter (STRERR): Module for converting
  2449. error codes to strings. The module is used by nrf_log.
  2450. - Added two drivers for TFT LCDs: ILI9341 and ST7735.
  2451. *** Changes
  2452. ************
  2453. ** BLE **
  2454. - Updated all BLE examples to use the nRF Connect PC application
  2455. (replacing Master Control Panel).
  2456. - Modified all BLE example to have logging enabled by default, to make
  2457. testing and debugging the SDK examples more consistent. Note that
  2458. logging greatly increases power consumption. Therefore, logging should
  2459. be disabled in any final product or when performing power profiling
  2460. tests.
  2461. - Updated the Eddystone example so that it can be released in production
  2462. quality.
  2463. - Updated all BLE examples to support the newest SoftDevices S132 v4.0.2
  2464. and S140 v5.0.0-2.alpha.
  2465. - Updated the Peer Manager to handle more than eight links.
  2466. - Updated all BLE examples to use the GATT module.
  2467. - Updated the GATT module to handle Data Length update related events.
  2468. - Improved the Alert Notification example application to more clearly
  2469. convey the Alert Notification Service. Increased the verbosity on UART
  2470. instead of relying only on the LEDs.
  2471. - Removed the experimental label from the Running Speed and Cadence
  2472. central example application.
  2473. - Cleaned up the use of RX/TX in the Nordic UART Service (NUS) to match
  2474. the terminology used in external tools (nRF Connect, nRF Toolbox).
  2475. - Modified the BLE UART example to enable the use of long ATT_MTU.
  2476. ** DFU **
  2477. - Updated the experimental BLE Buttonless DFU Service to use the
  2478. RAM-retention register to enter bootloader mode instead of flash
  2479. access.
  2480. - Updated the experimental BLE Buttonless DFU Service to use the
  2481. Secure-DFU UUID (16-bit proprietary Nordic UUID).
  2482. - Updated the BLE Buttonless DFU characteristic to use a new
  2483. vendor-specific base UUID (0x8EC9xxxx-F315-4F60-9FB8-838830DAEA50).
  2484. The UUID changed to 0x8EC90003-F315-4F60-9FB8-838830DAEA50.
  2485. - Changed the BLE Buttonless DFU characteristic from notification to
  2486. indication.
  2487. - Changed the minimum version requirement for nrfutil to v2.2.0.
  2488. ** NFC **
  2489. - Updated the NFC Type 4 Tag library so that it can be released in
  2490. production quality. The library was moved to components\nfc\t4t_lib.
  2491. The example that shows the Type 4 Tag library is located in
  2492. examples\nfc\writable_ndef_msg.
  2493. - Updated the BLE Heart Rate Collector Example with NFC Pairing and the
  2494. HID Keyboard Application with BLE pairing using NFC to use the NFC BLE
  2495. Pairing library (nfc_pair_lib).
  2496. - Updated the BSP NFC Module so that it can be used without restrictions
  2497. together with Type 2 and Type 4 Tag libraries.
  2498. ** Serialization **
  2499. - Updated serialization to support the latest BLE SoftDevices S132
  2500. v4.0.2 and S140 v5.0.0-2.alpha.
  2501. ** Drivers and libraries **
  2502. - Updated the implementation of app_uart.
  2503. - Moved the static configuration of app_timer to sdk_config.h.
  2504. - Updated several hardware drivers:
  2505. - nrf_drv_power: Added initial support for USB plugging with SoftDevice.
  2506. - nrf_drv_pwm: Allowed for playbacks to be started using PPI.
  2507. - nrf_drv_spi: Added an abort function.
  2508. - nrf_drv_twi: Added a function for checking if the driver is busy.
  2509. - nrf_drv_uart: Added a function for checking the receiver state.
  2510. - nrf_drv_csense: Extended the driver to perform measurements using
  2511. SAADC. COMP is still supported, but it is not recommended for
  2512. production (see anomaly 84).
  2513. *** Bugfixes
  2514. *************
  2515. - Fixed several bugs in secure DFU to prevent handling invalid updates.
  2516. - Updated secure DFU on nRF52840 to utilize the entire 1 MB of flash, up
  2517. from the old (unintended) limitation of 512 KB.
  2518. - Fixed a bug where ble_app_hrs_rscs_relay would not dispatch
  2519. advertising time-out events to the advertising module.
  2520. - Fixed a bug where ble_app_uart would not handle the disconnected event
  2521. if it was received before a service discovery was completed.
  2522. - Fixed a bug where ble_app_pwr_profiling did not initialize the button
  2523. module.
  2524. - Fixed a bug where ble_app_proximity would not always trigger "High
  2525. Alert" on the AlertLevel characteristic when the link was lost.
  2526. - Fixed a bug where ble_app_uart would be blocked if app_uart_put
  2527. returned an error.
  2528. - Fixed a bug where Peer Manager corrupted FDS data in flash.
  2529. - Fixed a bug where FDS records updated with fds_record_update() would
  2530. not be garbage collected.
  2531. - Fixed an unaligned access error in FDS when using certain compiler
  2532. options in GCC.
  2533. - Fixed a bug in FDS where a missing swap page went undetected.
  2534. - Fixed the tick update method in FreeRTOS.
  2535. - Fixed a bug where wake-on-field functionality would not work with Type
  2536. 2 and Type 4 Tag libraries.
  2537. - Several bugfixes and improvements on drivers:
  2538. - nrf_drv_timer: Fixed a bug in NRF_TIMER_IS_BIT_WIDTH_VALID.
  2539. - nrf_drv_saadc: Fixed a bug where nrf_drv_saadc_calibrate_offset()
  2540. enabled a wrong interrupt.
  2541. - nrf_drv_pwm: Fixed inaccurate description of the
  2542. NRF_DRV_PWM_FLAG_LOOP flag.
  2543. *** Known Issues
  2544. *****************
  2545. ** BLE **
  2546. - If the S132 SoftDevice is configured with 0 Peripheral roles and 0
  2547. Central roles, sd_ble_enable() may corrupt up to 8 bytes above the
  2548. returned app_ram_base. For applications having such a configuration,
  2549. set the application RAM start to 8 bytes or more above the returned
  2550. app_ram_base.
  2551. ** DFU **
  2552. - The S140 SoftDevice currently does not support updating the bootloader.
  2553. - Secure DFU (serial):
  2554. - nrfutil currently does not support sending combined zip images
  2555. (SD+APP, SD+BL+APP, BL+SD). Use individually generated zip-images
  2556. instead.
  2557. - The device will not automatically boot the application after a
  2558. SoftDevice update. Reset the device manually.
  2559. - Secure DFU (BLE): Updates of SD+BL+APP may time out between the SD+BL
  2560. and APP stage on certain Android phones. Investigate the time-out
  2561. value with respect to your mobile app and consider increasing it.
  2562. ------------------------------------------------------------------------
  2563. nRF5 SDK v13.0.0-1.alpha
  2564. ------------------------
  2565. Release Date: Week 50, 2016
  2566. This release is an alpha release and should ONLY be used for the
  2567. following purposes:
  2568. - Exploring and trying out the new Bluetooth 5 features available
  2569. with the new SoftDevices.
  2570. - Trying out new features on the nRF52840 chip.
  2571. Highlights:
  2572. - Updated the BLE ATT_MTU Throughput Example (ble_app_att_mtu_throughput)
  2573. to showcase a PHY data rate of 2 Ms/s and coded PHY for long-range
  2574. transmission.
  2575. - Updated the cryptography library to include a CryptoCell CC310
  2576. backend (API changes compared to SDK 12.2.0).
  2577. - Updated the BLE LE Secure Connections Multirole Example
  2578. (ble_app_multirole_lesc) to use the CryptoCell CC310 backend of the
  2579. cryptography library (available only for nRF52840).
  2580. - Added serialization of the new SoftDevices S132 v5.0.0-1.alpha and
  2581. S140 v5.0.0-1.alpha. Added USB CDC ACM serial as transport layer.
  2582. - Dropped support for nRF51 Series devices.
  2583. - Dropped support for RTX.
  2584. The following toolchains/devices have been used for testing and
  2585. verification:
  2586. - ARM: MDK-ARM version 5.18a
  2587. - GCC: GCC ARM Embedded 4.9 2015q3
  2588. - IAR: IAR Workbench 7.30.4
  2589. Supported SoftDevices:
  2590. - S140 v5.0.0-1.alpha
  2591. - S132 v5.0.0-1.alpha
  2592. - S212 v2.0.0
  2593. - S332 v2.0.0
  2594. Supported boards:
  2595. - PCA10040
  2596. - PCA10056 (limited support; see the "Scope for the nRF52840" section)
  2597. - Dynastream's N5DK1 (only for ANT examples)
  2598. For other devices and boards, see the SDK documentation, section "Using
  2599. the SDK with other boards".
  2600. *** Scope for the nRF52840 chip
  2601. ********************************
  2602. All examples and libraries for the new chip must be treated as
  2603. experimental.
  2604. Some examples have not been ported to run on nRF52840. Check the
  2605. existing example projects to see which targets are supported.
  2606. The following SDK features are supported on the new nRF52840 chip:
  2607. - Most BLE, hardware peripheral, and NFC examples (with some
  2608. exceptions; see the available example projects for details)
  2609. - Peripheral HAL and drivers (both for existing and new peripherals)
  2610. - Cryptography library including CryptoCell CC310 backend
  2611. - NFC Type 2 Tag and Type 4 Tag
  2612. - Secure DFU (only with micro-ecc backend)
  2613. - Serialization of the SoftDevices S132 v5.0.0-1.alpha and
  2614. S140 v5.0.0-1.alpha with UART and USB CDC ACM transport layers
  2615. The following SDK features are not supported on the new nRF52840 chip yet:
  2616. - ANT
  2617. - DTM
  2618. - ESB and Gazell
  2619. - FreeRTOS
  2620. - Eddystone
  2621. *** New features
  2622. *****************
  2623. ** BLE **
  2624. - Updated the BLE ATT_MTU Throughput Example to demonstrate the use of
  2625. Bluetooth 5 features:
  2626. - PHY data rate of 2 Ms/s (nRF52832 and nRF52840)
  2627. - Coded PHY for long-range transmission (nRF52840 only)
  2628. ** NFC **
  2629. - Added a layer of abstraction for NFC OOB pairing, the NFC BLE Pairing
  2630. Library (nfc_ble_pair_lib).
  2631. - Added a central and a peripheral NFC BLE example that use the new NFC
  2632. BLE Pairing Library:
  2633. - Heart Rate Collector Application with NFC pairing (ble_app_hrs_nfc_c,
  2634. to be used with the Adafruit shield)
  2635. - BLE Peripheral example: Heart Rate Application with BLE pairing
  2636. using NFC Pairing Library (ble_app_hrs_nfc_pairing_lib)
  2637. ** Cryptography **
  2638. - Added a backend to the cryptography library that supports the ARM
  2639. CryptoCell 310 hardware-accelerated cryptography engine.
  2640. - Updated the LE Secure Connections Multirole Example to showcase how
  2641. to use the cryptography library with the CryptoCell CC310 backend
  2642. (nRF52840 only).
  2643. ** Serialization **
  2644. - Added serialization of the new SoftDevices S132 v5.0.0-1.alpha and
  2645. S140 v5.0.0-1.alpha.
  2646. - Added the transport layer USB CDC ACM (nRF52840 only).
  2647. *** Changes
  2648. ************
  2649. ** Drivers and libraries **
  2650. - Refactored the RNG driver.
  2651. ** BLE **
  2652. - Fixed a bug in the Multi-link Example where disconnecting all central
  2653. links would disable the app_button module.
  2654. - Fixed two bugs in the Buttonless DFU Template Application:
  2655. - The example now has writable set on the Control Point characteristic.
  2656. - The example is now using the correct part of the flash, enabling
  2657. flashing when a bootloader is present.
  2658. - Fixed a bug in the ANCS Client Application where NULL-termination of a
  2659. received attribute could happen outside its allocated buffer.
  2660. - Fixed a bug in the ANCS Client Application where using RFU attribute
  2661. IDs could cause illegal memory access.
  2662. - Modified the LE Secure Connections Multirole Example to prevent
  2663. creation of a second link to the same peer simultaneously.
  2664. ** NFC **
  2665. - Fixed a bug in NFC Type 2 and Type 4 Tag HAL where NFC would hang when
  2666. the chip was woken up from SYSTEM_OFF and HFXO was started before NFCT
  2667. requested it.
  2668. ** Serialization **
  2669. - UART and HCI UART transports have been optimized to better utilize
  2670. EasyDMA.
  2671. *** Known Issues
  2672. ****************
  2673. ** Overall **
  2674. - Updating the MDK requires to manually copy the header and linker files
  2675. into the SDK folder (ARM Keil uVision 4, IAR Workbench, ARMGCC).
  2676. - When uploading an application to an nRF52 IC using nrfjprog, you must
  2677. provide the "--reset/-r" argument or powercycle the board.
  2678. ** BLE **
  2679. - Some examples might have excessively verbose logging.
  2680. - Examples that use the Peer Manager might assert when deleting bonds,
  2681. because advertising is started twice.
  2682. - In the Proximity Application, writing "High Alert" to the AlertLevel
  2683. characteristic of the Link Loss Service does not trigger a high alert
  2684. when the link is lost.
  2685. - When an Android device is used as a peripheral, it sends slave
  2686. security request with the MITM bit set. The central applications in
  2687. the SDK will reject the security request (Pairing Failed) because
  2688. they do not support MITM.
  2689. - Advertisement intervals in the Eddystone Beacon Application are not
  2690. verified. Clients must ensure that the configured advertisement
  2691. interval is within the valid range. Note that EID/eTLM configurations
  2692. might require advertisement intervals larger than the default value.
  2693. ** NFC **
  2694. - NFC Type 2 and Type 4 Tag HAL modules require using TIMER4 on nRF52832.
  2695. - Type 2 Tag on nRF52840 chips might fail unpredictably.
  2696. - Some mobile phone apps cannot write Type 4 Tag ("NFC Tool" seems to
  2697. be okay to use).
  2698. ========================================================================
  2699. nRF5 SDK v12.2.0
  2700. ----------------
  2701. Release Date: Week 49, 2016
  2702. Highlights:
  2703. - Added an NFC Type 4 Tag stack (experimental).
  2704. - Replaced the existing Eddystone example with a new implementation.
  2705. - Added experimental support for the new nRF52840 chip. See the section
  2706. "Scope for the nRF52840" for information about which SDK features are
  2707. supported on the new chip.
  2708. The following toolchains/devices have been used for testing and
  2709. verification:
  2710. - ARM: MDK-ARM version 5.18a
  2711. - GCC: GCC ARM Embedded 4.9 2015q3
  2712. - IAR: IAR Workbench 7.30.4
  2713. Supported SoftDevices:
  2714. - S130 v2.0.1
  2715. - S132 v3.0.0
  2716. - S212 v2.0.0
  2717. - S332 v2.0.0
  2718. Supported boards:
  2719. - PCA10028
  2720. - PCA10031
  2721. - PCA10040
  2722. - PCA10056 (limited support; see the "Scope for the nRF52840" section)
  2723. - PCA20006 (only for beacon examples)
  2724. - Dynastream's N5DK1 (only for ANT examples)
  2725. For other devices and boards, see the SDK documentation, section "Using
  2726. the SDK with other boards".
  2727. *** Scope for the nRF52840 chip
  2728. ********************************
  2729. Support for the new development board PCA10056 has been added.
  2730. All examples and libraries for the new chip should be treated as
  2731. experimental.
  2732. The following SDK features are supported on the new nRF52840 chip:
  2733. - Most BLE, hardware peripheral, and NFC examples (with some
  2734. exceptions; see the available example projects for details)
  2735. - Peripheral HAL and drivers (both for existing and new peripherals)
  2736. - Library supporting CC310 CryptoCell
  2737. - NFC Type 2 Tag and Type 4 Tag
  2738. The following SDK features are not supported on the new nRF52840 chip:
  2739. - ANT
  2740. - Secure DFU
  2741. - Serialization
  2742. - DTM
  2743. - ESB and Gazell
  2744. - RTX and FreeRTOS
  2745. - Eddystone
  2746. *** New features
  2747. *****************
  2748. ** Drivers and libraries **
  2749. - Added a SysTick driver.
  2750. - Added a queue module (nrf_queue).
  2751. - Added a memory block allocator module (nrf_balloc).
  2752. - Added an atomic operations module (nrf_atomic, nRF52 Series only).
  2753. - Added an atomic FIFO module (app_atfifo, nRF52 Series only).
  2754. - Added a power management module (nrf_pwr_mgmt).
  2755. - Added an asynchronous SD card driver using SPI.
  2756. - Ported fatfs for nRF5 (external library).
  2757. *** nRF52840 specific updates ***
  2758. - Added a USB device stack and the following USB classes: HID, MSC,
  2759. CDC ACM, Audio.
  2760. - Added a QSPI driver for external memories.
  2761. - Added support for 2 UART instances.
  2762. - Added support for 4 PWM instances.
  2763. - Added support for more GPIO (48 pins).
  2764. ** BLE **
  2765. - Integrated the Eddystone project from GitHub, replacing the existing
  2766. Eddystone Beacon example. The new implementation follows the
  2767. specification at https://github.com/google/eddystone (commit 97225a9
  2768. from Sep 28, 2016). The new Eddystone library and example supports both
  2769. nRF51 and nRF52 (experimental).
  2770. - Added an example to demonstrate ATT throughput with long ATT_MTU and
  2771. DLE (experimental).
  2772. - Added a GATT module that encapsulates the long ATT_MTU feature.
  2773. - Extended the Apple Notification Center Service (ANCS) Service module
  2774. and example application:
  2775. - Added 'notification actions' that depend on the app (for example,
  2776. marking a new email as read or dialing up a missed call).
  2777. - Added functionality to retrieve app attributes, which allows to
  2778. get the name of the app that provided a notification.
  2779. - Extended the Continuous Glucose Monitoring Service (CGMS) example
  2780. application to handle greater, lesser, or equal filtering for the
  2781. Record Access control point.
  2782. - Updated the BLE examples to no longer attempt to re-initiate bonding
  2783. if encryption fails due to a missing or wrong key.
  2784. ** NFC **
  2785. - Added support for NFC Type 4 Tag with both read and write NDEF
  2786. access (experimental).
  2787. - Added support for raw ISO-DEP transmission protocol mode.
  2788. - Added Type 4 Tag support to the Adafruit Tag Reader example.
  2789. ** Cryptography **
  2790. - Added support for the ARM CryptoCell 310 hardware-accelerated
  2791. cryptography engine.
  2792. - Added examples to show how to use the hardware-accelerated
  2793. cryptography functionality.
  2794. *** Changes
  2795. ************
  2796. ** Overall **
  2797. - Changed the default interrupt priorities for nRF52 to be the same as
  2798. the SoftDevice event priority.
  2799. - Prefixed error codes with "NRF_".
  2800. - Fixed a bug in the clock driver where the driver was failing to handle
  2801. two requests coming from the same source.
  2802. - Removed nRF52 support for RTX. RTX is now supported on nRF51 chips
  2803. only.
  2804. - Updated the example Secure DFU images. They are now created with the
  2805. debug flag enabled.
  2806. - Modified the SoftDevice header files nrf_soc.h and nrf_nvic.h to
  2807. support PCA10056 (nRF52840).
  2808. - Split up the files located in the examples\bsp folder to new locations:
  2809. components\libraries\bsp and components\boards.
  2810. ** Drivers and libraries **
  2811. - Updated the RNG driver so that it supports the SoftDevice being
  2812. enabled and disabled. Removed the function nrf_drv_rng_pool_capacity().
  2813. - Changed the API for function app_button_is_pushed() (located in
  2814. app_button.h).
  2815. - Extended the app_gpiote API to support more than 32 pins. Removed
  2816. unimplemented functions from the API.
  2817. - Extended the nrf_gpio API to support more than 32 pins. Removed
  2818. functions that referred to 8-bit ports (for example,
  2819. nrf_gpio_port_read).
  2820. - Removed the function nrf_drv_adc_gpio_to_ain() from the
  2821. nrf_drv_adc API.
  2822. - Removed the function nrf_drv_comp_gpio_to_ain() from the
  2823. nrf_drv_comp API.
  2824. - Removed the function nrf_drv_saadc_gpio_to_ain() from the
  2825. nrf_drv_saadc API.
  2826. ** BLE **
  2827. - Fixed an issue that would cause some central examples to fail when
  2828. restarting scanning using a whitelist.
  2829. - Updated the Peer Manager modules to return NRF_ERROR_STORAGE_FULL
  2830. instead of NRF_ERROR_NO_MEM.
  2831. - The field "peer_id" in the Peer Manager structure
  2832. "pm_peer_data_bonding_t" has been renamed to "peer_ble_id".
  2833. - Fixed an issue where the Database Discovery Module would not
  2834. re-initialize properly upon successive discoveries.
  2835. - Fixed an issue where the Database Discovery Module would fail to
  2836. discover the extended properties descriptor and the characteristic
  2837. user description descriptors.
  2838. - Fixed an issue where the Apple Notification Center Service (ANCS)
  2839. example application could crash if the connecting iPhone disconnected
  2840. immediately after connecting.
  2841. ** NFC **
  2842. - Modified the Adafruit NFC Shield library to support reading Type 2 and
  2843. Type 4 Tags.
  2844. - Improved performance of the Adafruit library in Type 2 Tag reader mode
  2845. (faster read).
  2846. - Added LE Secure Connections OOB values encoding in ble_pair_msg.
  2847. - Enabled dynamic update of the TK value in ble_pair_msg.
  2848. *** Known Issues
  2849. ****************
  2850. ** Overall **
  2851. - Updating the MDK requires to manually copy the header and linker files
  2852. into the SDK folder (ARM Keil uVision 4, IAR Workbench, ARMGCC).
  2853. - When uploading an application to an nRF52 IC using nrfjprog, you must
  2854. provide the "--reset/-r" argument or powercycle the board.
  2855. - RTX is not supported on nRF52 chips.
  2856. ** BLE **
  2857. - Some examples might have excessively verbose logging.
  2858. - In the Proximity Application, writing "High Alert" to the AlertLevel
  2859. characteristic of the Link Loss Service does not trigger a high alert
  2860. when the link is lost.
  2861. - When an Android device is used as a peripheral, it sends slave
  2862. security request with the MITM bit set. The central applications in
  2863. the SDK will reject the security request (Pairing Failed) because
  2864. they do not support MITM.
  2865. - Eddystone Beacon Application:
  2866. - Advertisement intervals are not verified. Clients must ensure that
  2867. the configured advertisement interval is within the valid range.
  2868. Note that EID/eTLM configurations might require advertisement
  2869. intervals larger than the default value.
  2870. - Caution: On nRF51 devices, eTLM calculation takes around 500 ms
  2871. and is performed once per EID slot in the same interrupt level
  2872. priority as the 'Unlock' functionality. Therefore, if multiple EID
  2873. slots and an eTLM slot are configured, the client might not be able
  2874. to unlock a beacon that has an eTLM slot and uses the default
  2875. advertisement interval. To resolve this issue, increase the
  2876. advertisement interval.
  2877. - Buttonless DFU Template Application (experimental):
  2878. - The project setup of the example is wrong and does not fit into the
  2879. available space below the DFU bootloader. To fix this problem,
  2880. change the IROM1 size from 0x61000 to 0x59000. In addition, comment
  2881. out the code section that reserves a codepage at 0x7E000 for MBR
  2882. parameters. For details, see
  2883. https://devzone.nordicsemi.com/question/100609/sdk-12-bootloader-erased-after-programming/
  2884. - To switch to DFU mode, you must write to the DFU control point.
  2885. However, this characteristic is set as read only. Add the following
  2886. code line to enable the write property:
  2887. char_md.char_props.write = 1;
  2888. For details, see
  2889. https://devzone.nordicsemi.com/question/93414/sdk12-ble_app_buttonless_dfu/#95079
  2890. ** NFC **
  2891. - NFC Type 2 and Type 4 Tag HAL modules require using TIMER4 on nRF52832.
  2892. - Type 2 Tag on nRF52840 chips might fail unpredictably.
  2893. - Some mobile phone apps cannot write Type 4 Tag ("NFC Tool" seems to be
  2894. okay to use).
  2895. ========================================================================
  2896. nRF5 SDK v12.1.0
  2897. ----------------
  2898. Release Date: Week 40, 2016
  2899. Highlights:
  2900. - Added serialization of the S132 SoftDevice v3.0.0. Serialization of S130 is now deprecated.
  2901. - Included the latest MDK v8.9.0 with a crucial workaround for nRF52832 Errata 108:
  2902. http://infocenter.nordicsemi.com/topic/com.nordic.infocenter.nrf52832.Rev1.errata/anomaly_832_108.html
  2903. The following toolchains/devices have been used for testing and verification:
  2904. - ARM: MDK-ARM version 5.18a
  2905. - GCC: GCC ARM Embedded 4.9 2015q3
  2906. - IAR: IAR Workbench 7.30.4
  2907. Supported SoftDevices:
  2908. - S130 v2.0.1
  2909. - S132 v3.0.0
  2910. - S212 v2.0.0
  2911. - S332 v2.0.0
  2912. Supported IC revisions:
  2913. - nRF51422/nRF51822 IC revision 3
  2914. - nRF52832 IC revision 1
  2915. Supported boards:
  2916. - PCA10028
  2917. - PCA10031
  2918. - PCA10040
  2919. - PCA20006 (only for beacon examples)
  2920. - Dynastream's D52 Starter Kit (only for ANT examples)
  2921. - Arduino Primo v2.1 (board header only)
  2922. For other devices and boards, see the SDK documentation, section "Using the SDK with other boards".
  2923. *** New features
  2924. ****************
  2925. ** Overall **
  2926. - Serialization of the S132 SoftDevice v3.0.
  2927. *** Changes
  2928. ***********
  2929. ** Overall **
  2930. - Includes the latest Nordic MDK v8.9.0.
  2931. - Small documentation updates.
  2932. *** Known issues
  2933. ****************
  2934. ** Overall **
  2935. - Updating the MDK requires to manually copy the header and linker files
  2936. into the SDK folder (ARM Keil uVision 4, IAR Workbench, ARMGCC).
  2937. - When uploading an application to an nRF52 IC using nrfjprog, you must
  2938. provide the "--reset/-r" argument or powercycle the board.
  2939. ** BLE **
  2940. - When performing service discoveries after a reconnect,
  2941. ble_db_discovery might fail to initialize. Refer to this link for a fix:
  2942. https://devzone.nordicsemi.com/question/92452/nrf52-ble_db_discovery-failed-to-initialize-correctly-when-repeats-the-service-discovery/
  2943. - The "UART/Serial Port Emulation over BLE" (ble_app_uart) example
  2944. does not compile with nrf_log enabled (missing nrf_log sources)
  2945. - Some examples might have excessively verbose logging.
  2946. - Performing pairing without bonding will cause examples to assert. To
  2947. fix this, make sure the call to pm_peer_rank_highest() during
  2948. PM_EVT_CONN_SEC_SUCCEEDED happens only when the procedure is
  2949. PM_LINK_SECURED_PROCEDURE_BONDING.
  2950. - When an Android device is used as a peripheral, it sends slave
  2951. security request with the MITM bit set. The central applications in
  2952. the SDK will reject the security request (Pairing Failed) because
  2953. they do not support MITM.
  2954. ** Secure DFU **
  2955. - nRF Toolbox for iPhone:
  2956. - When an error occurs, nRF Toolbox does not automatically
  2957. disconnect. You must therefore reset the board manually to
  2958. disconnect before you can connect again.
  2959. - It is not possible to abort a transfer when the device connection
  2960. is lost.
  2961. - On resumption, nRF Toolbox does not call execute, which makes it
  2962. impossible to resume a transfer.
  2963. - When transferring a combined SoftDevice and bootloader image, the
  2964. bootloader might not be updated.
  2965. - On nRF52 devices, the DFU operation is sometimes reported as
  2966. completed, even though the device is not updated.
  2967. ** NFC **
  2968. - NFC Type 2 Tag HAL requires using TIMER4 on nRF52832.
  2969. ------------------------------------------------------------------------
  2970. nRF5 SDK v12.0.0
  2971. ----------------
  2972. Release Date: Week 35, 2016
  2973. Highlights:
  2974. - Added a secure DFU bootloader example and bootloader libraries.
  2975. This is an improved implementation that replaces the legacy DFU.
  2976. - Added an implementation of the Continuous Glucose Monitoring
  2977. Service (CGMS).
  2978. - Added support for the S132 SoftDevice v3.0.0.
  2979. - Added support for the S212 and S332 SoftDevices v2.0.0.
  2980. - Added a capacitive sensor driver and library (csense).
  2981. - Added Gazell support on nRF52 (experimental).
  2982. - Added new SDK configuration header files to manage static
  2983. configuration of an application.
  2984. - Overhauled the log subsystem.
  2985. - Removed support for the PCA10036 board and nRF52832 Engineering A
  2986. and B MCUs.
  2987. - Included a critical MDK update (v8.7.1).
  2988. - Added support for the CMSIS DSP library.
  2989. - Missing feature: Serialization of the latest S132 SoftDevice v3.0.0
  2990. API (work in progress).
  2991. The following toolchains/devices have been used for testing and
  2992. verification:
  2993. - ARM: MDK-ARM version 5.18a
  2994. - GCC: GCC ARM Embedded 4.9 2015q3
  2995. - IAR: IAR Workbench 7.30.4
  2996. Supported SoftDevices:
  2997. - S130 v2.0.1
  2998. - S132 v3.0.0
  2999. - S212 v2.0.0
  3000. - S332 v2.0.0
  3001. Supported IC revisions:
  3002. - nRF51422/nRF51822 IC revision 3
  3003. - nRF52832 IC revision 1
  3004. - nRF52832 Engineering C
  3005. Supported boards:
  3006. - PCA10028
  3007. - PCA10031
  3008. - PCA10040
  3009. - PCA20006 (only for beacon examples)
  3010. - Dynastream's D52 Starter Kit (only for ANT examples)
  3011. - Arduino Primo v2.1 (board header only)
  3012. For other devices and boards see the SDK documentation, section
  3013. "Using the SDK with other boards".
  3014. *** New features
  3015. ****************
  3016. ** Overall **
  3017. - Added a secure DFU bootloader example and bootloader libraries. This
  3018. is an improved implementation that replaces the legacy DFU. The
  3019. example includes support for cryptographically signed operations.
  3020. ** Drivers and libraries **
  3021. - Added a capacitive sensor driver and library for nRF51 and nRF52
  3022. based systems.
  3023. - Added an app_timer profiler to get maximum operation queue usage.
  3024. - Reduced RAM usage in app_timer and changed the app_timer_cnt_get
  3025. function (see the migration note in the Timer library documentation).
  3026. - Added pull-up configuration to the TWIS driver.
  3027. - Added an FFT FPU example with the CMSIS DSP library.
  3028. ** BLE **
  3029. - Added a Continuous Glucose Monitoring Service (CGMS) implementation,
  3030. including an example application (experimental).
  3031. - Added a Bond Management Service (BMS) implementation, including an
  3032. example application (experimental).
  3033. - Expanded APIs to support Privacy 1.2.
  3034. - Updated Direct Test Mode (DTM), including support for nRF52.
  3035. ** ANT **
  3036. - Added new examples: Continuous Waveform Mode, High Duty Search and
  3037. Background Scanning, and Time Synchronization.
  3038. ** NFC **
  3039. - Added an NFC BSP module (bsp_nfc) and an example showing the usage of
  3040. NFC as a wakeup source.
  3041. ** Proprietary **
  3042. - Gazell: Ported examples and library to nRF52 (experimental).
  3043. *** Changes
  3044. ***********
  3045. ** Overall **
  3046. - Added a new log system across all SDK sources. Replaced printf and
  3047. the old log system.
  3048. ** Drivers and libraries **
  3049. - Unified the configuration subsystem and moved configuration to one
  3050. file (sdk_config.h).
  3051. - Changed the NRF51 and NRF52 ifdefs in drivers to peripheral related
  3052. ifdefs.
  3053. - Improved the PWM library (app_pwm): SET/CLEAR tasks instead of TOGGLE
  3054. in nRF52.
  3055. - Updated the TWI driver to de-configure GPIO pins in the uninit
  3056. function (power-saving change).
  3057. - Unified field names in HAL.
  3058. - FreeRTOS fixes:
  3059. - Fixed invalid assertion.
  3060. - Improved tickless mode.
  3061. - Simplified the TWI sensor example.
  3062. - Added PCA10031 support to the led_softblink and low_power_pwm
  3063. examples.
  3064. ** Serialization **
  3065. - No support.
  3066. ** BLE **
  3067. - Removed the Device Manager modules. All example applications now use
  3068. the Peer Manager.
  3069. - Removed the pstorage module. All example applications now use the
  3070. fstorage module.
  3071. ** ANT **
  3072. - Moved the following examples from experimental to production level:
  3073. - Advanced Burst
  3074. - Asynchronous Transmitter
  3075. - Continuous Scanning Controller
  3076. - Debug
  3077. - Message Types
  3078. - Relay
  3079. - Search Sharing
  3080. - Search Uplink
  3081. ** NFC **
  3082. - Moved BLE OOB Pairing Data encoding to a separate module
  3083. (nfc_ble_oob_advdata).
  3084. - Modified nfc_t2t_lib and hal_nfc_t2t to conform with Nordic's
  3085. coding standard.
  3086. *** Fixed issues
  3087. ****************
  3088. ** Drivers and libraries **
  3089. - APP_FIFO: Fixed an issue with app_fifo_write writing one byte even
  3090. though it was requested to write zero bytes.
  3091. - APP_BUTTON: Memory improvements.
  3092. - GPIOTE: Fixed handler pointer checking.
  3093. - PDM: Fixed high power usage and unexpected restart after calling
  3094. nrf_drv_pdm_stop().
  3095. - QDEC: Fixed QDEC un-initialization sequence.
  3096. - SAADC: Added missing channel calibration.
  3097. - SAADC: Fixed high power consumption and burst mode (oversampling
  3098. without external trigger).
  3099. - SPI: Fixed STOPPED interrupt handling.
  3100. - SPIS: Fixed registers in get function of the amount of TX and RX done.
  3101. - TWI: Fixed misc sending bytes and misleading error codes.
  3102. - TWI: Added pin toggling functionality configuration during init (pin
  3103. toggling sequence during init may cause issues with some devices).
  3104. - UART: Fixed data corruption at 1 Mbaud and race conditions.
  3105. - DELAY: Fixed nrf_delay_us(0) case.
  3106. ** BLE **
  3107. - Fixed an issue where BLE example applications could assert if Button
  3108. 2 was held to start advertising while in a connection.
  3109. - Fixed several minor documentation mistakes that could make testing
  3110. the BLE examples less clear.
  3111. ** ANT **
  3112. - Fixed channel type setup in the following examples: Broadcast, Multi
  3113. Channels, and Continuous Scanning Controller.
  3114. ** NFC **
  3115. - NDEF Text record: Fixed UTF selection.
  3116. - NDEF message size calculation.
  3117. *** Known issues
  3118. ****************
  3119. ** Overall **
  3120. - Updating the MDK requires to manually copy the header and linker files
  3121. into the SDK folder (ARM Keil uVision 4, IAR Workbench, ARMGCC).
  3122. - When uploading an application to an nRF52 IC using nrfjprog, you must
  3123. provide the "--reset/-r" argument or powercycle the board.
  3124. ** BLE **
  3125. - Some examples might have excessively verbose logging.
  3126. - Performing pairing without bonding will cause examples to assert. To
  3127. fix this, make sure the call to pm_peer_rank_highest() during
  3128. PM_EVT_CONN_SEC_SUCCEEDED happens only when the procedure is
  3129. PM_LINK_SECURED_PROCEDURE_BONDING.
  3130. - When an Android device is used as a peripheral, it sends slave
  3131. security request with the MITM bit set. The central applications in
  3132. the SDK will reject the security request (Pairing Failed) because
  3133. they do not support MITM.
  3134. ** Secure DFU **
  3135. - nRF Toolbox for iPhone:
  3136. - When an error occurs, nRF Toolbox does not automatically
  3137. disconnect. You must therefore reset the board manually to
  3138. disconnect before you can connect again.
  3139. - It is not possible to abort a transfer when the device connection
  3140. is lost.
  3141. - On resumption, nRF Toolbox does not call execute, which makes it
  3142. impossible to resume a transfer.
  3143. - When transferring a combined SoftDevice and bootloader image, the
  3144. bootloader might not be updated.
  3145. - On nRF52 devices, the DFU operation is sometimes reported as
  3146. completed, even though the device is not updated.
  3147. ** NFC **
  3148. - NFC Type 2 Tag HAL requires using TIMER4 on nRF52832.
  3149. ========================================================================
  3150. nRF5 SDK v11.0.0
  3151. ----------------
  3152. Release date: Week 10, 2016
  3153. Highlights:
  3154. - Combined SDK supporting both the nRF51 and the nRF52 Series
  3155. - Moved Peer Manager out of experimental
  3156. - Moved NFC libraries out of experimental and added support for low
  3157. power mode
  3158. - Added drivers for all nRF52 peripherals
  3159. - Added serialization of the S132 and S130 SoftDevices
  3160. - Added support for SoftDevices S130 v2.0.0, S132 v2.0.0, S212 v0.9.x,
  3161. and S332 v0.9.x
  3162. - Replaced the Enhanced ShockBurst library with a new implementation
  3163. (based on µESB)
  3164. - Included a critical MDK update (v8.5.0)
  3165. - Removed support for CMSIS Packs
  3166. The following toolchains/devices have been used for testing and
  3167. verification:
  3168. - ARM: MDK-ARM version 5.16a
  3169. - GCC: GCC ARM Embedded 4.9 2015q1
  3170. - IAR: IAR Workbench 7.30.4
  3171. Supported SoftDevices:
  3172. - S130 v2.0.0
  3173. - S132 v2.0.0
  3174. - S212 v0.9.x
  3175. - S332 v0.9.x
  3176. Supported IC revisions:
  3177. - nRF51 IC revision 3
  3178. - nRF52 IC revision 1
  3179. - nRF52 Engineering C
  3180. - nRF52 Engineering A and Engineering B (see Compatibility)
  3181. Supported boards:
  3182. - PCA10028
  3183. - PCA10031
  3184. - PCA10036 (see Compatibility)
  3185. - PCA10040 (see Compatibility)
  3186. - PCA20006 (only for beacon examples)
  3187. For other devices and boards, see the SDK documentation, section
  3188. "Using the SDK with other boards".
  3189. Compatibility:
  3190. The SoftDevices that are supported in this SDK are not compatible
  3191. out-of-the-box with nRF52 Engineering A and Engineering B (the
  3192. IC revisions present on all versions of PCA10036 and on PCA10040
  3193. v0.9.0).
  3194. However, you can use the latest SoftDevices on Engineering A and B
  3195. nRF52 chips for development purposes if you implement the
  3196. workaround for anomaly 73 (TIMER: Event lost, see
  3197. http://infocenter.nordicsemi.com/topic/com.nordic.infocenter.nrf52/dita/nrf52/errata.html).
  3198. *** New features
  3199. ****************
  3200. ** Drivers and libraries **
  3201. - Added a COMP driver (nRF52 only)
  3202. ** BLE **
  3203. - Extended the Peer Manager functionality:
  3204. - Added an additional data unit (Peer Rank) that can be used for
  3205. tracking which bonds are most (and least) recently used
  3206. - Added support for LE Secure Connections in Peer Manager
  3207. (experimental)
  3208. - Added an example application for LE Secure Connections (experimental,
  3209. support for Keil5, IAR, and GCC only)
  3210. ** ANT **
  3211. - Added new examples (experimental):
  3212. - Advanced Burst
  3213. - Asynchronous Transmitter
  3214. - Continuous Scanning Controller
  3215. - Debug Demo
  3216. - IO Demo
  3217. - Message Types
  3218. - Search Sharing
  3219. - Search Uplink
  3220. - ANT OTA bootloader application now uses the SoCLibrary API to perform
  3221. NVIC operations instead of direct operations
  3222. - Added multiprotocol examples for the S332 SoftDevice:
  3223. - Heart Rate Monitor Relay Application
  3224. - Shared Channels (experimental)
  3225. ** Serialization **
  3226. - Added serialization of the S130 and S132 v2.0.0 SoftDevices
  3227. ** NFC **
  3228. - Added a generic NDEF message parser that can parse NDEF messages to
  3229. the format that is used by the generic NFC NDEF message builder
  3230. - Added a module and example for creating NDEF text records
  3231. - Added and modified NFC pairing examples (experimental):
  3232. - HID Keyboard Application with BLE pairing using NFC (new)
  3233. - Heart Rate Application with BLE pairing using NFC (improved user
  3234. experience)
  3235. ** Proprietary **
  3236. - Added a Low Power Transmitter/Receiver example for ESB
  3237. *** Changes
  3238. ***********
  3239. ** Overall **
  3240. - Support for CMSIS Packs has been removed. The SDK is delivered as zip
  3241. file only.
  3242. ** Drivers and libraries **
  3243. - The MSB and LSB macros have been renamed to MSB_32 and LSB_32. Code
  3244. using these macros should be changed to use either the 16- or the
  3245. 32-bit variant.
  3246. ** BLE **
  3247. - Multi-instance handling of Service client modules has been greatly
  3248. improved. The client examples now handle service discovery in the main
  3249. application context. The main application context must manage which
  3250. client instance belongs to which connection link.
  3251. - The Multi-link Example has been modified to demonstrate multiple
  3252. client instances in a better way.
  3253. - The ble_app_multilink_peripheral example has been removed.
  3254. ble_app_blinky now acts as the peripheral for ble_app_multilink_central.
  3255. - Heart Rate Application with RTX: Support for nRF52 has been removed.
  3256. - The Peer Manager is no longer experimental.
  3257. - The following BLE examples now use Peer Manager:
  3258. - Central:
  3259. Running Speed and Cadence Collector (ble_app_rscs_c)
  3260. - Central and Peripheral:
  3261. BLE Relay (ble_app_hrs_rscs_relay)
  3262. BLE LE Secure Connections Multirole (ble_app_multirole_lesc)
  3263. - Peripheral:
  3264. Alert Notification (ble_app_alert_notification)
  3265. Proximity (ble_app_proximity)
  3266. Glucose (ble_app_gls)
  3267. HID Keyboard Application with BLE pairing using NFC (experimental_ble_app_hids_keyboard_pairing_nfc)
  3268. - The behavior of Peer Manager and Device Manager has changed to reject
  3269. pairing requests from already bonded peer centrals.
  3270. - Several BLE peripheral examples now support the S332 SoftDevice.
  3271. - Minor bugfixes in DFU.
  3272. ** ANT **
  3273. - The ANT bootloader was aligned to MBR version 2.0.0.
  3274. - The following ANT examples now support the S332 SoftDevice
  3275. (experimental):
  3276. - ANT Bootloader/DFU
  3277. - Message Types
  3278. ** NFC **
  3279. - The Adafruit Tag Reader Example has been extended to show added NDEF
  3280. parsing functionality.
  3281. - The NFC Type 2 Tag HAL was improved with a workaround for supporting
  3282. low power mode.
  3283. ** Proprietary **
  3284. - A new implementation of the Enhanced ShockBurst (ESB) protocol
  3285. supporting both nRF51 and nRF52 has been added.
  3286. *** Fixed issues
  3287. ****************
  3288. ** Drivers and libraries **
  3289. - GPIOTE: Fixed the problem of lost events in low-accuracy sense toggle
  3290. mode
  3291. - SAADC: Added functionality to use one AIN with multiple channels
  3292. - UART: Fixed a glitch on TX pin when initializing the driver
  3293. - UART: Fixed the problem that TX bytes were sent in wrong order in
  3294. app_uart_fifo
  3295. ** BLE **
  3296. - Removed a vulnerability in Peer Manager and Device Manager that would
  3297. allow malicious attackers to overwrite the bonding information of a
  3298. bonded device
  3299. ** ANT **
  3300. - Fixed the handling of send-until-success request types in the ANT
  3301. request controller
  3302. - Fixed an ant_evt_t structure member alignment bug
  3303. ** NFC **
  3304. - Fixed the NFC examples to work when the UART logger is enabled
  3305. - Fixed a buffer leakage bug in the module for creating
  3306. application/vnd.bluetooth.le.oob records
  3307. *** Known issues
  3308. ****************
  3309. ** Drivers and libraries **
  3310. - Using the NVIC API directly and not through a SoftDevice causes
  3311. problems, especially when NVIC_EnableIRQ or NVIC_DisableIRQ are called
  3312. from critical sections.
  3313. ** BLE **
  3314. - All BLE examples have been tested only on PCA10028 and PCA10040.
  3315. - BLE Examples that use pairing are incompatible with examples in SDK
  3316. version 6.1 and earlier that do not use pairing.
  3317. ** ANT **
  3318. - Previous versions of the ANT DFU example are incompatible with the ANT
  3319. S212/S332 SoftDevices version 0.9.x.
  3320. ** NFC **
  3321. - NFCT requires using TIMER4 on nRF52832.
  3322. ** FPU **
  3323. - When the FPU is in use, it triggers the FPU_IRQn interrupt when one of
  3324. the six exception flags (IDC, IXC, UFC, OFC, DZC, IOC) is set.
  3325. The FPU interrupt will always set the pending flag (even if the
  3326. interrupt is not enabled), irrespective of whether the user is
  3327. interested in the exception bit.
  3328. The pending flag then prevents the SoftDevice from going into low
  3329. power mode when sd_app_evt_wait() is called.
  3330. Therefore, always clear the exception bits and the pending interrupt
  3331. before calling sd_app_evt_wait(). See the code below for an example
  3332. implementation.
  3333. FPU exception bit definition:
  3334. http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0553a/BABBFJEC.html
  3335. Example code:
  3336. {
  3337. // Set bit 7 and bits 4..0 in the mask to one (0x ...00 1001 1111)
  3338. #define FPU_EXCEPTION_MASK 0x0000009F
  3339. ...
  3340. /* Clear exceptions and PendingIRQ from the FPU unit */
  3341. __set_FPSCR(__get_FPSCR() & ~(FPU_EXCEPTION_MASK));
  3342. (void) __get_FPSCR();
  3343. NVIC_ClearPendingIRQ(FPU_IRQn);
  3344. /* Call SoftDevice Wait For event */
  3345. error_code = sd_app_evt_wait();
  3346. }
  3347. ========================================================================
  3348. nRF5 SDK v11.0.0-2.alpha
  3349. ------------------------
  3350. Release date: Week 51, 2015
  3351. Highlights:
  3352. - Common SDK supporting both the nRF51 and the nRF52 Series
  3353. - Added support for SoftDevices S130 v2.0.0, S132 v2.0.0, and S212 v0.5.1
  3354. - Permanently removed support for SoftDevices S110 and S120
  3355. - Temporarily removed support for ANTBLE SoftDevices
  3356. - Enhanced Peer Manager and FDS modules
  3357. - Enhanced DFU module
  3358. - Configured nrf_log to use UART by default
  3359. - Added HardFault handler
  3360. - Added drivers for nRF52 peripherals: nrf_drv_i2s, nrf_drv_pdm,
  3361. nrf_drv_pwm
  3362. - Enhanced drivers to work for both nRF51 and nRF52: nrf_drv_twi,
  3363. nrf_drv_spi, nrf_drv_uart, nrf_drv_timer, nrf_drv_ppi, nrf_drv_clock
  3364. - Added FreeRTOS and RTX support for nRF52
  3365. - Added NFC modules: Type 2 Tag parser, generic NDEF message builder,
  3366. new NFC records and messages
  3367. - Added support for Adafruit PN532 NFC shield to provide NFC Forum
  3368. Device (Poller) functionality
  3369. - Improved support for NFC: enhanced NFC Type 2 Tag library and
  3370. Connection Handover module
  3371. The following toolchains/devices have been used for testing and
  3372. verification:
  3373. - ARM: MDK-ARM version 5.16a
  3374. - GCC: GCC ARM Embedded 4.9 2015q1
  3375. - IAR: IAR Workbench 7.30.4
  3376. - Windows XP SP3 32-bit
  3377. - Windows 7 SP1 64-bit
  3378. - Windows 8.1
  3379. Supported SoftDevices:
  3380. - S130 v2.0.0-7.alpha
  3381. - S132 v2.0.0-7.alpha
  3382. - S210 v5.0.0
  3383. - S212 v0.5.1.alpha
  3384. Supported boards:
  3385. - PCA10028
  3386. - PCA10031
  3387. - PCA10036
  3388. - PCA10040
  3389. - PCA20006 (only for beacon examples)
  3390. - Dynastream's N5DK1 (only for ANT examples)
  3391. For other devices and boards, see the SDK documentation, section "Using
  3392. the SDK with other boards".
  3393. Drivers and libraries:
  3394. New features:
  3395. - Added driver and example for PWM peripheral (nrf_drv_pwm).
  3396. - Added driver and example for I2S peripheral (nrf_drv_i2s).
  3397. - Added driver for PDM peripheral (nrf_drv_pdm).
  3398. - Enhanced nrf_drv_twi and nrf_drv_spi to support AUTOLOG and
  3399. triggering transfers from PPI.
  3400. - Added double buffering of RX buffers to nrf_drv_uart.
  3401. - Extended nrf_drv_timer to support more compare channels and low
  3402. power counter mode in nRF52.
  3403. - Extended nrf_drv_ppi API to support forks.
  3404. - Added support for FreeRTOS and RTX on nRF52.
  3405. - Simplified SPI and SPIS examples.
  3406. Fixed issues:
  3407. - In certain cases, FreeRTOS on nRF51 kept interrupts disabled after
  3408. context switch (see https://devzone.nordicsemi.com/question/57993/tickless-freertos-in-sdk-100-app_uart).
  3409. Known issues:
  3410. - The FreeRTOS nRF51 port has a wrong assertion during system startup.
  3411. If you are using assertions, you can safely ignore it. Alternatively,
  3412. comment out line 188 in port_cmsis.c.
  3413. Changes:
  3414. - Enhanced nrf_drv_clock driver (asynchronous clock management).
  3415. Serialization:
  3416. - Work in progress; not included in this release.
  3417. ANT:
  3418. New features:
  3419. - Added support for the S212 SoftDevice v0.5.1.alpha.
  3420. - Added ANT DFU support for nRF52.
  3421. Known issues:
  3422. - When using the ANT OTA Updater v1.2. for nRF52, there is a flash
  3423. memory address limitation of 0x40000 (256 KB) for the application.
  3424. BLE:
  3425. Changes:
  3426. - All BLE examples have been tested only on PCA10028 and PCA10040.
  3427. - The S13x SoftDevice v2.0.0-7.alpha is configurable, which leads to a
  3428. variable RAM setup:
  3429. - Added a macro to the softdevice_handler module to check the RAM
  3430. configuration against the SoftDevice parameters.
  3431. - Added a wrapper function for the sd_enable function to the
  3432. softdevice_handler module, which can output the required RAM
  3433. start address if the one passed to the SoftDevice is not
  3434. correct.
  3435. - DFU:
  3436. - Added an experimental nRF52 bootloader.
  3437. - Updated the SoftDevice initalization according to API changes in
  3438. S132 v2.0.0-7.alpha.
  3439. - Updated to MBR version v2.0.0-1 alpha.
  3440. - Introduced nrf_log as default logging module (UART) in all BLE
  3441. examples.
  3442. - Peer Manager & FDS have received incremental improvements and bug
  3443. fixes.
  3444. Known issues:
  3445. - In the HRS/RSCS Relay example, button presses do not have any effect.
  3446. - ble_app_cts_c requires an increased UART_TX_BUF_SIZE. The size can be
  3447. set in nrf_log.c.
  3448. - DTM for nRF52 does not support long packets according to the
  3449. Bluetooth 4.2 specification.
  3450. - Inconsistent behavior in DFU with devices running Android v6.0.1.
  3451. - The BLE and serial DFU examples do not work when using CMSIS Packs.
  3452. Use the zip version of the SDK instead.
  3453. NFC:
  3454. New features:
  3455. - Added a Type 2 Tag parser.
  3456. - Added a generic NFC NDEF message builder (the builder is used to
  3457. implement all specific records and messages).
  3458. - Added modules to create Windows LaunchApp records, Android
  3459. Application Records, and common application launch messages. Added
  3460. an associated example.
  3461. - Ported the Adafruit NFC library for the Adafruit PN532 Shield, which
  3462. provides NFC Forum Device capabilities. Added an associated example
  3463. to read tags.
  3464. - Added modules to create application/vnd.bluetooth.le.oob records,
  3465. application/vnd.bluetooth.ep.oob records, ac records, Hs records,
  3466. and BLE pairing messages.
  3467. Changes:
  3468. - Improved the NFC Type 2 Tag library: tested and power-optimized the
  3469. library and enhanced it with RTT logger capability.
  3470. - Re-implemented NFC URI record and message. Refactored the associated
  3471. example.
  3472. - Enhanced and re-implemented the NFC Connection Handover solution
  3473. (pairing using NFC).
  3474. - Re-implemented the BLE NFC pairing example.
  3475. Known issues:
  3476. - NFC examples do not work when UART logger is enabled.
  3477. ========================================================================
  3478. nRF51 SDK v10.0.0
  3479. -----------------
  3480. Release date: Week 46, 2015
  3481. Highlights:
  3482. - New BLE Peer Manager (experimental), replacement for the BLE Device
  3483. Manager
  3484. - FreeRTOS support
  3485. - New ANT modules, additional examples, and new and expanded ANT+
  3486. profiles
  3487. - Support for Dynastream's N5 Starter Kit
  3488. - Three new BLE Services
  3489. - Precompiled HEX files
  3490. The following toolchains/devices have been used for testing and
  3491. verification:
  3492. - ARM: MDK-ARM version 5.14.0.0 and 5.16a
  3493. - GCC: GCC ARM Embedded 4.9 2015q1
  3494. - IAR: IAR Workbench 7.30.4
  3495. - Windows XP SP3 32-bit
  3496. - Windows 7 SP1 64-bit
  3497. - Windows 8.1
  3498. Supported SoftDevices:
  3499. - S110 v8.0.0
  3500. - S120 v2.1.0
  3501. - S130 v1.0.0
  3502. - S210 v5.0.0
  3503. - S310 v3.0.0
  3504. Supported boards:
  3505. - PCA10028
  3506. - PCA10031
  3507. - Dynastream's N5DK1 (only for ANT examples)
  3508. For other devices and boards, see the SDK documentation, section "Using
  3509. the SDK with other boards".
  3510. Changes:
  3511. Drivers and libraries:
  3512. New features:
  3513. - Ported FreeRTOS to run on nRF51. Added two FreeRTOS examples: one
  3514. to run on bare metal and one running a BLE HRS example using the
  3515. S110 and S130 SoftDevices.
  3516. - Added a TWI transaction manager module for managing access to an
  3517. I2C bus. Added an example that uses this module to control two
  3518. sensors on the same I2C bus.
  3519. - Added an example that shows how to use the TWI driver.
  3520. - Added a low-power PWM module (software-controlled low-accuracy
  3521. PWM). Added an example that shows how to use this module.
  3522. - Added an LED softblink module that uses the low-power PWM. Added
  3523. an example that shows how to use this module.
  3524. - Ported app_uart to use the UART driver and moved it to the
  3525. libraries folder.
  3526. - Ported app_gpiote to use the GPIOTE driver.
  3527. - Added nrf_log, a logging module that supports printf and that can
  3528. use either UART or SEGGER RTT as transport medium.
  3529. Fixed issues:
  3530. - Mailbox module moved out of serialization.
  3531. - Bug fixes in app_timer module.
  3532. - App_timer module no longer requires to define the number of
  3533. timers used in the application.
  3534. - Bug fixes in PWM module.
  3535. Changes:
  3536. - FIFO library: Extended APIs for multi-byte read and write to the
  3537. FIFO.
  3538. - Memory Manager module:
  3539. - Extended number of block categories to 7 (from 3).
  3540. - More RAM-efficient management of memory blocks.
  3541. - Added a diagnostic function to help determine the right
  3542. configuration needed for the application.
  3543. Serialization:
  3544. New features:
  3545. - Added a command for resetting the connectivity chip.
  3546. ANT:
  3547. New features:
  3548. - Added the following new ANT modules:
  3549. - ant_encryption
  3550. - ant_key_manager
  3551. - ant_search_config
  3552. - Extended/changed the following existing ANT modules:
  3553. - ant_channel_config
  3554. - ant_stack_config
  3555. - ant_state_indicator
  3556. - Refactored the ANT/ANT+ examples and profiles to make them look more
  3557. similar to the BLE profiles and examples:
  3558. - The following ANT+ profiles have been extracted and extended:
  3559. Bicycle Power (ant_bpwr), Bicycle Speed & Cadence (ant_bsc),
  3560. Stride Based Speed & Distance (ant_sdm)
  3561. - All ANT+ examples have been refactored to use extracted
  3562. profiles.
  3563. - All ANT+/ANT examples have been refactored to use created
  3564. modules.
  3565. - Added three new ANT examples:
  3566. - ant_scalable
  3567. - ant_scalable_encrypted
  3568. - ant_scan_and_forward
  3569. BLE:
  3570. - Added an experimental module named Peer Manager. This module will
  3571. eventually replace the existing Device Manager. The new Peer Manager
  3572. improves on the Device Manager in multiple ways, mainly by
  3573. supporting concurrent central and peripheral connections.
  3574. - Added an experimental flash memory module named Flash Data Storage
  3575. (FDS), which greatly reduces the need for time-consuming write and
  3576. clear operations. When using FDS, data can be arbitrarily long or
  3577. short (within about a page). All pieces of data are tagged with
  3578. types, which makes it easy to version data.
  3579. - Updated the experimental HRS/RSCS Relay example:
  3580. - It now uses the new Peer Manager instead of the Device Manager.
  3581. Therefore, it now supports bonding in both central and peripheral
  3582. roles.
  3583. - It uses the new nrf_log module, which can use SEGGER RTT.
  3584. - Removed the app_s130_demo example.
  3585. - Added an experimental example supporting the Eddystone beacon
  3586. format.
  3587. - Added the BLE Connection State module, which keeps track of certain
  3588. states of each connection (for example, whether it is encrypted) and
  3589. can also keep track of user-defined states.
  3590. - Added the Mapped Flags module, which keeps track of flags that are
  3591. mapped to keys. It is used by the BLE Connection State module.
  3592. - Added ble_gatt_db.h (containing a GATT service structure) and
  3593. modified ble_db_discovery module to use it.
  3594. BLE Services:
  3595. - Updated the Bluetoothds_template application (experimental) to be
  3596. compatible with Bluetooth Developer Studio v1.0 and the Nordic
  3597. Semiconductor NRF5X v1.1.8 plugin.
  3598. - Added three new services:
  3599. - Location Navigation Service (experimental)
  3600. - Proprietary LED Button Service (experimental)
  3601. - Nordic UART Client Service (experimental)
  3602. Fixed issues:
  3603. - App_pwm occasionally gives inverted signal.
  3604. Known issues:
  3605. - Device Manager is not supported in multi-role S130 operation.
  3606. - Device Manager works in peripheral or central only operation on
  3607. S130. This must be decided at compile time.
  3608. - The DFU over BLE example has been tested to work with a minimum
  3609. connection interval of 11.25 ms. The application cannot handle
  3610. connection intervals lower than 11.25 ms and may undergo a system
  3611. reset in the middle of a firmware update.
  3612. Workaround: If you face unexpected disconnects during the firmware
  3613. update process, consider increasing the connection
  3614. interval used by the master.
  3615. - The old manual procedure for testing buttonless DFU, as specified in
  3616. the documentation, can lead to the DFU process hanging or returning
  3617. an error when used with Master Control Panel 3.8 and newer.
  3618. - Bootloader binaries (.bin files) generated with the GCC makefile
  3619. should not be used. Instead, generate the bootloader bin files using
  3620. nrfutils, found on GitHub.
  3621. ========================================================================
  3622. nRF52 SDK v0.9.2
  3623. ----------------
  3624. Release date: Week 42, 2015
  3625. This is an amendment to nRF52 SDK v0.9.1.
  3626. Highlights:
  3627. - New targets to enable the two near field communication (NFC)
  3628. examples to run on the new PCA10040 development board with
  3629. nRF52832 IC rev. Engineering B.
  3630. Libraries:
  3631. - Extended the NFC HAL layer of the NFC library to support the NFCT
  3632. peripherial for both the chip version delivered with the nRF52
  3633. Preview Development Kit (Engineering A: QFAA-AA0, QFAA-AC0,
  3634. CGAA-AA0) and the chip version delivered with the nRF52 Development
  3635. Kit (Engineering B: QFAA-BA0, QFAA-BB0, CHAA-AA0, CHAA-AB0).
  3636. Examples:
  3637. - Added PCA10040 as target bord for the following examples:
  3638. - Heart Rate Example with pairing over NFC
  3639. - NFC URL Record Application
  3640. Known issues/workarounds:
  3641. - To use the software workarounds implemented for PCA10036 (part
  3642. of nRF52 Preview Development Kit), globally define
  3643. HAL_NFC_ENGINEERING_A_FTPAN_WORKAROUND in your project.
  3644. - The TIMER4 peripheral is used to implement one of the workarounds
  3645. for PCA10036. This workaround is not used for PCA10040.
  3646. - The ble_app_hrs_pairing_nfc example is unable to wake up from
  3647. system off.
  3648. ========================================================================
  3649. nRF52 SDK v0.9.1
  3650. ----------------
  3651. Release date: Week 29, 2015
  3652. This is an amendment to nRF52 SDK v0.9.0.
  3653. Highlights:
  3654. - Support for near field communication (NFC)
  3655. Libraries/Services:
  3656. - Added a library that supports Type 2 NFC-A tag functionality in
  3657. read-only state
  3658. - Added a module to generate NFC NDEF messages for BLE pairing over NFC
  3659. - Added a module to generate NFC NDEF messages with an URI record type
  3660. - Extended the ble_advdata module
  3661. Examples:
  3662. - Added ble_app_hrs_pairing_nfc example that demonstrates pairing over
  3663. NFC (with S132 SoftDevice)
  3664. - Added record_url NFC example that demonstrates exposing a URL record
  3665. (without SoftDevice)
  3666. Limitations:
  3667. - The current version of the NFC library uses TIMER4.
  3668. - The ble_app_hrs_pairing_nfc example has been tested only with Samsung
  3669. Galaxy S6.
  3670. - If the path to the SDK directory is too long, compilation in Keil fails.
  3671. To work around this problem, move the SDK higher in the folder tree
  3672. or use shorter folder names.
  3673. ========================================================================
  3674. nRF51 SDK v9.0.0
  3675. ----------------
  3676. Release Date: Week 28, 2015
  3677. Highlights:
  3678. - Support for S210 SoftDevice v5.0.0
  3679. - Support for S310 SoftDevice v3.0.0
  3680. - Documentation moved to Infocenter
  3681. - DFU Signing using Elliptic Curve Cryptography added as experimental
  3682. - Available in the zip file only
  3683. - Running Speed and Cadence relay example showing concurrent
  3684. central/peripheral functionality of S130
  3685. The following toolchains/devices have been used for testing and verification:
  3686. - ARM: MDK-ARM version 5.14.0.0
  3687. - GCC: GCC ARM Embedded 4.9 2015q1
  3688. - IAR: IAR Workbench 7.20
  3689. - Windows XP SP3 32-bit
  3690. - Windows 7 SP1 64-bit
  3691. - Windows 8.1
  3692. Supported SoftDevices:
  3693. - S110 v8.0.0
  3694. - S120 v2.1.0
  3695. - S130 v1.0.0
  3696. - S210 v5.0.0
  3697. - S310 v3.0.0
  3698. Supported boards:
  3699. - PCA10028
  3700. - PCA10031
  3701. For other devices and boards, see the SDK documentation, section
  3702. "Using the SDK with other boards".
  3703. Changes:
  3704. - Flash access module has been refactored (pstorage).
  3705. ANT:
  3706. - Both the S310 and the S210 SoftDevices now support an extended
  3707. number of ANT channels (16).
  3708. Libraries:
  3709. - Heart Rate Monitor Profile
  3710. - ANT stack configuration
  3711. - ANT channel configuration
  3712. - ANT channel state indicator
  3713. - ANT pulse simulator
  3714. Examples:
  3715. - The ANT HRM examples have been refactored.
  3716. - The Bicycle Power examples (ant_bicycle_pwr) support S310.
  3717. ANT + BLE (S310):
  3718. The following examples were added:
  3719. - Bluetooth LE and ANT combined heart rate example (ble_ant_app_hrm).
  3720. - Experimental ANT Shared Channels (experimental_ant_shared_channel_master_to_master,
  3721. experimental_ant_shared_channel_slave).
  3722. BLE:
  3723. - Advertising module has a new mode: Low Duty Cycle Directed Advertising.
  3724. - Running Speed and Cadence Client added as experimental.
  3725. - Bluetooth Developer Studio template added as experimental.
  3726. - Heart Rate Sensor example (ble_app_hrs) supports S310.
  3727. - Running Speed and Cadence example (ble_app_rscs) supports S310.
  3728. - Combined Peripheral and Central example added as experimental.
  3729. - DFU Signing using Elliptic Curve Cryptography added as experimental
  3730. (using the same elliptic curve and hashing algorithm as Bluetooth
  3731. Low Energy 4.2 Secure Connections).
  3732. Fixed issues:
  3733. - Pstorage now supports updates of bond split across two pages.
  3734. - Advertising module can be set to infinite time-out.
  3735. - Corrected clock source in BLE multiactivity beacon example.
  3736. - Serialization HCI transport layer: Receiving packet-buffer is not
  3737. freed while sending ACK or NACK.
  3738. Known issues:
  3739. - Device Manager is not supported in multi-role S130 operation.
  3740. - Device Manager works in peripheral or central only operation on
  3741. S130. This must be decided at compile time.
  3742. - The DFU over BLE example has been tested to work with a minimum
  3743. connection interval of 11.25 ms. The application cannot handle
  3744. connection intervals lower than 11.25 ms and may undergo a system
  3745. reset in the middle of a firmware update.
  3746. Workaround: If you face unexpected disconnects during the firmware
  3747. update process, consider increasing the connection interval used
  3748. by the master.
  3749. - App_pwm occasionally gives inverted signal.
  3750. - The old manual procedure for testing buttonless DFU, as specified in
  3751. the documentation, can lead to the DFU process hanging or returning
  3752. an error when used with Master Control Panel 3.8 and newer.
  3753. ========================================================================
  3754. nRF52 SDK v0.9.0
  3755. ----------------
  3756. Release date: 17.06.2015
  3757. Highlights:
  3758. - Support for PCA10036 board v1.0.0 with nRF52832 QFAAAA
  3759. - Support for S132 SoftDevice v1.0.0-3.alpha (hex included)
  3760. - Support for S212 SoftDevice v0.2.0-1.alpha
  3761. - Support for Keil5 without CMSIS Packs
  3762. - Support for GCC
  3763. - Same structure as nRF51 SDK v8.1.0
  3764. - New peripheral drivers
  3765. - Documentation moved to Infocenter
  3766. The following toolchains/devices have been used for testing and verification:
  3767. - ARM: MDK-ARM version 5.14.0.0
  3768. - GCC: GCC ARM Embedded 4.9 2015q1
  3769. - Windows 7 SP1 64-bit
  3770. Supported SoftDevices:
  3771. - S132 v1.0.0-3.alpha
  3772. - S212 v0.2.0-1.alpha
  3773. Supported boards:
  3774. - PCA10036 v1.0.0
  3775. Examples:
  3776. - Most examples are ported from nRF51 SDK v8.1.0
  3777. - BLE examples run with the S132 SoftDevice
  3778. - ANT examples run with the S212 SoftDevice
  3779. - The following examples are included:
  3780. - BLE peripheral examples
  3781. - BLE central example
  3782. - New BLE combined central and peripheral example
  3783. - ANT examples
  3784. - HW peripheral examples
  3785. - New SAADC example
  3786. - New TWI master with TWI slave example
  3787. - BLE/serial DFU bootloader
  3788. - Direct Test Mode Application
  3789. Drivers:
  3790. - Includes all drivers from nRF51 SDK v8.1.0
  3791. - New drivers:
  3792. - SPI driver that supports SPI and SPIM
  3793. - UART driver that supports UART and UARTE
  3794. - SAADC HAL driver
  3795. - TWI slave driver
  3796. - SAADC driver
  3797. Libraries/Services:
  3798. - Same functionality as for nRF51 SDK v8.1.0
  3799. - The following libraries and services are included:
  3800. - BLE libraries
  3801. - BLE Services
  3802. - Transport Services
  3803. - Other libraries/components
  3804. Known issues:
  3805. - Device might reset when a Bluetooth link layer procedure and flash operation happens in parallel.
  3806. - Inconsistent behavior with Nexus devices running Android v5.1.1, for example:
  3807. - DFU fails
  3808. - Link loss might reset the nRF52 device
  3809. (such behavior might occur with other devices as well)
  3810. - After a power cycle, a UART lockup between Segger J-Link and nRF52 might occur
  3811. - Before a serial DFU operation or DTM can be executed, "nrfjprog --reset" must be run
  3812. ========================================================================
  3813. nRF51 SDK v. 8.1.1
  3814. ------------------
  3815. This is a supplement to the nRF51 SDK v8.1.0 release notes.
  3816. This release does not include any code changes compared to nRF51 SDK v8.1.0., except for a minor addition that is described in the "Changes" section.
  3817. Fixed issues:
  3818. - Project does not compile if nrf_drv_ppi is used together with SoftDevice S110, S120 or S210.
  3819. Issue exists only in CMSIS PACK release.
  3820. Changes:
  3821. - Released new SoftDevice packs: nRF_SoftDevice_S110.8.0.1, nRF_SoftDevice_S120.2.0.1 and
  3822. nRF_SoftDevice_S210.4.0.1-5 with updated nrf_sd_def.h.
  3823. Supported SoftDevices:
  3824. - S110 8.0.0
  3825. - S120 2.0.0
  3826. - S130 1.0.0
  3827. - S210 4.0.1
  3828. ========================================================================
  3829. nRF51 SDK v8.1.0
  3830. ----------------
  3831. Highlights:
  3832. - Support for SoftDevice S130 v1.0.0
  3833. - Serialization supporting SoftDevice S110, S120, and S130
  3834. - ANCS updated and no longer in experimental state
  3835. - GCC updated to new version: ARMGCC 4.9 q1-2015
  3836. - DFU example now has support for IAR and GCC
  3837. The following toolchains/devices have been used for testing and verification:
  3838. - ARM: MDK-ARM version 4.72.10, 5.13.0.0, 5.14.0.0
  3839. - GCC: gcc-arm-embedded 4.9 2015q1
  3840. - IAR: IAR Embedded Workbench for ARM version 7.20.2
  3841. - Windows XP SP3 32-bit
  3842. - Windows 7 SP1 64-bit
  3843. - Windows 8.1
  3844. Supported devices:
  3845. - This SDK is optimized for IC revision 3.
  3846. For details, see the "nRF51 Series Compatibility Matrix" document (ATTN-51) available on
  3847. www.nordicsemi.com.
  3848. Note 1: To run the ANT examples, you must use an nRF51422 device.
  3849. Note 2: Some of the examples using the SoftDevice will not fit on the 128 kB variant of the
  3850. chip.
  3851. Supported SoftDevices:
  3852. - S110 8.0.0
  3853. - S120 2.0.0
  3854. - S130 1.0.0
  3855. - S210 4.0.1
  3856. Supported boards:
  3857. - PCA10028
  3858. - PCA10031
  3859. For other devices and boards, see the SDK documentation, section "Using the SDK with other
  3860. boards", or use SDK v6.x.x.
  3861. Changes:
  3862. ANT + BLE (dual stack):
  3863. - Not included in this release due to conflicting interface between SoftDevice S310 and S110. Use SDK v7.2.0 for S310 support.
  3864. - S310 support will be reintroduced in a future release.
  3865. BLE:
  3866. - SoftDevices:
  3867. - Support for S130 v1.0.0.
  3868. - Serialization:
  3869. - Fully serialized S110, S120, and S130 API.
  3870. - Modules/Services:
  3871. - New button module (bsp_btn_ble) that enables functionality such as disconnect, turn off whitelist, go to sleep.
  3872. - Advertising module now supports scan response data
  3873. - Examples:
  3874. - ANCS example is no longer in experimental state.
  3875. Proprietary:
  3876. - IAR support for proprietary examples.
  3877. Peripheral drivers & libraries:
  3878. - New peripheral drivers: TWI, SWI, and GPIOTE.
  3879. - New PWM driver. PWM example updated to use the driver.
  3880. Fixed issues:
  3881. - NRFFOSDK-2044: Fixed issue in app_gpiote.
  3882. - NRFFOSDK-3855: Fixed issue in Current Time Service.
  3883. Known issues:
  3884. - Device Manager is not supported in multirole S130 operation.
  3885. - Device Manager works in peripheral or central only operation on S130. This must be decided at compile time.
  3886. - The DFU over BLE example has been tested to work with a minimum connection interval of
  3887. 11.25 ms. The application cannot handle connection intervals lower than 11.25 ms and may
  3888. undergo a system reset in the middle of a firmware update.
  3889. Workaround: If you face unexpected disconnects during the firmware update process, consider
  3890. increasing the connection interval.
  3891. - ANT:
  3892. - NRFFOSDK-755: HRM TX buttons example may report wrong total elapsed time.
  3893. - BLE:
  3894. - A few APIs of the Device Manager are not implemented. Also, documentation providing
  3895. examples of how the API can be used is missing.
  3896. - NRFFOSDK-2824: Device Manager (pstorage) does not support update of bond split across two
  3897. pages.
  3898. - Proprietary:
  3899. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box
  3900. with the nRF51 ESB examples. This is due to:
  3901. - The legacy examples do not use "payload in ACK".
  3902. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  3903. - The examples do not use dynamic payload length.
  3904. The legacy examples need to add the following to work with the nRF51 examples:
  3905. hal_nrf_setup_dynamic_payload(0xFF);
  3906. hal_nrf_enable_dynamic_payload(true);
  3907. hal_nrf_enable_ack_payload(true);
  3908. hal_nrf_set_rf_channel(10);
  3909. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  3910. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy
  3911. Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and
  3912. channel tables require adjustment.
  3913. - Timeslot period: Edit the gzll_params.h file used in the nRF24Lxx projects or use the
  3914. nrf_gzll_set_timeslot_period() function in the nRF51 projects
  3915. (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  3916. - Channel table: Edit the gzll_params.h file used in the nRF24Lxx projects or use the
  3917. nrf_gzll_set_channel_table() function in the nRF51 projects.
  3918. - Gazell does not support "Low Power Host mode" (Host mode 1).
  3919. ========================================================================
  3920. nRF51 SDK v8.0.0
  3921. ----------------
  3922. Highlights:
  3923. - Support for the latest S110, S120, and S130 SoftDevices. (S310 is not supported.)
  3924. - SoftDevices included in the SDK.
  3925. - Greatly increased driver and HAL coverage.
  3926. - New service client and profile example: Current Time Service/Time Profile.
  3927. - IAR support for most examples.
  3928. The following toolchains/devices have been used for testing and verification:
  3929. - ARM: MDK-ARM Version 4.72.10, 5.13.0.0, 5.14.0.0
  3930. - GCC: gcc-arm-embedded 4.7 2013q1
  3931. - IAR: IAR Embedded Workbench for ARM version 7.20.2
  3932. - Windows XP SP3 32-bit
  3933. - Windows 7 SP1 64-bit
  3934. - Windows 8.1
  3935. Supported devices:
  3936. - This SDK is optimized for IC revision 3.
  3937. For details, see the "nRF51 Series Compatibility Matrix" document (ATTN-51) available on
  3938. www.nordicsemi.com.
  3939. Note 1: To run the ANT examples, you must use an nRF51422 device.
  3940. Note 2: Some of the examples using the SoftDevice will not fit on the 128 kB variant of the
  3941. chip.
  3942. Supported SoftDevices:
  3943. - S110 8.0.0
  3944. - S120 2.0.0
  3945. - S130 0.9.0-1.alpha
  3946. - S210 4.0.1
  3947. Supported boards:
  3948. - PCA10028
  3949. - PCA10031
  3950. For other devices and boards, see the SDK documentation, section "Using the SDK with other
  3951. boards", or use SDK v6.x.x.
  3952. Changes:
  3953. Toolchain/IDE:
  3954. - The nRF51 SDK now supports the following toolchains in most examples:
  3955. - Keil 5.14 (with packs)
  3956. - Keil 5.14 (without packs)
  3957. - Keil 4.72.10
  3958. - ARM GCC 4.7 2013q1
  3959. - IAR 7.20.2
  3960. - The supported SoftDevices are now included in the SDK and can be flashed directly from
  3961. Keil, as a separate target.
  3962. ANT + BLE (dual stack):
  3963. - Removed support for the S310 SoftDevice for BLE API compatibility reasons. For support,
  3964. use SDK v7.2.0.
  3965. BLE:
  3966. - SoftDevices:
  3967. - The SDK now supports the S110 SoftDevice v8.0.0.
  3968. - The SDK now supports the S120 SoftDevice v2.0.0.
  3969. - The SDK now supports the S130 SoftDevice v0.9.0-1.alpha.
  3970. - Serialization:
  3971. - Serialization support has been removed. For support, use SDK v7.2.0 with appropriate
  3972. SoftDevices.
  3973. - Modules/Services:
  3974. - Added a new advertising module (ble_advertising) that provides automatic handling of
  3975. directed/fast/slow advertising, with and without whitelist.
  3976. - Nordic UART Service (ble_nus), detached from the UART over BLE Example.
  3977. - Added Current Time Service Client (ble_cts_c).
  3978. - Service Changed characteristic has been implemented for DFU, so that the indication is
  3979. sent when transitioning between application and bootloader.
  3980. - Implemented a mechanism for sharing of IRK and LTK from application to bootloader.
  3981. This allows for whitelist advertising and reconnection in DFU mode using existing
  3982. keys.
  3983. - Examples:
  3984. - The UART over BLE Example is no longer experimental.
  3985. - Added a Time Profile (ble_app_cts_c) example using the Current Time Service Client
  3986. implementation.
  3987. Drivers/Libraries:
  3988. - Added hardware abstraction layer for the following hardware peripherals:
  3989. - ADC (Analog-to-digital converter)
  3990. - CLOCK (Clock management)
  3991. - LPCOMP (Low power comparator)
  3992. - PPI (Programmable Peripheral Interconnect)
  3993. - QDEC (Quadrature decoder)
  3994. - RNG (Random number generator)
  3995. - RTC (Real time counter)
  3996. - TIMER (Timer/counter)
  3997. - WDT (Watchdog timer)
  3998. - Added drivers for the following peripherals:
  3999. - CLOCK (Clock management)
  4000. - LPCOMP (Low power comparator)
  4001. - PPI (Programmable Peripheral Interconnect)
  4002. - QDEC (Quadrature decoder)
  4003. - RNG (Random number generator)
  4004. - RTC (Real time counter)
  4005. - TIMER (Timer/counter)
  4006. - WDT (Watchdog timer)
  4007. - Added modules:
  4008. - app_simple_timer (Simple timer based on TIMER1)
  4009. Hardware Examples:
  4010. - Added:
  4011. - adc_simple (NRF_ADC)
  4012. - clock (NRF_DRV_CLOCK)
  4013. - lpcomp (NRF_DRV_LPCOMP)
  4014. - qdec (NRF_DRV_QDEC)
  4015. - simple_timer (APP_SIMPLE_TIMER)
  4016. - wdt (NRF_DRV_WDT)
  4017. - Modified:
  4018. - ppi (NRF_DRV_PPI)
  4019. - rng (NRF_DRV_RNG)
  4020. - rtc (NRF_DRV_RTC)
  4021. - timer (NRF_DRV_TIMER)
  4022. Fixed issues:
  4023. - Fixed pstorage issue where different applications could write to the same page.
  4024. Known issues:
  4025. - The DFU over BLE example has been tested to work with a minimum connection interval of
  4026. 11.25 ms. The application cannot handle connection intervals lower than 11.25 ms and may
  4027. undergo a system reset in the middle of a firmware update.
  4028. Workaround: If you face unexpected disconnects during the firmware update process, consider
  4029. increasing the connection interval used by the master.
  4030. - ANT:
  4031. - NRFFOSDK-755: HRM TX buttons example may report wrong total elapsed time
  4032. - BLE:
  4033. - A few APIs of the Device Manager are not implemented. Also, documentation providing
  4034. examples of how the API can be used is missing.
  4035. - NRFFOSDK-2824: Device Manager (pstorage) does not support update of bond split across two
  4036. pages.
  4037. - Proprietary:
  4038. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box
  4039. with the nRF51 ESB examples. This is due to:
  4040. - The legacy examples do not use "payload in ACK".
  4041. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4042. - The examples do not use dynamic payload length.
  4043. The legacy examples need to add the following to work with the nRF51 examples:
  4044. hal_nrf_setup_dynamic_payload(0xFF);
  4045. hal_nrf_enable_dynamic_payload(true);
  4046. hal_nrf_enable_ack_payload(true);
  4047. hal_nrf_set_rf_channel(10);
  4048. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4049. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy
  4050. Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and
  4051. channel tables require adjustment.
  4052. - Timeslot period: Edit the gzll_params.h file used in the nRF24Lxx projects or use the
  4053. nrf_gzll_set_timeslot_period() function in the nRF51 projects
  4054. (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4055. - Channel table: Edit the gzll_params.h file used in the nRF24Lxx projects or use the
  4056. nrf_gzll_set_channel_table() function in the nRF51 projects.
  4057. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4058. ========================================================================
  4059. nRF51 SDK v7.2.0
  4060. ----------------
  4061. Following toolchains/devices have been used for testing and verification:
  4062. - ARM: MDK-ARM Version 5.12, 5.13
  4063. - GCC: gcc-arm-embedded 4.7 2013q1
  4064. - IAR: no support in this release
  4065. - Windows XP SP3 32-bit
  4066. - Windows 7 SP1 64-bit
  4067. - Windows 8.1
  4068. Supported devices
  4069. - This SDK is optimized for IC revision 3.
  4070. For details, see the "nRF51 Series Compatibility Matrix" document (ATTN-51) available on
  4071. www.nordicsemi.com.
  4072. Note 1: To run the ANT examples, you must use an nRF51422 device.
  4073. Note 2: Some of the examples using the SoftDevice will not fit on the 128 kB variant of the
  4074. chip.
  4075. Note 3: Some of the serialization examples are too big to be compiled using the free version
  4076. of Keil.
  4077. Supported SoftDevices:
  4078. - S110 7.1.0
  4079. - S120 1.0.1
  4080. - S130 0.5.0-1.alpha
  4081. - S210 4.0.1
  4082. - S310 2.0.1
  4083. Supported boards:
  4084. - PCA10028
  4085. - PCA10031
  4086. - S110 connectivity support for Wavetek WT51822
  4087. For other devices and boards, see the SDK documentation, section "Using the SDK with other
  4088. boards", or use SDK v6.x.x.
  4089. Changes:
  4090. - ANT:
  4091. - ANT-FS client example: Added callback to allow applications to execute custom code while
  4092. waiting for the burst to complete
  4093. - Major rework on ANT DFU example
  4094. - Added new ANT hub-2-hub/shared channel example
  4095. - Added S310 target support for DTM example
  4096. - BLE DFU is now supported for S310
  4097. Fixed issues:
  4098. - ANT:
  4099. - ANT-FS: Fixed bug with transfer sequence number error causing download failures
  4100. - ANT-FS: Fixed bug where upon exhaustion of m_retry, the link time-out has been mistakenly
  4101. disabled by a burst transfer
  4102. - Fixed issue in linker script for S310
  4103. - Fixed memory corruption issue by using dedicated buffers for ANT and BLE stack events
  4104. respectively on S310
  4105. - Fixed an issue where the ANT OTA Updater application v0.8 would not support hex files
  4106. with code size larger than 65535 bytes
  4107. Known issues:
  4108. - SEGGER J-Link software has some issues with Keil.
  4109. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for details.
  4110. - Keil 5.13 may issue a warning about missing packs even when all Nordic Semiconductor packs are
  4111. correctly installed.
  4112. - The DFU over BLE example has been tested to work with a minimum connection interval of
  4113. 11.25 ms. The application cannot handle connection intervals lower than 11.25 ms and may
  4114. undergo a system reset in the middle of a firmware update.
  4115. Workaround: If you face unexpected disconnects during the firmware update process, consider
  4116. increasing the connection interval used by the master.
  4117. - ANT:
  4118. - NRFFOSDK-755: HRM TX buttons example may report wrong total elapsed time
  4119. - BLE:
  4120. - NRFFOSDK-3135: S120 examples: RAM is limited to 16 kB, because S120 V1.0.1 does not
  4121. support utilizing the whole flash on the QFACAB chip
  4122. - NRFFOSDK-119: Only the ble_app_proximity_low_power and ble_app_hrs applications are power
  4123. optimized
  4124. - S120 examples: Flash clear operation may fail when connected. Impact of this in the S120
  4125. examples is that if the peer loses the bond and a rebonding occurs, flash clear fails and
  4126. a DM_EVT_DEVICE_CONTEXT_STORED event is notified with a failure.
  4127. - A few APIs of the Device Manager are not implemented. Also, documentation providing
  4128. examples of how the API can be used is missing.
  4129. - NRFFOSDK-2824: Device Manager (pstorage) does not support update of bond split across two
  4130. pages.
  4131. - Proprietary:
  4132. - Temperature example does not give sane output values. This is a hardware-related issue
  4133. described in PAN_028 and will be fixed in future silicon.
  4134. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box
  4135. with the nRF51 ESB examples. This is due to:
  4136. - The legacy examples do not use "payload in ACK".
  4137. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4138. - The examples do not use dynamic payload length.
  4139. The legacy examples need to add the following to work with the nRF51 examples:
  4140. hal_nrf_setup_dynamic_payload(0xFF);
  4141. hal_nrf_enable_dynamic_payload(true);
  4142. hal_nrf_enable_ack_payload(true);
  4143. hal_nrf_set_rf_channel(10);
  4144. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4145. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy
  4146. Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and
  4147. channel tables require adjustment.
  4148. - Timeslot period: Edit the gzll_params.h file used in the nRF24Lxx projects or use the
  4149. nrf_gzll_set_timeslot_period() function in the nRF51 projects
  4150. (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4151. - Channel table: Edit the gzll_params.h file used in the nRF24Lxx projects or use the
  4152. nrf_gzll_set_channel_table() function in the nRF51 projects.
  4153. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4154. ========================================================================
  4155. nRF51 SDK v7.1.0
  4156. ----------------
  4157. Following toolchains/devices have been used for testing and verification:
  4158. - ARM: MDK-ARM Version 5.12
  4159. - GCC: gcc-arm-embedded 4.7 2013q1
  4160. - IAR: no support in this release
  4161. - Windows XP SP3 32-bit
  4162. - Windows 7 SP1 64-bit
  4163. - Windows 8.1
  4164. Tested with devices:
  4165. - nRF51422 QFACAB
  4166. For others devices, use SDK 6.x.x.
  4167. Supported SoftDevices:
  4168. - S110 7.1.0
  4169. - S120 1.0.1
  4170. - S130 0.5.0-1.alpha
  4171. - S210 4.0.1
  4172. - S310 2.0.0
  4173. Supported boards:
  4174. - PCA10028
  4175. - PCA10031
  4176. - S110 connectivity support for Wavetek WT51822
  4177. For other boards, use SDK V6.x.x.
  4178. Changes:
  4179. - Experimental support for over-the-air firmware update using the ANT radio protocol
  4180. - New experimental example ANT relay demo
  4181. - Support for S310 ANT+BLE version 2.0.0
  4182. - Re-introduce Device Firmware Update via UART
  4183. - BLE DFU single bank support for bootloader+softdevice update
  4184. Fixed issues:
  4185. - NRFFOSDK-3119 Fixed issue in app_timer where issuing start/stop from interrupt context caused long delays
  4186. Known issues:
  4187. - SEGGER J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  4188. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms. The application cannot handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firmware update.
  4189. Workaround: If you face unexpected disconnects during the firmware update process, consider increasing the connection interval used by the master
  4190. ANT
  4191. - The OTA Updater application v.0.8 does not support hex files with code size larger than 65535 bytes.
  4192. - NRFFOSDK-366: ANT-FS host: download sometimes fails when downloading a large file
  4193. - NRFFOSDK-755: HRM TX buttons example may report wrong total elapsed time
  4194. BLE
  4195. - NRFFOSDK-3135: S120 examples: RAM is limited to 16 kB, because S120 V1.0.1 does not support utilizing the whole flash on the QFACAB chip
  4196. - NRFFOSDK-119: Only the ble_app_proximity_low_power and ble_app_hrs applications are power optimized
  4197. - S120 examples: Flash clear operation may fail when connected. Impact of this in the S120 examples is that if the peer loses the bond and a rebonding occurs, flash clear fails and a DM_EVT_DEVICE_CONTEXT_STORED event is notified with a failure.
  4198. - A few APIs of the Device Manager are not implemented. Also, documentation providing examples of how the API can be used is missing.
  4199. - NRFFOSDK-2824: Device Manager (pstorage) does not support update of bond split across two pages.
  4200. Proprietary:
  4201. - Temperature example does not give sane output values. This is a hardware-related issue described in PAN_028 and will be fixed in future silicon.
  4202. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  4203. - The legacy examples do not use "payload in ACK".
  4204. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4205. - The examples do not use dynamic payload length.
  4206. The legacy examples need to add the following to work with the nRF51 examples:
  4207. hal_nrf_setup_dynamic_payload(0xFF);
  4208. hal_nrf_enable_dynamic_payload(true);
  4209. hal_nrf_enable_ack_payload(true);
  4210. hal_nrf_set_rf_channel(10);
  4211. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4212. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  4213. - Timeslot period: Edit the gzll_params.h file used in the nRF24Lxx projects or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4214. - Channel table: Edit the gzll_params.h file used in the nRF24Lxx projects or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  4215. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4216. ========================================================================
  4217. nRF51 SDK v. 7.0.1
  4218. ------------------
  4219. This is a supplement to the nRF51 SDK v7.0.0 release notes.
  4220. This release does not include any code changes compared to nRF51 SDK v7.0.0, except for a minor addition that is described in the "Changes" section.
  4221. Fixed issues:
  4222. - Replaced DeviceFamilyPack v1.1.3, which has a wrong URL, with DeviceFamilyPack v1.1.4.
  4223. - Added a version field to Pack examples descriptions (NordicSemiconductor.nRF_Examples.pdsc).
  4224. - Added missing Nordic Semiconductor nRF51 MDK installer to the repository distribution (nRF51_SDK_x.x.x_xxxxxxx.zip).
  4225. - Added missing message sequence charts to the documentation.
  4226. - Changed incorrect description of supported SoftDevices in the release notes (see below for the correct list of supported SoftDevices).
  4227. Changes:
  4228. - Added all the register and bitfields for the SPIM peripheral (present in the nRF51802 device) to the HAL header files and replaced the pack nRF_Drivers v1.0.0 with nRF_Drivers v1.1.0.
  4229. Supported SoftDevices:
  4230. - S110 7.1.0
  4231. - S120 1.0.1
  4232. - S130 0.5.0-1.alpha
  4233. - S210 4.0.1
  4234. nRF51 SDK v7.0.0
  4235. ----------------
  4236. Following toolchains/devices have been used for testing and verification:
  4237. - ARM: MDK-ARM Version 5.12
  4238. - GCC: gcc-arm-embedded 4.7 2013q1
  4239. - IAR: no support in this release
  4240. - Windows XP SP3 32-bit
  4241. - Windows 7 SP1 64-bit
  4242. - Windows 8.1
  4243. Tested with devices:
  4244. - nRF51422 QFACAB
  4245. For others devices, use SDK 6.x.x.
  4246. Supported SoftDevices:
  4247. - S110 7.1.0
  4248. - S120 1.0.0 S120 1.0.1
  4249. - S130 0.5.0-1.alpha
  4250. - S210 4.0.1
  4251. - S310 1.0.0
  4252. Supported boards:
  4253. - PCA10028
  4254. - PCA10031
  4255. - S110 connectivity support for Wavetek WT51822
  4256. For other boards, use SDK V6.x.x.
  4257. Changes:
  4258. - New folder structure
  4259. - Moved from installer to CMSIS pack format
  4260. - Added support for PCA100028 and PCA10031
  4261. - Deprecated support for previous boards
  4262. - Added support for RTX tickless
  4263. ANT
  4264. - Changed the ANT examples to support S210 SoftDevice v4.0.1
  4265. - Added experimental Background Scanning example
  4266. ANT + BLE (Dual stack)
  4267. - Removed support for S310 SoftDevice (for support, use SDK v6.x.x)
  4268. BLE
  4269. - DFU: Added experimental mechanism to exchange encryption keys between application and BootLoader
  4270. - DFU: Added identification of firmware versions in the init packet
  4271. - Added experimental BLE nRF UART example
  4272. - Added experimental ANCS example
  4273. - Added experimental example demonstrating usage of S130 SoftDevice
  4274. - Added HRS example with RTX
  4275. Proprietary
  4276. - Deprecated the following examples (for support, use SDK v6.x.x):
  4277. * ADNS2080 Mouse Sensor Driver Application
  4278. * Cherry8x16 Keyboard Application
  4279. * Button Debouncer Example
  4280. * nRF6350 Radio Configuration Example
  4281. * PWM Analyzer Example
  4282. * Motor Control Example
  4283. * TWI Master Example
  4284. Fixed issues:
  4285. - NRFFOSDK-362: Reset button won't work after programming without cycling the target power
  4286. - NRFFOETT-205: The nRF51822 installer will not run if no C:\ drive exists - No installer
  4287. - NRFFOSDK-236: When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear - No installer
  4288. - NRFFOSDK-363: Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  4289. Known issues:
  4290. - SEGGER J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  4291. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms. The application cannot handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firmware update.
  4292. Workaround: If you face unexpected disconnects during the firmware update process, consider increasing the connection interval used by the master
  4293. ANT
  4294. - NRFFOSDK-366: ANT-FS host: download sometimes fails when downloading a large file
  4295. - NRFFOSDK-755: HRM TX buttons example may report wrong total elapsed time
  4296. BLE
  4297. - NRFFOSDK-3135: S120 examples: RAM is limited to 16 kB, because S120 V1.0.1 does not support utilizing the whole flash on the QFACAB chip
  4298. - NRFFOSDK-119: Only the ble_app_proximity_low_power and ble_app_hrs applications are power optimized
  4299. - S120 examples: Flash clear operation may fail when connected. Impact of this in the S120 examples is that if the peer loses the bond and a rebonding occurs, flash clear fails and a DM_EVT_DEVICE_CONTEXT_STORED event is notified with a failure.
  4300. - A few APIs of the Device Manager are not implemented. Also, documentation providing examples of how the API can be used is missing.
  4301. - NRFFOSDK-2824: Device Manager (pstorage) does not support update of bond split across two pages.
  4302. Proprietary:
  4303. - NRFFOSDK-1769: Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  4304. - Temperature example does not give sane output values. This is a hardware-related issue described in PAN_028 and will be fixed in future silicon.
  4305. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  4306. - The legacy examples do not use "payload in ACK".
  4307. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4308. - The examples do not use dynamic payload length.
  4309. The legacy examples need to add the following to work with the nRF51 examples:
  4310. hal_nrf_setup_dynamic_payload(0xFF);
  4311. hal_nrf_enable_dynamic_payload(true);
  4312. hal_nrf_enable_ack_payload(true);
  4313. hal_nrf_set_rf_channel(10);
  4314. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4315. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  4316. - Timeslot period: Edit the gzll_params.h file used in the nRF24Lxx projects or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4317. - Channel table: Edit the gzll_params.h file used in the nRF24Lxx projects or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  4318. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4319. ========================================================================
  4320. nRF51 SDK v. 6.1.0
  4321. ------------------
  4322. Following toolchains/devices have been used for testing and verification:
  4323. - ARM: MDK-ARM Version 5.10.x/5.11.x
  4324. - GCC: gcc-arm-embedded 4.7 2013q1
  4325. - IAR: Embedded Workbench for ARM 6.60
  4326. - Windows XP SP3 32 bit
  4327. - Windows 7 SP1 64 bit
  4328. - Windows 8.0/8.1
  4329. Tested with devices:
  4330. - nRF51822 QFAAG0
  4331. - nRF51822 QFAAGC
  4332. - nRF51822 QFAAFA
  4333. - nRF51422 QFAAE0
  4334. For others devices, use SDK 4.x.x
  4335. Supported SoftDevices:
  4336. - S110 7.0.0
  4337. - S120 1.0.0
  4338. - S210 3.0.0
  4339. - S310 1.0.0
  4340. Supported boards:
  4341. - PCA10000 v1.0 (Only for use with Master Emulator)
  4342. - PCA10000 v2.1.0 and 2.2.0
  4343. - PCA10001 v2.1.0 and 2.2.0
  4344. - PCA10004 v2.1.0
  4345. - PCA10005 v2.1.0 and 2.2.0
  4346. - PCA10003 v3.0.0
  4347. Changes:
  4348. - Added Keil 5 uvprojx files for most example projects.
  4349. - Extended GCC support, most examples now supplied with Makefiles.
  4350. ANT
  4351. - None.
  4352. ANT + BLE (Dual stack)
  4353. - None.
  4354. BLE
  4355. - Device firmware upgrade with support for OTA update of SoftDevice, app and bootloader is no longer in experimental status.
  4356. - Buttonless bootloader mode, enter bootloader mode via over-the-air command (see ble_app_hrs example, using ble_app_hrs_dfu.uvproj project).
  4357. - Device manager (BLE bond handling) for S110 and S120 are no longer in experimental status.
  4358. - db_discovery module (for GATT database discovery) for S120 is no longer in experimental status.
  4359. - New reliable transport layer for S110 SoftDevice serialization.
  4360. - Example ble_app_hrs_c (heart rate collector) for S120 is no longer in experimental status.
  4361. - Example ble_app_multilink_central for S120 is no longer in experimental status.
  4362. - Example ble_app_multilink_peripheral for S110 is no longer in experimental status.
  4363. - Experimental examples ble_app_ancs and ble_app_multiactivity have been deprecated from this release.
  4364. - Experimental example ble_app_uart for pca10001 has been deprecated from this release.
  4365. Proprietary
  4366. - None.
  4367. Fixed issues:
  4368. - NRFFOSDK-2884: Fixed issue in app_button module (function app_button_is_pushed).
  4369. - NRFFOSDK-1341: Added missing characteristic in Blood Glucose application.
  4370. - NRFFOSDK-2859: Removed redundant code in Blood Glucose application.
  4371. - NRFFOSDK-2557: Fixed some doxygen documentation errors.
  4372. Known issues:
  4373. - When flashing from Keil 4, a pop-up might appear stating "Cannot Load Flash Device Description !".
  4374. Solution:
  4375. - Write new flash algorithm settings to the uvopt file.
  4376. Press ALT+F7 to open "Options for Target" dialog.
  4377. Select "Options for Target" -> "Utilities".
  4378. Press "Settings" button to see flashing algorithms.
  4379. Verify that "nRF51xxx" is in the list of flashing algorithms, if not add it by pressing the "Add" button.
  4380. Exit and save settings by pressing "OK". This is also important to do if you did find the "nRF51xxx" in the list of flashing algorithms.
  4381. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  4382. Solution:
  4383. Press ALT+F7 to open "Options for Target" dialog.
  4384. Select "Options for Target" -> "Device".
  4385. Choose "Nordic nRF51 Series Devices" from the Database list.
  4386. Select the variant of the nRF51 chip that is used for the KEIL project target.
  4387. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  4388. Solution: Upgrade J-Link software to version 4.66 or later.
  4389. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  4390. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  4391. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  4392. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  4393. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  4394. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  4395. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  4396. Solution: Wake-up the current application from SYSTEM_OFF before flashing a new application.
  4397. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms.
  4398. This application will not be able to handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firmware update.
  4399. Workaround: If you face unexpected disconnects during firmware update process, consider increasing the connection interval used by the master.
  4400. ANT
  4401. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  4402. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  4403. BLE
  4404. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  4405. - S120 Examples: Flash clear operation may fail when connected. Impact of this in the S120 examples is that if peer loses the bond and a re-bonding occurs, flash clear fails, and DM_EVT_DEVICE_CONTEXT_STORED event is notified with a failure.
  4406. - Device manager has a few APIs unimplemented. Also documentation providing examples of how API can be used is missing.
  4407. - NRFFOSDK-2824: Device manager (pstorage) doesn't support update of bond split across two pages.
  4408. Proprietary:
  4409. - NRFFOSDK-1769: Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  4410. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  4411. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  4412. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  4413. - The legacy examples do not use "payload in ACK".
  4414. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4415. - The examples do not use dynamic payload length.
  4416. The legacy examples need to add the following in order to work with the nRF51 examples:
  4417. hal_nrf_setup_dynamic_payload(0xFF);
  4418. hal_nrf_enable_dynamic_payload(true);
  4419. hal_nrf_enable_ack_payload(true);
  4420. hal_nrf_set_rf_channel(10);
  4421. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4422. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  4423. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4424. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  4425. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4426. ========================================================================
  4427. nRF51 SDK v. 6.0.0
  4428. ------------------
  4429. Following toolchains/devices have been used for testing and verification:
  4430. - ARM: MDK-ARM Version 5.10.x/5.11.x
  4431. - GCC: gcc-arm-embedded 4.7 2013q1
  4432. - IAR: Embedded Workbench for ARM 6.60
  4433. - Windows XP SP3 32 bit
  4434. - Windows 7 SP1 64 bit
  4435. - Windows 8.0/8.1
  4436. Tested with devices:
  4437. - nRF51822 QFAAG0
  4438. - nRF51822 QFAAGC
  4439. - nRF51822 QFAAFA
  4440. - nRF51422 QFAAE0
  4441. For others devices, use SDK 4.x.x
  4442. Supported SoftDevices:
  4443. - S110 7.0.0
  4444. - S120 1.0.0
  4445. - S210 3.0.0
  4446. - S310 1.0.0
  4447. Supported boards:
  4448. - PCA10000 v1.0 (Only for use with Master Emulator)
  4449. - PCA10000 v2.1.0 and 2.2.0
  4450. - PCA10001 v2.1.0 and 2.2.0
  4451. - PCA10004 v2.1.0
  4452. - PCA10005 v2.1.0 and 2.2.0
  4453. - PCA10003 v3.0.0
  4454. Changes:
  4455. - Added partial support for Keil 5 uvprojx files.
  4456. ANT
  4457. - None
  4458. ANT + BLE (Dual stack)
  4459. BLE
  4460. - New module device manager replaces bond manager for storing persistent data
  4461. - Experimental device manager support for s120 (BLE central)
  4462. - S110 serialization solution has been reworked
  4463. - 100% s110 BLE APIs are now serialized
  4464. - S110 support for application concurrent multiprotocol radio access
  4465. - Pstorage module: Added API for doing range updates
  4466. - Experimental: Device firmware upgrade now supports updating both SoftDevice and bootloader for s110
  4467. Proprietary
  4468. - Enhanced ShockBurst: Added nrf_esb_reuse_pid() function to API, giving "reuse payload" functionality.
  4469. - Gazell: Added "suspend" mode enabling sharing of radio and PPI.
  4470. - Gazell: HW resources are released when Gazell is being disabled or entering suspend mode.
  4471. - Gazell: HW resources are reconfigured when Gazell is being enabled or exiting from suspend mode.
  4472. Fixed issues:
  4473. - NRFFOSDK-2542 - SoftDevice related documentation for S110, S120 and S310 BLE stack is not consistent. When looking up SoftDevice application interface or message sequence charts, it is possible that one is looking at incorrect interface. Recommendation hence is to look at SoftDevice headers to ensure correct appplication interface. This is also applicable for Serialization library references. This will be fixed in next release.
  4474. - SDK documentation has been splitted into 4 seperate documents with a common index page.
  4475. ANT
  4476. - None
  4477. ANT + BLE (Dual stack)
  4478. - S310 Heart Rate Relay Example: Bonding does not always function as expected. If bonding is enabled using compiler flag it is recommended to perform service discovery before bonding to minimize chances of unexpected behaviour.
  4479. BLE
  4480. Proprietary
  4481. - Enhanced ShockBurst/Gazell: Received packets in Host/PRX mode with CRC error can no longer return ACK to device.
  4482. - NRFFOSDK-2470: app_timer - Fixed issue where starting and stopping the timer repeatedly caused errors in the module
  4483. Known issues:
  4484. - When flashing from Keil 4, a pop-up might appear stating "Cannot Load Flash Device Description !".
  4485. Solution:
  4486. - Write new flash algorithm settings to the uvopt file.
  4487. Press ALT+F7 to open "Options for Target" dialog.
  4488. Select "Options for Target" -> "Utilities".
  4489. Press "Settings" button to see flashing algorithms.
  4490. Verify that "nRF51xxx" is in the list of flashing algorithms, if not add it by pressing the "Add" button.
  4491. Exit and save settings by pressing "OK". This is also important to do if you did find the "nRF51xxx" in the list of flashing algorithms.
  4492. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  4493. Solution:
  4494. Press ALT+F7 to open "Options for Target" dialog.
  4495. Select "Options for Target" -> "Device".
  4496. Choose "Nordic nRF51 Series Devices" from the Database list.
  4497. Select the variant of the nRF51 chip that is used for the KEIL project target.
  4498. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  4499. Solution: Upgrade J-Link software to version 4.66 or later.
  4500. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  4501. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  4502. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  4503. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  4504. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  4505. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  4506. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  4507. Solution: Wake-up the current application from SYSTEM_OFF before flashing a new application.
  4508. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms.
  4509. This application will not be able to handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firmware update.
  4510. Workaround: If you face unexpected disconnects during firmware update process, consider increasing the connection interval used by the master.
  4511. ANT
  4512. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  4513. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  4514. BLE
  4515. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  4516. - S120 Examples: Flash clear operation may fail when connected. Impact of this in the S120 examples is that if peer loses the bond and a re-bonding occurs, flash clear fails, and DM_EVT_DEVICE_CONTEXT_STORED event is notified with a failure.
  4517. - Device manager has a few APIs unimplemented. Also documentation providing examples of how API can be used is missing.
  4518. - NRFFOSDK-2824: Device manager (pstorage) doesn't support update of bond split across two pages.
  4519. Proprietary:
  4520. - NRFFOSDK-1769: Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  4521. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  4522. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  4523. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  4524. - The legacy examples do not use "payload in ACK".
  4525. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4526. - The examples do not use dynamic payload length.
  4527. The legacy examples need to add the following in order to work with the nRF51 examples:
  4528. hal_nrf_setup_dynamic_payload(0xFF);
  4529. hal_nrf_enable_dynamic_payload(true);
  4530. hal_nrf_enable_ack_payload(true);
  4531. hal_nrf_set_rf_channel(10);
  4532. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4533. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  4534. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4535. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  4536. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4537. ========================================================================
  4538. nRF51 SDK v. 5.2.0
  4539. ------------------
  4540. Following toolchains/devices have been used for testing and verification:
  4541. - ARM: MDK-ARM Version 5.10.x
  4542. - GCC: gcc-arm-embedded 4.7 2013q1
  4543. - IAR: Embedded Workbench for ARM 6.60
  4544. - Windows XP SP3 32 bit
  4545. - Windows 7 SP1 64 bit
  4546. - Windows 8.0/8.1
  4547. - The BLE example applications for HID Keyboard and HID Mouse have been tested with HID host running on Windows 8.1.
  4548. Tested with devices:
  4549. - nRF51822 QFAAG0
  4550. - nRF51822 QFAAGC
  4551. - nRF51822 QFAAFA
  4552. - nRF51422 QFAAE0
  4553. For others devices, use SDK 4.x.x
  4554. Supported SoftDevices:
  4555. - S110 6.0.0
  4556. - S120 1.0.0-1.alpha
  4557. - S210 3.0.0
  4558. - S310 1.0.0
  4559. Supported boards:
  4560. - PCA10000 v1.0 (Only for use with Master Emulator)
  4561. - PCA10000 v2.1.0 and 2.2.0
  4562. - PCA10001 v2.1.0 and 2.2.0
  4563. - PCA10004 v2.1.0
  4564. - PCA10005 v2.1.0 and 2.2.0
  4565. - PCA10003 v3.0.0
  4566. Changes:
  4567. - app_button module: Detect both push and release, instead of just push
  4568. - Persistent storage (pstorage) module:
  4569. - Support for writing to used memory regions with the new update API.
  4570. - Support for clearing single blocks.
  4571. - Added get_status API to identify pending flash operations.
  4572. ANT
  4573. - None
  4574. ANT + BLE (Dual stack)
  4575. - Support for s310 SoftDevice added.
  4576. - Heart rate monitor example project support added.
  4577. - Added Device Firmware Update (DFU) example for s310.
  4578. BLE
  4579. - New experimental device manager module for managing bonds on s120.
  4580. - Beacon example added. It is available at nrf51822\Board\nrf6310\s110\ble_app_beacon
  4581. and nrf51822\Board\pca10001\s110\ble_app_beacon.
  4582. - Multiple GATT clients: The Database Discovery module available in
  4583. nrf51822\Board\nrf6310\s120\experimental\common folder can now be used to
  4584. discover two GATT services at the peer.
  4585. - Serialized s110 advertisement example has been removed.
  4586. - HID Keyboard application modified to send upper case letters on pressing Button 2.
  4587. Proprietary
  4588. - None
  4589. Fixed issues:
  4590. ANT
  4591. - None
  4592. ANT + BLE (Dual stack)
  4593. - None
  4594. BLE
  4595. - NRFFOSDK-1897: Glucose: Fixed bug where authentication was not initiated when connecting to already bonded master.
  4596. - NRFFOSDK-2318: Glucose Feature values had incorrect values for 'General Device Fault Supported', 'Time fault Supported', and 'Multiple Bond Supported'. This has been fixed.
  4597. - ANCS: The advertising interval of the Apple Notification Center Client example application is reduced to 25 ms. Previously it was 250 ms which made it hard to discover from the peer device.
  4598. - NRFFOSDK-2357: Blood Pressure application changed to check if indication is enabled before attempting to send an indication to the peer
  4599. - NRFFOSDK-2336: HID Keyboard application fixed to send the correct Input Report bytes when in Boot Mode.
  4600. - Fixed issue in bond manager related to clearing of whitelist on deleting all bonds.
  4601. - NRFFOSDK-2162: New pstorage get_status API used to allow for flash access to be completed before system off.
  4602. Proprietary
  4603. - NRFFOETT-644 - Gazell / ESB: Fixed some documentation issues.
  4604. Known issues:
  4605. - NRFFOSDK-2542 - SoftDevice related documentation for S110, S120 and S310 BLE stack is not consistent. When looking up SoftDevice application interface or message sequence charts, it is possible that one is looking at incorrect interface. Recommendation hence is to look at SoftDevice headers to ensure correct appplication interface. This is also applicable for Serialization library references. This will be fixed in next release.
  4606. - When flashing from Keil 4, a pop-up might appear stating "Cannot Load Flash Device Description !".
  4607. Solution:
  4608. - Write new flash algorithm settings to the uvopt file.
  4609. Press ALT+F7 to open "Options for Target" dialog.
  4610. Select "Options for Target" -> "Utilities".
  4611. Press "Settings" button to see flashing algorithms.
  4612. Verify that "nRF51xxx" is in the list of flashing algorithms, if not add it by pressing the "Add" button.
  4613. Exit and save settings by pressing "OK". This is also important to do if you did find the "nRF51xxx" in the list of flashing algorithms.
  4614. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  4615. Solution:
  4616. Press ALT+F7 to open "Options for Target" dialog.
  4617. Select "Options for Target" -> "Device".
  4618. Choose "Nordic nRF51 Series Devices" from the Database list.
  4619. Select the variant of the nRF51 chip that is used for the KEIL project target.
  4620. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  4621. Solution: Upgrade J-Link software to version 4.66 or later.
  4622. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  4623. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  4624. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  4625. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  4626. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  4627. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  4628. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  4629. Solution: Wake-up the current application from SYSTEM_OFF before flashing a new application.
  4630. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms.
  4631. This application will not be able to handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firware update.
  4632. Workaround: If you face unexpected disconnects during firmware update process, consider increasing the connection interval used by the master.
  4633. ANT
  4634. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  4635. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  4636. ANT + BLE (Dual stack)
  4637. - S310 Heart Rate Relay Example: Bonding does not always function as expected. If bonding is enabled using compiler flag it is recommended to perform service discovery before bonding to minimize chances of unexpected behavior.
  4638. BLE
  4639. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  4640. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application.
  4641. (If the bonding information is not erased manually - by pressing button 1 during start-up - the new application might assert. )
  4642. - S120 Examples: Flash clear operation may fail when connected. Impact of this in the S120 examples is that if peer loses the bond and a re-bonding occurs, flash clear fails, and DM_EVT_DEVICE_CONTEXT_STORED event is notified with a failure.
  4643. - Device manager is an experimental module and has a few APIs unimplemented. Also documentation providing examples of how API can be used is missing.
  4644. Proprietary:
  4645. - NRFFOSDK-1769: Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  4646. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  4647. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  4648. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  4649. - The legacy examples do not use "payload in ACK".
  4650. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4651. - The examples do not use dynamic payload length.
  4652. The legacy examples need to add the following in order to work with the nRF51 examples:
  4653. hal_nrf_setup_dynamic_payload(0xFF);
  4654. hal_nrf_enable_dynamic_payload(true);
  4655. hal_nrf_enable_ack_payload(true);
  4656. hal_nrf_set_rf_channel(10);
  4657. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4658. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  4659. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4660. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  4661. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4662. ========================================================================
  4663. nRF51 SDK v. 5.1.0
  4664. ------------------
  4665. Following toolchains/devices have been used for testing and verification:
  4666. - ARM: MDK-ARM Version 5.0.5.x
  4667. - GCC: gcc-arm-embedded 4.7 2013q1
  4668. - IAR: Embedded Workbench for ARM 6.60
  4669. - Windows XP SP3 32 bit
  4670. - Windows 7 SP1 64 bit
  4671. - Windows 8.0/8.1
  4672. - The BLE example applications for HID Keyboard and HID Mouse have been tested with HID host running on Windows 8.1.
  4673. Tested with devices:
  4674. - nRF51822 QFAAGC (For others, use SDK 4.x.x)
  4675. - nRF51822 QFAAFA (For others, use SDK 4.x.x)
  4676. - nRF51422 QFAADA (For others, use SDK 4.x.x)
  4677. Supported SoftDevices:
  4678. - S110 6.0.0
  4679. - S120 0.8.0-2.alpha
  4680. - S210 3.0.0-3.beta
  4681. - S310 1.0.0-2.alpha
  4682. Supported boards:
  4683. - PCA10000 v1.0 (Only for use with Master Emulator)
  4684. - PCA10000 v2.1.0 and 2.2.0
  4685. - PCA10001 v2.1.0 and 2.2.0
  4686. - PCA10004 v2.1.0
  4687. - PCA10005 v2.1.0 and 2.2.0
  4688. Changes:
  4689. - Moved and renamed SoftDevice header folders:
  4690. from nrf51822/Include/ble/softdevice to nrf51822/Include/s110
  4691. from nrf51422/Include/ble/softdevice to nrf51422/Include/s210
  4692. - Added SoftDevice headers for s120 and s310 at:
  4693. nrf51822/Include/s120
  4694. nrf51422/Include/s310
  4695. - Moved ANT examples from nrf51422/Board/<board name>/ant to nrf51422/Board/<board name>/s210
  4696. - Moved s110 SoftDevice examples from nrf51822/Board/<board name>/ble to nrf51822/Board/<board name>/s110
  4697. - Added folder for s310 examples in nrf51422/Board/<board name>/s310
  4698. - Added folder for s120 SoftDevice examples in nrf51822/Board/<board name>/s120
  4699. ANT
  4700. - The flash layout settings of all ANT examples have been adapted to suit the new flash layout of S210 SoftDevice.
  4701. BLE
  4702. - Added experimental Multilink (up to 8) Central example which uses s120 SoftDevice.
  4703. - Added experimental Heart Rate collector example which uses s120 SoftDevice.
  4704. - Added prototype iBeacon example.
  4705. Proprietary
  4706. Fixed issues:
  4707. - NRFFOETT-671: Added support for creating new nRF51 projects in Keil 5.
  4708. ANT
  4709. - NRFFOETT-438: The API documentation of S210 SoftDevice is now correctly structured in the SDK documentation.
  4710. BLE
  4711. Proprietary
  4712. Known issues:
  4713. - When flashing from Keil 4, a pop-up might appear stating "Cannot Load Flash Device Description !".
  4714. Solution:
  4715. - Write new flash algorithm settings to the uvopt file.
  4716. Press ALT+F7 to open "Options for Target" dialog.
  4717. Select "Options for Target" -> "Utilities".
  4718. Press "Settings" button to see flashing algorithms.
  4719. Verify that "nRF51xxx" is in the list of flashing algorithms, if not add it by pressing the "Add" button.
  4720. Exit and save settings by pressing "OK". This is also important to do if you did find the "nRF51xxx" in the list of flashing algorithms.
  4721. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  4722. Solution:
  4723. Press ALT+F7 to open "Options for Target" dialog.
  4724. Select "Options for Target" -> "Device".
  4725. Choose "Nordic nRF51 Series Devices" from the Database list.
  4726. Select the variant of the nRF51 chip that is used for the KEIL project target.
  4727. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  4728. Solution: Upgrade J-Link software to version 4.66 or later.
  4729. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  4730. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  4731. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  4732. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  4733. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  4734. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  4735. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  4736. Solution: Wake-up the current application from SYSTEM_OFF before flashing a new application.
  4737. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms.
  4738. This application will not be able to handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firware update.
  4739. Workaround: If you face unexpected disconnects during firmware update process, consider increasing the connection interval used by the master.
  4740. ANT
  4741. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  4742. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  4743. BLE
  4744. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  4745. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application.
  4746. (If the bonding information is not erased manually - by pressing button 1 during start-up - the new application might assert. )
  4747. - NRFFOSDK-2162 - Heart Rate application for PCA10001 possible inconsistent system attributes on power cycle. It is possible that the system attributes on power cycle are not consistent with the ones updated during previous connection.
  4748. Proprietary:
  4749. - NRFFOSDK-1769: Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  4750. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  4751. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  4752. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  4753. - The legacy examples do not use "payload in ACK".
  4754. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4755. - The examples do not use dynamic payload length.
  4756. The legacy examples need to add the following in order to work with the nRF51 examples:
  4757. hal_nrf_setup_dynamic_payload(0xFF);
  4758. hal_nrf_enable_dynamic_payload(true);
  4759. hal_nrf_enable_ack_payload(true);
  4760. hal_nrf_set_rf_channel(10);
  4761. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4762. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  4763. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4764. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  4765. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4766. ========================================================================
  4767. nRF51 SDK v. 5.0.0
  4768. ------------------
  4769. Following toolchains/devices have been used for testing and verification:
  4770. - ARM: MDK-ARM Version 4.72.1.0
  4771. - GCC: gcc-arm-embedded 4.7 2013q1
  4772. - IAR: embedded workbench for ARM 6.60
  4773. - Windows XP SP3 32 bit
  4774. - Windows 7 SP1 64 bit
  4775. - Windows 8.0/8.1
  4776. - The BLE example applications for HID Keyboard and HID Mouse have been tested with HID host running on Windows 8.1.
  4777. Tested with devices:
  4778. - nRF51822 QFAAGC (For others, use SDK 4.x.x)
  4779. - nRF51822 QFAAFA (For others, use SDK 4.x.x)
  4780. - nRF51422 QFAADA (For others, use SDK 4.x.x)
  4781. Supported SoftDevices:
  4782. - S110 6.0.0-3 Beta
  4783. - Expected to be Compatible with SoftDevice S110 V6.0.0 production version
  4784. Supported boards:
  4785. - PCA10000 v1.0 (Only for use with Master Emulator)
  4786. - PCA10000 v2.1.0 and 2.2.0
  4787. - PCA10001 v2.1.0 and 2.2.0
  4788. - PCA10004 v2.1.0
  4789. - PCA10005 v2.1.0
  4790. NOTE: The ANT examples in this release will only work on nRF51422 QFAADA engineering samples.
  4791. Currently no official boards/kits exist that work with these examples.
  4792. Changes:
  4793. - Added pstorage module for handling asynchronous non-volatile memory (flash) access via SoftDevice API
  4794. - Existing BLE event handler has been extended into the new SoftDevice handler module. The new SoftDevice handler module allows for fetching SoC, BLE and ANT events
  4795. - Restructured documentation
  4796. ANT
  4797. BLE
  4798. - Changes for support of S110 V6.0.0-3 Beta
  4799. - Added Apple Notification Center in experimental
  4800. Proprietary
  4801. - SPI slave driver and example code added
  4802. - Include new ESB library which uses the same peripherals as the S110 SoftDevice
  4803. Fixed issues:
  4804. ANT
  4805. BLE
  4806. Proprietary
  4807. Known issues:
  4808. - Creating a blank project with Keil V5.0 it is not possible to choose the nRF51 series.
  4809. Solution:
  4810. Start new projects by making a copy of any existing keil project from the SDK
  4811. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  4812. Solution:
  4813. Press ALT+F7 to open "Options for Target" dialog.
  4814. Select "Options for Target" -> "Device".
  4815. Choose "Nordic nRF51 Series Devices" from the Database list.
  4816. Select the variant of the nRF51 chip that is used for the KEIL project target.
  4817. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  4818. Solution: Upgrade J-Link software to version 4.66 or later.
  4819. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  4820. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  4821. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  4822. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  4823. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  4824. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  4825. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  4826. Solution: Wake-up the current application from SYSTEM_OFF before flashing a new application.
  4827. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms.
  4828. This application will not be able to handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firware update.
  4829. Workaround: If you face unexpected disconnects during firmware update process, consider increasing the connection interval used by the master.
  4830. ANT
  4831. - NRFFOETT-438 - Documentation on S210 SoftDevice API wrongly structured. All SoftDevice functions appear as SVCALL in the Doxygen page.
  4832. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  4833. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  4834. BLE
  4835. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  4836. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application.
  4837. (If the bonding information is not erased manually - by pressing button 1 during start-up - the new application might assert. )
  4838. - NRFFOSDK-2162 - Heart Rate application for PCA10001 possible inconsistent system attributes on power cycle. It is possible that the system attributes on power cycle are not consistent with the ones updated during previous connection.
  4839. Proprietary:
  4840. - NRFFOSDK-1769: Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  4841. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  4842. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  4843. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  4844. - The legacy examples do not use "payload in ACK".
  4845. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4846. - The examples do not use dynamic payload length.
  4847. The legacy examples need to add the following in order to work with the nRF51 examples:
  4848. hal_nrf_setup_dynamic_payload(0xFF);
  4849. hal_nrf_enable_dynamic_payload(true);
  4850. hal_nrf_enable_ack_payload(true);
  4851. hal_nrf_set_rf_channel(10);
  4852. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4853. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  4854. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4855. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  4856. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4857. ========================================================================
  4858. nRF51 SDK v. 4.4.2
  4859. ------------------
  4860. Following toolchains/devices have been used for testing and verification:
  4861. - ARM: MDK-ARM Version 4.72.1.0
  4862. - GCC: gcc-arm-embedded 4.7 2013q1
  4863. - IAR: embedded workbench for ARM 6.60
  4864. - N51822 QFAACA on PCA10004 module on nRF6310 motherboard
  4865. - N51822 QFAAFA on PCA10005 module on nRF6310 motherboard
  4866. - Windows XP SP3 32 bit
  4867. - Windows 7 SP1 64 bit
  4868. - Windows 8.0/8.1
  4869. - BLE SoftDevice Version : s110_nrf51822_5.2.1
  4870. - The BLE example applications for HID Keyboard and HID Mouse have been tested with HID host running on Windows 8.1.
  4871. - Supported boards in nRF51 SDK v. 4.4.2:
  4872. - PCA10000 v1.0 (Only for use with Master Emulator)
  4873. - PCA10000 v2.0.0
  4874. - PCA10001 v1.0 through v2.1.0
  4875. - PCA10003 v1.0 through v2.0.0
  4876. - PCA10004 v1.0 through v2.0.0
  4877. - PCA10005 v1.0 through v2.1.0
  4878. - PCA10006 v1.0 through v2.0.0
  4879. - PCA10007 v1.0 through v2.0.0
  4880. - PCA10014 v1.0
  4881. - PCA10018 v1.0.0 through v1.1.0
  4882. Changes:
  4883. ANT
  4884. None
  4885. BLE
  4886. - Removed ble_dfu_send_hex.exe from device_firmware_update experimental folder. Similar feature is now available in latest Master Control Panel application.
  4887. Proprietary
  4888. None
  4889. Fixed issues:
  4890. - NRFFOSDK-1750 - Added PAN-11 workaround in PPI, PWM, and Simple PWM motor control examples.
  4891. - NRFFOSDK-1633 - Added PAN-56 workaround in TWI master driver.
  4892. ANT
  4893. None
  4894. BLE
  4895. - NRFFOSDK-1025 - The field max_len in rep_char_add signature in ble_hids.c has been corrected to uint16_t.
  4896. - NRFFOSDK-1921 - In case IRK is distrubuted by a peer using public address whitelist is updated for both IRK and address.
  4897. - NRFFOSDK-1899 - System attributes re-initialized on rebonding.
  4898. - NRFFOSDK-1900 - Removed false detection of DIV collisions.
  4899. - NRFFOSDK-1993 - Increased buffer in hci_mem_pool_internal.h fix the serialization examples.
  4900. Proprietary
  4901. None
  4902. Known issues:
  4903. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  4904. Solution:
  4905. Press ALT+F7 to open "Options for Target" dialog.
  4906. Select "Options for Target" -> "Device".
  4907. Choose "Nordic nRF51 Series Devices" from the Database list.
  4908. Select the variant of the nRF51 chip that is used for the KEIL project target.
  4909. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  4910. Solution: Upgrade J-Link software to version 4.66 or later.
  4911. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  4912. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  4913. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  4914. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  4915. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  4916. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  4917. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  4918. Solution: Wake-up the current application from SYSTEM_OFF before flashing a new application.
  4919. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms.
  4920. This application will not be able to handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firware update.
  4921. Workaround: If you face unexpected disconnects during firmware update process, consider increasing the connection interval used by the master.
  4922. ANT
  4923. - NRFFOETT-438 - Documentation on S210 SoftDevice API wrongly structured. All SoftDevice functions appear as SVCALL in the Doxygen page.
  4924. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  4925. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  4926. BLE
  4927. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  4928. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application.
  4929. (If the bonding information is not erased manually - by pressing button 1 during start-up - the new application might assert. )
  4930. Proprietary:
  4931. - NRFFOSDK-1769: Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  4932. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  4933. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  4934. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  4935. - The legacy examples do not use "payload in ACK".
  4936. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  4937. - The examples do not use dynamic payload length.
  4938. The legacy examples need to add the following in order to work with the nRF51 examples:
  4939. hal_nrf_setup_dynamic_payload(0xFF);
  4940. hal_nrf_enable_dynamic_payload(true);
  4941. hal_nrf_enable_ack_payload(true);
  4942. hal_nrf_set_rf_channel(10);
  4943. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  4944. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  4945. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  4946. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  4947. - Gazell does not support "Low Power Host mode" (Host mode 1).
  4948. ========================================================================
  4949. nRF51 SDK v. 4.4.1
  4950. ------------------
  4951. Following toolchains/devices have been used for testing and verification:
  4952. - ARM: MDK-ARM Version 4.71.2
  4953. - GCC: gcc-arm-embedded 4.7 2013q1
  4954. - IAR: embedded workbench for ARM 6.60
  4955. - N51422 QFAACA on PCA10003 evaluation kit board
  4956. - N51822 QFAACA on PCA10004/5 module on nRF6310 motherboard
  4957. - Windows XP SP3 32 bit
  4958. - Windows 7 SP1 64 bit
  4959. - BLE SoftDevice Version : s110_nrf51822_5.2.1
  4960. - The BLE example applications for HID Keyboard and HID Mouse have been tested with HID host running on Windows 8.1 Preview.
  4961. Changes:
  4962. - DFU documentation improved.
  4963. ANT
  4964. None
  4965. BLE
  4966. - NRFFOSDK-1759: Example IAR application for Heart Rate Service added.
  4967. - NRFFOSDK-1271: Speed and Cadence Control Point added to Cycling Speed and Cadence Service.
  4968. Proprietary
  4969. - ESB: Improved tolerance to delayed interrupts.
  4970. Fixed issues:
  4971. - NRFFOSDK-1592: Risk of losing timer interrupts when the resolution of the timer is very high, e.g. 1 ms resolution, is now fixed.
  4972. ANT
  4973. None
  4974. BLE
  4975. - NRFFOETT-399: An IRK is added to the bond manager's whitelist only if the address type of the master is 'resolvable'.
  4976. - NRFFOETT-552: DTM application is now implementing PCN_083
  4977. - NRFFOSDK-1828: Key refresh was triggering a link failure when re-bonding to a master. This is now fixed.
  4978. - NRFFOETT-571: Premature disconnection scenario handling added to bond manager. Previously this was resulting in system attributes of a master to be cleared.
  4979. Proprietary
  4980. - ESB: The nrf_esb_tx_failed() callback function was never called when dynamic acknowledgement was used. This is now fixed.
  4981. Known issues:
  4982. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  4983. Solution:
  4984. Press ALT+F7 to open "Options for Target" dialog.
  4985. Select "Options for Target" -> "Device".
  4986. Choose "Nordic nRF51 Series Devices" from the Database list.
  4987. Select the variant of the nRF51 chip that is used for the KEIL project target.
  4988. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  4989. Solution: Upgrade J-Link software to version 4.66 or later.
  4990. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  4991. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  4992. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  4993. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  4994. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  4995. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  4996. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  4997. Solution: Wake-up the current application from SYSTEM_OFF before flashing a new application.
  4998. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms.
  4999. This application will not be able to handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firware update.
  5000. Workaround: If you face unexpected disconnects during firmware update process, consider increasing the connection interval used by the master.
  5001. ANT
  5002. - NRFFOETT-438 - Documentation on S210 SoftDevice API wrongly structured. All SoftDevice functions appear as SVCALL in the Doxygen page.
  5003. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  5004. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  5005. BLE
  5006. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  5007. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application.
  5008. (If the bonding information is not erased manually - by pressing button 1 during start-up - the new application might assert. )
  5009. Proprietary:
  5010. - NRFFOSDK-1769: Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  5011. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5012. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  5013. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  5014. - The legacy examples do not use "payload in ACK".
  5015. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  5016. - The examples do not use dynamic payload length.
  5017. The legacy examples need to add the following in order to work with the nRF51 examples:
  5018. hal_nrf_setup_dynamic_payload(0xFF);
  5019. hal_nrf_enable_dynamic_payload(true);
  5020. hal_nrf_enable_ack_payload(true);
  5021. hal_nrf_set_rf_channel(10);
  5022. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  5023. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  5024. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  5025. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  5026. - Gazell does not support "Low Power Host mode" (Host mode 1).
  5027. ========================================================================
  5028. nRF51 SDK v. 4.4.0
  5029. ------------------
  5030. Following toolchains/devices have been used for testing and verification:
  5031. - ARM: MDK-ARM Version 4.71.2
  5032. - GCC: gcc-arm-embedded 4.7 2013q1
  5033. - N51422 QFAACA on PCA10003 evaluation kit board
  5034. - N51822 QFAACA on PCA10004/5 module on nRF6310 motherboard
  5035. - Windows XP SP3 32 bit
  5036. - Windows 7 SP1 64 bit
  5037. - BLE SoftDevice Version : s110_nrf51822_5.2.1
  5038. - The BLE example applications for HID Keyboard and HID Mouse have been tested with HID host running on Windows 8.
  5039. Changes:
  5040. - Device Firmware Update example released as part of the main SDK.
  5041. - Added support for image transfer over BLE.
  5042. - HCI Transport Layer used for serial transfer.
  5043. - Note: This example is implemented to work on nRF6310 motherboard because it uses Button 7 to enter bootloader mode on reset.
  5044. This is because Button 0 and Button 1 are used by other SDK applications as wakeup buttons.
  5045. If this example is to be changed to work for evaluation kit board, then this should be taken into consideration.
  5046. - PC application examples for performing firmware updates using HCI and BLE added in nrf6310\device_firmware_updates\experimental folder.
  5047. - UICR Configuration example added to the SDK. It can be found in nrf6310\uicr_config_example folder.
  5048. ANT
  5049. None
  5050. BLE
  5051. - NRFFOETT-507: ble_app_dtm missing bytes on UART fixed.
  5052. - NRFFOSDK-73 : HID keyboard application will now send one key press per notification.
  5053. Proprietary
  5054. None
  5055. Fixed issues:
  5056. ANT
  5057. None
  5058. BLE
  5059. - NRFFOSDK-1432: Buffer overflow issue in ble_bondmngr_sys_attr_store() function fixed.
  5060. - NRFFOETT-339: CCCD values (System Atributes) are now restored on reconnection to a known master only after the link is encrypted.
  5061. Proprietary
  5062. None
  5063. Known issues:
  5064. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  5065. Solution:
  5066. Press ALT+F7 to open "Options for Target" dialog.
  5067. Select "Options for Target" -> "Device".
  5068. Choose "Nordic nRF51 Series Devices" from the Database list.
  5069. Select the variant of the nRF51 chip that is used for the KEIL project target.
  5070. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  5071. Solution: Upgrade J-Link software to version 4.66 or later.
  5072. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5073. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  5074. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5075. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  5076. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  5077. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  5078. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  5079. Solution: Wake-up the current application from SYSTEM_OFF before flashing a new application.
  5080. - NRFFOSDK-1774: During SDK installation, chosing custom install location for SDK examples will create Start Menu shortcuts that point to Keil installation location.
  5081. - NRFFOSDK-1592: There is a risk of losing timer interrupts when the resolution of the timer is very high, e.g. 1 ms resolution.
  5082. - The DFU over BLE example has been tested to work with a minimum connection interval of 11.25 ms.
  5083. This application will not be able to handle connection intervals lower than 11.25 ms and may undergo a system reset in the middle of a firware update.
  5084. Workaround: If you face unexpected disconnects during firmware update process, consider increasing the connection interval used by the master.
  5085. ANT
  5086. - NRFFOETT-438 - Documentation on S210 SoftDevice API wrongly structured. All SoftDevice functions appear as SVCALL in the Doxygen page.
  5087. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  5088. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  5089. BLE
  5090. - NRFFOETT-399 - The bond manager will use distrubted IRK in its whitelist regardless of the type of central's address and should actually use the irk if distributed and if the central's address is not public, and not random_static and not random_private_non_resovable.
  5091. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  5092. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application.
  5093. (If the bonding information is not erased manually - by pressing button 1 during start-up - the new application might assert. )
  5094. Proprietary:
  5095. - NRFFOSDK-1769: Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  5096. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5097. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  5098. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  5099. - The legacy examples do not use "payload in ACK".
  5100. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  5101. - The examples do not use dynamic payload length.
  5102. The legacy examples need to add the following in order to work with the nRF51 examples:
  5103. hal_nrf_setup_dynamic_payload(0xFF);
  5104. hal_nrf_enable_dynamic_payload(true);
  5105. hal_nrf_enable_ack_payload(true);
  5106. hal_nrf_set_rf_channel(10);
  5107. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  5108. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  5109. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  5110. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  5111. - Gazell does not support "Low Power Host mode" (Host mode 1).
  5112. ========================================================================
  5113. nRF51 SDK v. 4.3.0
  5114. ------------------
  5115. Following toolchains/devices have been used for testing and verification:
  5116. - ARM: MDK-ARM Version 4.60
  5117. - GCC: gcc-arm-embedded 4.7 2013q1
  5118. - N51422 QFAACA on PCA10003 evaluation kit board
  5119. - N51822 QFAACA on PCA10004/5 module on nRF6310 motherboard
  5120. - Windows XP SP3 32 bit
  5121. - Windows 7 SP1 64 bit
  5122. - BLE SoftDevice Version : s110_nrf51822_5.2.0
  5123. Changes:
  5124. - Supported GCC toolchain switched from CodeSourcery to gcc-arm-embedded.
  5125. - New gcc startup file, linker scripts, and makefiles.
  5126. - Updated CMSIS header files in Include/gcc to the latest revision (3.20).
  5127. - Makefile target "all" now runs "clean" and "debug" targets instead of incremental "release" target.
  5128. - nrf.h requires projects to have a define for a chip to enable some needed workarounds.
  5129. - SDK examples now support PCA10000 v2.0.0. To make the examples work on the older PCA10000 v1.0, the UART pins need to be remapped in the pca10000.h header file.
  5130. For v1.0
  5131. #define RX_PIN_NUMBER 3
  5132. #define TX_PIN_NUMBER 1
  5133. #define CTS_PIN_NUMBER 2
  5134. #define RTS_PIN_NUMBER 0
  5135. For v2.0.0
  5136. #define RX_PIN_NUMBER 11
  5137. #define TX_PIN_NUMBER 9
  5138. #define CTS_PIN_NUMBER 10
  5139. #define RTS_PIN_NUMBER 8
  5140. ANT
  5141. - ANT examples have been updated to support the newest UART API.
  5142. BLE
  5143. - HCI Transport Layer from Bluetooth Specification v4.0 introduced for BLE S110 Serialized Applications.
  5144. - BLE S110 Serialization Examples released as part of the main SDK.
  5145. - Updated serialized ble_app_advertising and ble_app_hrs to use app_scheduler.
  5146. - Connection Parameter update module : Added possibility to request different connection parameters multiple times. A new event, BLE_CONN_PARAMS_EVT_SUCCEEDED has been created. Event handler implementation needs to take this into account, especially if they were implemented to trigger a disconnect regardless of the type of event.
  5147. - Added Makefile and Eclipse project file for ble_app_hrs.
  5148. - Changed hard coded flash pages to be FICR CODESIZE dependent.
  5149. Proprietary
  5150. - Gazell:
  5151. - Added Gazell Pairing Host source code and board example. Backwards compatible with nRF24L Gazell Pairing Device and Host modules.
  5152. - Added function nrf_gzll_set_auto_disable(uint32_t num_ticks), to disable Gazell after a number of timeslots.
  5153. - Added function nrf_gzll_get_tick_count().
  5154. - Gazell Pairing Device now uses nrf_gzll_get_tick_count() in order to implement a delay. This reduces current consumption.
  5155. - Default sync_lifetime value has been increased to 3*channel_table_size*number_of_timeslots_per_channel. This improves performance in high-interference environments. Current users who are satisfied with the performance may wish to maintain the minimum value of 1*channel_table_size*number_of_timeslots_per_channel, in order to avoid any slight increase in current consumption.
  5156. - Enhanced ShockBurst:
  5157. - ESB PTX now calls nrf_esb_tx_success() callback instead of nrf_esb_tx_failed() for NOACK packets.
  5158. - Fix in nrf_esb_set_mode()
  5159. - Information concerning backwards compatibility with nRF24L devices has been moved to the User Guide.
  5160. Fixed issues:
  5161. - Examples doing flash writes were not waiting for writes to finish.
  5162. ANT
  5163. - NRFFOSDK-1312 - Changed ANTFS_TRANSMIT_POWER define in antfs.h from 0 to 3. The define previously had an incorrect definition which set the power value to -20dBm instead of 0dBm even though the comment indicated 0dBm.
  5164. BLE
  5165. - NRFFOETT-402 - DFU Bootloader application in experimental project now sets stack pointer correctly before executing reset vector of application.
  5166. Proprietary
  5167. - NRFFOETT-301 - Radio example uses obsolete RADIO_TXPOWER_TXPOWER_Neg40dBm definition.
  5168. - Fixed issue in TWI HW driver. Event was not cleared before waiting it to get cleared.
  5169. - Floating point ABI used by Makefiles was incorrect. Now using mabi-float=soft.
  5170. - Gazell/ESB: Fixed set_mode() functionality.
  5171. - Gazell GCC board examples startup and run correctly with the GCC libraries.
  5172. - A Gazell Device nows stop the RSSI measurement when no ACK is received, improving the base current consumption.
  5173. Known issues:
  5174. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  5175. Solution:
  5176. Press ALT+F7 to open "Options for Target" dialog.
  5177. Select "Options for Target" -> "Device".
  5178. Choose "Nordic nRF51 Series Devices" from the Database list.
  5179. Select the variant of the nRF51 chip that is used for the KEIL project target.
  5180. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  5181. Solution: Upgrade J-Link software to version 4.66 or later.
  5182. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5183. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  5184. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5185. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  5186. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  5187. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  5188. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  5189. Solution: Wake-up the current application from SYSTEM_OFF before flashing a new application.
  5190. ANT
  5191. - NRFFOETT-438 - Documentation on S210 SoftDevice API wrongly structured. All SoftDevice functions appear as SVCALL in the Doxygen page.
  5192. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  5193. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  5194. BLE
  5195. - NRFFOETT-399 - The bond manager will use distrubted IRK in its whitelist regardless of the type of central's address and should actually use the irk if distributed and if the central's address is not public, and not random_static and not random_private_non_resovable.
  5196. - NRFFOSDK-1432 - A buffer overflow has been discovered in the BLE bond manager upon system attributes store. Workaround, define BLE_BONDMNGR_MAX_BONDED_MASTERS in ble_bondmngr_cfg.h to be 1 higher than the number of bond required by the applicaiton.
  5197. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  5198. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application.
  5199. (If the bonding information is not erased manually - by pressing button 1 during start-up - the new application might assert. )
  5200. Proprietary:
  5201. - Not all examples have makefiles, nor have they been tested with the new toolchain. Expect minor compilation issues.
  5202. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5203. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  5204. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  5205. - The legacy examples do not use "payload in ACK".
  5206. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  5207. - The examples do not use dynamic payload length.
  5208. The legacy examples need to add the following in order to work with the nRF51 examples:
  5209. hal_nrf_setup_dynamic_payload(0xFF);
  5210. hal_nrf_enable_dynamic_payload(true);
  5211. hal_nrf_enable_ack_payload(true);
  5212. hal_nrf_set_rf_channel(10);
  5213. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  5214. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  5215. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  5216. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  5217. - Gazell does not support "Low Power Host mode" (Host mode 1).
  5218. ========================================================================
  5219. nRF51 SDK v. 4.2.0
  5220. ------------------
  5221. Following toolchains/devices have been used for testing and verification:
  5222. - ARM: MDK-ARM Version 4.60
  5223. - N51422 QFAACA on PCA10003 evaluation kit board
  5224. - N51822 QFAACA on PCA10004/5 module on nRF6310 motherboard
  5225. - Windows XP SP3 32 bit
  5226. - Windows 7 SP1 64 bit
  5227. - BLE SoftDevice Version : s110_nrf51822_5.1.0
  5228. Changes:
  5229. ANT
  5230. BLE
  5231. - NRFFOSDK-623 - BLE S110 DFU Bootloader prototype added to experimental folder.
  5232. - NRFFOSDK-996 - Delete of individual bonds in Bond Manager. API extension.
  5233. Validity check of stored bond added to Bond Manager API.
  5234. - NRFFOSDK-745 - Extended BLE S110 Serialized API.
  5235. Added serialized Heartrate example to exprimental folder.
  5236. Proprietary
  5237. Fixed issues:
  5238. - NRFFOSDK-1015 - nRFgo Display lock up after a reset
  5239. ANT
  5240. BLE
  5241. - NRFFOSDK-486 - All applications using bond manager will assert when the maximum number of bonded masters is passed.
  5242. Proprietary
  5243. Known issues:
  5244. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  5245. Solution:
  5246. Press ALT+F7 to open "Options for Target" dialog.
  5247. Select "Options for Target" -> "Device".
  5248. Choose "Nordic nRF51 Series Devices" from the Database list.
  5249. Select the variant of the nRF51 chip that is used for the KEIL project target.
  5250. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  5251. Solution: Upgrade J-Link software to version 4.66 or later.
  5252. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5253. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  5254. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5255. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  5256. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  5257. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  5258. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  5259. Solution: Wake-up the current application from SYTEM_OFF before flashing a new application.
  5260. ANT
  5261. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  5262. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  5263. BLE
  5264. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  5265. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application.
  5266. (If the bonding information is not erased manually - by pressing button 1 during start-up - the new application might assert. )
  5267. Proprietary:
  5268. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5269. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  5270. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  5271. - The legacy examples do not use "payload in ACK".
  5272. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  5273. - The examples do not use dynamic payload length.
  5274. The legacy examples need to add the following in order to work with the nRF51 examples:
  5275. hal_nrf_setup_dynamic_payload(0xFF);
  5276. hal_nrf_enable_dynamic_payload(true);
  5277. hal_nrf_enable_ack_payload(true);
  5278. hal_nrf_set_rf_channel(10);
  5279. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  5280. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  5281. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  5282. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  5283. - Gazell does not support "Low Power Host mode" (Host mode 1).
  5284. ========================================================================
  5285. nRF51 SDK v. 4.1.0
  5286. ------------------
  5287. Following toolchains/devices have been used for testing and verification:
  5288. - ARM: MDK-ARM Version 4.60
  5289. - N51422 QFAACA on PCA10003 evaluation kit board
  5290. - N51822 QFAACA on PCA10004/5 module on nRF6310 motherboard
  5291. - Windows XP SP3 32 bit
  5292. - Windows 7 SP1 64 bit
  5293. - BLE SoftDevice Version : s110_nrf51822_5.0.0
  5294. Changes:
  5295. - nRF51 device variant removed from KEIL device database and replaced with nRF51 series specific devices.
  5296. - Added nrf6310_experimental folder to the nRF51 SDK which contains examples and modules under development.
  5297. - Experimental version of the SoftDevice S110 serialization API with examples.
  5298. - Removed obsolete Master Emulator firmware from the release (nrf51822\Board\pca10000\ble\master_emulator\MEFW_nRF51822_firmware.hex).
  5299. - Renamed twi_sw_master_example to twi_master_example
  5300. ANT
  5301. BLE
  5302. - Updated SoftDevice S110 specific documentation to include message sequence charts.
  5303. Proprietary
  5304. Fixed issues:
  5305. - NRFFOETT-257 - twi_master_clear_bus() functionality fix done.
  5306. - NRFFOSDK-953 - twi_hw_master.c functionality fix done.
  5307. ANT
  5308. BLE
  5309. - NRFFOSDK-758 - Button 1 does not wake up Bluetooth examples applications. To erase bonding information from system-off mode, press both button 0 and button 1.
  5310. Proprietary
  5311. Known issues:
  5312. - If you have an existing KEIL project target set to use device variant "nRF51", a pop-up might appear stating that you have to "update your device selection".
  5313. Solution:
  5314. Press ALT+F7 to open "Options for Target" dialog.
  5315. Select "Options for Target" -> "Device".
  5316. Choose "Nordic nRF51 Series Devices" from the Database list.
  5317. Select the variant of the nRF51 chip that is used for the KEIL project target.
  5318. - When using J-Link software prior to version 4.66, a warning might appear when entering "Options for Target" -> "Debug" -> "Settings". The warning indicates that the device is unknown to the specific version of the J-Link software.
  5319. Solution: Upgrade J-Link software to version 4.66 or later.
  5320. - Segger J-Link software has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5321. - On some Windows XP machines, J-Link CDC installer fails producing an error message saying it could not find JLinkCDCDriver_x86.msi.
  5322. Solution: Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5323. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  5324. - NRFFOSDK-236 - When the bundled J-Link OB CDC driver installation dialog appears, the error message "Failed to install driver (Timeout occurred)" might appear . Ignore it.
  5325. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power.
  5326. - NRFFOSDK-363 - Flashing software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  5327. Solution: Wake-up the current application from SYTEM_OFF before flashing a new application.
  5328. ANT
  5329. - NRFFOSDK-366 - ANT-FS host: download sometimes fails when downloading a large file.
  5330. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  5331. BLE
  5332. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized.
  5333. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application.
  5334. (If the bonding information is not erased manually - by pressing button 1 during start-up - the new application might assert. )
  5335. - NRFFOSDK-486 - All applications using the bond manager will assert when the maximum number of bonded masters is passed. See proximity application documentation.
  5336. Proprietary:
  5337. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5338. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  5339. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  5340. - The legacy examples do not use "payload in ACK".
  5341. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  5342. - The examples do not use dynamic payload length.
  5343. The legacy examples need to add the following in order to work with the nRF51 examples:
  5344. hal_nrf_setup_dynamic_payload(0xFF);
  5345. hal_nrf_enable_dynamic_payload(true);
  5346. hal_nrf_enable_ack_payload(true);
  5347. hal_nrf_set_rf_channel(10);
  5348. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  5349. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  5350. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  5351. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  5352. - Gazell does not support "Low Power Host mode" (Host mode 1).
  5353. ========================================================================
  5354. nRF51 SDK v. 4.0.1
  5355. ------------------
  5356. Following toolchains/devices have been used for testing and verification:
  5357. - ARM: MDK-ARM Version 4.60
  5358. - N51422 QFAACA on PCA10006 module on nRF6310 motherboard
  5359. - N51822 QFAACA on PCA10001 evaluation kit board
  5360. - Windows XP SP3 32-bit
  5361. - Windows 7 SP1 64-bit
  5362. - BLE SoftDevice Version : s110_nrf51822_4.0.0-2.beta
  5363. Changes:
  5364. - Adressed poor search functionality in the documentation by upgrading used Doxygen version and adding a CHM version of the documentation.
  5365. Proprietary
  5366. - ESB/Gazell: A hard PLL rampdown is now implemented which shortens the TX to RX switching time to match nRF24L devices.
  5367. Fixed issues:
  5368. - NRFFOSDK-801 - Project memory layout was incorrect for S110 4.0.0 targets.
  5369. - NRFFOETT-249 - gcc_nrf51_s110.ld had wrong SoftDevice size.
  5370. ANT
  5371. BLE
  5372. - NRFFOSDK-807 - Made changes to the default assert handler.
  5373. - NRFFOSDK-800 - Bug when switching between BLE and Gazell mode on buttons presses fixed.
  5374. - NRFFOETT-225 - DTM didn't work with Tescom TC3000C and R&S CBT.
  5375. - NRFFOETT-262 - Evaluation kit BLE examples had button pin pullup resistors disabled.
  5376. - NRFFOSDK-804 - Excluded ble_sps.c and ble_sps.h from release as they have not been fully implemented.
  5377. Proprietary
  5378. - ESB/Gazell: The peripherals are no longer prepared for use by the nrf_esb_init() and nrf_gzll_init() functions. This is performed in the SystemInit() function.
  5379. Known issues:
  5380. - Segger JLink has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5381. On some Windows XP machines JLink CDC installer fails with error message saying it could not find JLinkCDCDriver_x86.msi.
  5382. Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5383. - NRFFOETT-205 - The nRF51 SDK installer will not run if no C:\ drive exists
  5384. - NRFFOSDK-236 - When the bundled JLink OB CDC driver installation dialog appears, it might pop up an error saying "Failed to install driver (Timeout occurred)". Ignore it.
  5385. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power
  5386. - NRFFOSDK-363 - Flashing a software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode (implies to wake-up the current application from SYTEM_OFF before flashing a new application)
  5387. ANT
  5388. - NRFFOSDK-366 - ANT-FS host: download some times fails when downloading large file.
  5389. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  5390. BLE
  5391. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized
  5392. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application
  5393. If the bonding information are not erased manually - by pressing button 1 during start-up - the new application might assert.
  5394. - NRFFOSDK-486 - All applications using bond manager will assert when the maximum number of bonded masters is passed - See proximity application documentation.
  5395. - NRFFOSDK-758 - Button 1 does not wake up Bluetooth examples applications. To erase bonding information from system-off mode, press on both button 0 and button 1.
  5396. - NRFFOSDK-759 - Unable to switch to BLE mode from gazell mode in Multiprotocol application
  5397. Proprietary:
  5398. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5399. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  5400. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  5401. - The legacy examples do not use "payload in ACK".
  5402. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  5403. - The examples do not use dynamic payload length.
  5404. The legacy examples need to add the following in order to work with the nRF51 examples:
  5405. hal_nrf_setup_dynamic_payload(0xFF);
  5406. hal_nrf_enable_dynamic_payload(true);
  5407. hal_nrf_enable_ack_payload(true);
  5408. hal_nrf_set_rf_channel(10);
  5409. In addition, the legacy PTX example must add code for handling the payloads received in ACK.
  5410. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  5411. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  5412. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  5413. - Gazell does not support "Low Power Host mode" (Host mode 1).
  5414. ========================================================================
  5415. nRF51 SDK v. 4.0.0
  5416. -----------------
  5417. Following toolchains/devices have been used for testing and verification:
  5418. - ARM: MDK-ARM Version 4.60
  5419. - N51422 QFAACA on PCA10006 module on nRF6310 motherboard
  5420. - N51822 QFAACA on PCA10001 evaluation kit board
  5421. - Windows XP SP3 32-bit
  5422. - Windows 7 SP1 64-bit
  5423. Changes:
  5424. - NRFFOSDK-192 - Interrupt driven low power UART module added.
  5425. - NRFFOSDK-543 - Set of common modules used by nRF51xxx examples added.
  5426. ANT
  5427. - NRFFOSDK-312 - adapt to renaming of SoftDevice S210 V2.0.0 APIs
  5428. BLE
  5429. - NRFFOSDK-55 - adapt to renaming of SoftDevice S110 V4.0.0 APIs
  5430. Fixed issues:
  5431. - NRFFOSDK-563 - nRF51 SDK installer - Keil CDB not installing correctly on PC's running Win7 w/Asian Locales (prim: Japanese/Chinese).
  5432. ANT
  5433. - NRFFOSDK-484 - HRM TX background pages are not following 65th packet rule according to spec
  5434. BLE
  5435. - NRFFOSDK-361 - System attributes are stored in flash only after disconnect. API ble_bondmngr_sys_attr_store to save system attributes while in a connection is now available.
  5436. Known issues:
  5437. - Segger JLink has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5438. On some Windows XP machines JLink CDC installer fails with error message saying it could not find JLinkCDCDriver_x86.msi.
  5439. Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5440. - NRFFOETT-205 - The nRF51822 installer will not run if no C:\ drive exists
  5441. - NRFFOSDK-236 - When the bundled JLink OB CDC driver installation dialog appears, it might pop up an error saying "Failed to install driver (Timeout occurred)". Ignore it.
  5442. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power
  5443. - NRFFOSDK-363 - Flashing a software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode (implies to wake-up the current application from SYTEM_OFF before flashing a new application)
  5444. ANT
  5445. - NRFFOSDK-366 - ANT-FS host: download some times fails when downloading large file.
  5446. - NRFFOSDK-755 - HRM TX buttons example may report wrong total elapsed time.
  5447. BLE
  5448. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized
  5449. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application
  5450. If the bonding information are not erased manually - by pressing button 1 during start-up - the new application might assert.
  5451. - NRFFOSDK-486 - All applications using bond manager will assert when the maximum number of bonded masters is passed - See proximity application documentation.
  5452. - NRFFOSDK-758 - Button 1 does not wake up Bluetooth examples applications. To erase bonding information from system-off mode, press on both button 0 and button 1.
  5453. - NRFFOSDK-759 - Unable to switch to BLE mode from gazell mode in Multiprotocol application
  5454. Proprietary:
  5455. - ESB/Gazell: Calling nrf_esb_init() or nrf_gzll_init() will disable usage of the GPIOTE peripheral.
  5456. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5457. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  5458. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  5459. - The legacy examples do not use "payload in ACK".
  5460. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  5461. - The examples do not use dynamic payload length.
  5462. The legacy examples need to add the following in order to work with the
  5463. nRF51 examples:
  5464. hal_nrf_setup_dynamic_payload(0xFF);
  5465. hal_nrf_enable_dynamic_payload(true);
  5466. hal_nrf_enable_ack_payload(true);
  5467. hal_nrf_set_rf_channel(10);
  5468. In addition, the legacy PTX example must add code for handling the
  5469. payloads received in ACK.
  5470. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  5471. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  5472. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  5473. - Gazell does not support "Low Power Host mode" (Host mode 1).
  5474. ========================================================================
  5475. nRF51 SDK v3.0.0
  5476. -----------------
  5477. Following toolchains/devices have been used for testing and verification:
  5478. - ARM: MDK-ARM Version 4.60
  5479. - Windows XP SP3 32-bit
  5480. - Windows 7 SP1 64-bit
  5481. Changes:
  5482. - Merged nRF514 and nRF518 SDKs
  5483. - system_nrf51.c: GPIOTE peripheral turned on during system init.
  5484. ANT
  5485. - Added ANT bicycle power-only sensor example
  5486. - Added ANT combined bicycle speed and cadence sensor example
  5487. BLE
  5488. - Added Direct Test Mode (DTM) source code
  5489. - Added Glucose Meter service and example
  5490. - Added Health Thermometer service and example
  5491. - Added Blood Pressure service and example
  5492. - Added Proximity example for evaluation board
  5493. - Bond manager and flash module modified to write bonding information in flash while in a connection
  5494. Fixed issues:
  5495. BLE
  5496. -NRFFOSDK-120 - ble_bondmngr_store_bonded_masters function from the bond manager cannot be used when advertising nor when in a connection
  5497. The bonding information are now written while in a connection but not the system attributes information.
  5498. ANT
  5499. - Fixed incorrect event time generation in ANT HRM Tx example
  5500. - NRFFOSDK-469 - ANT - bicycle power rx: doxygen architecture picture defect
  5501. - NRFFOSDK-470 - ANT - bicycle power tx: doxygen architecture picture defect
  5502. Proprietary:
  5503. - twi_hw_master example : Fixed deadlock when stop condition was not issued. (NRFFOETT-167)
  5504. - Bugfix: Polarity of on-air "no_ack" bit inverted to comply with legacy nRF24L01
  5505. hardware ESB.
  5506. Known issues:
  5507. - Segger JLink has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5508. On some Windows XP machines JLink CDC installer fails with error message saying it could not find JLinkCDCDriver_x86.msi.
  5509. Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5510. - NRFFOSDK-236 - When the bundled JLink OB CDC driver installation dialog appears, it might pop up an error saying "Failed to install driver (Timeout occurred)". Ignore it.
  5511. - NRFFOSDK-362 - Reset button won't work after programming without cycling the target power
  5512. - NRFFOSDK-363 - Flashing a software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode
  5513. (implies to wake-up the current application from SYTEM_OFF before flashing a new application)
  5514. ANT
  5515. - ARCH-506 - ANT-FS host; download could fail when downloading large files.
  5516. - NRFFOSDK-484 - HRM TX background pages are not following 65th packet rule according to spec
  5517. BLE
  5518. - NRFFOSDK-119 - Only the "....\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\","....\sdk\nrf5822\Board\pca10001\ble\ble_app_proximity\ ", and "....\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ " applications are power optimized
  5519. - NRFFOSDK-361 - System attributes are stored in flash only after disconnect.
  5520. - NRFFOSDK-472 - Bonding information in flash are not erased during programming of a new application
  5521. If the bonding information are not erased manually - by pressing button 1 during start-up - the new application might assert.
  5522. - NRFFOSDK-486 - All applications using bond manager will assert when the maximum number of bonded masters is passed
  5523. For more information, see proximity application documentation.
  5524. Proprietary:
  5525. - ESB/Gazell: Calling nrf_esb_init() or nrf_gzll_init() will disable usage of the GPIOTE peripheral.
  5526. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5527. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  5528. - The nRF24Lxx ESB examples found in the legacy nRFready SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  5529. - The legacy examples do not use "payload in ACK".
  5530. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  5531. - The examples do not use dynamic payload length.
  5532. The legacy examples need to add the following in order to work with the
  5533. nRF51 examples:
  5534. hal_nrf_setup_dynamic_payload(0xFF);
  5535. hal_nrf_enable_dynamic_payload(true);
  5536. hal_nrf_enable_ack_payload(true);
  5537. hal_nrf_set_rf_channel(10);
  5538. In addition, the legacy PTX example must add code for handling the
  5539. payloads received in ACK.
  5540. - The Gazell Link Layer examples are not fully "out of the box" compatible with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx devices. The timeslot periods and channel tables require adjustment.
  5541. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  5542. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects, or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  5543. - Gazell does not support "Low Power Host mode" (Host mode 1).
  5544. Notification ANT:
  5545. - This is last release that will support N51422 QFAACA (ANT). Next release will contain API changes.
  5546. ========================================================
  5547. Old release notes from before SDK merge
  5548. ========================================================
  5549. nRF518 SDK v2.0.0
  5550. -----------------
  5551. Following toolchains/devices have been used for testing and verification:
  5552. - ARM: MDK-ARM Version 4.60
  5553. - N51822 QFAACA on PCA10000 evaluation kit USB dongle
  5554. - N51822 QFAACA on PCA10001 evaluation kit board
  5555. - N51822 QFAACA on PCA10004 module on nRF6310 motherboard
  5556. - Windows XP SP3 32-bit
  5557. - Windows 7 SP1 64-bit
  5558. Bluetooth:
  5559. - Bluetooth Low Energy SoftDevice S110_nRF51822_2.0.0_alpha1
  5560. Gazell / ESB libraries on-air compatible with the following SDKs for legacy nRF24Lxx devices:
  5561. - nRFgo SDK 2.3.0
  5562. - nRFready Desktop 1.2.3
  5563. Changes:
  5564. Bluetooth:
  5565. - Adapted examples for updated S110 API (S110_nRF51822_2.0.0_alpha1).
  5566. - Added Find Me (Immediate Alert Service as client) to Proximity Application.
  5567. - Added Alert Notification (client) service and example.
  5568. - Added Cycling Speed and Cadence service and example.
  5569. - Added Running Speed and Cadence service and example.
  5570. - Bond Manager modified to add Whitelist handling and CRC verification of flash.
  5571. - Bond Manager usage added to all examples except for power profiling application.
  5572. - Use of Whitelist added to Proximity, HID Mouse and HID Keyboard examples.
  5573. - Use of directed advertisement added to HID Mouse and HID Keyboard examples.
  5574. - Timer Module refactored.
  5575. Proprietary:
  5576. - Added nRF24L series address conversion functions to radio_example.
  5577. - Added support for GCC to nRF51 Code Examples, ESB and Gazell examples.
  5578. - Examples no longer use deprecated PERPOWER register.
  5579. - Disabled "Download to flash" and "Verify Code Download" in JLink debug Download Options.
  5580. - All SDK release notes are now in this file.
  5581. - Added hardware flow control option to simple_uart.
  5582. - Fixed compilation problems with Keil ARM MDK v4.60 and ram retention, temperature and blinky examples.
  5583. - debouncer_example, ppi_example and timer_example now explicitly set timer bitmode.
  5584. - keil_arm_uv4.lnt include folder changed from C:\Keil\ARM\RV31\INC to C:\Keil\ARM\ARMCC\INC.
  5585. - Corrected location of SFR files in UV projects.
  5586. - ESB: ESB PRX transceiver operations are shorted, removing continuous wave transmission and improving speed and current consumption.
  5587. - ESB: PRX starts listening immediately after sending an ACK, no longer waiting for the next timeslot.
  5588. - ESB: The NOACK bit is changed to an ACK bit to ensure compatibility with L01 radios. The L01 product specification is incorrect, only devices using dynamic ack will see this.
  5589. - ESB: esb_is_enabled function added.
  5590. - ESB: Disabling CRC checking on PRX/Host side works correctly
  5591. - ESB: Added support for controlling the XOSC outside the ESB library
  5592. - Gazell: Added support for controlling the XOSC outside the Gazell library
  5593. - GZP: No longer deletes pairing data on gzp_init. Added functions to check if device has pairing data and delete all pairing info from flash.
  5594. - GZP: gzp_desktop_emulator example requires only one key press to pair and has been tested to work on SoftDevice.
  5595. - GZP: nrf_nvmc_write_bytes correctly iterates through bytes.
  5596. Fixed issues:
  5597. - Examples use deprecated PERPOWER register.
  5598. Proprietary:
  5599. - When using Keil ARM MDK v4.60 the ram retention, temperature and blinky examples might fail during compilation.
  5600. - Gazell and ESB examples point to wrong SFR file (should be SFD\Nordic\nRF51\nRF51822.sfr).
  5601. Bluetooth:
  5602. - The buttons on the evaluation board are not debounced.
  5603. Known issues:
  5604. - Segger JLink has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5605. - On some Windows XP machines JLink CDC installer fails with error message saying it could not find JLinkCDCDriver_x86.msi.
  5606. Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5607. - When the bundled JLink OB CDC driver installation dialog appears, it might pop up an error saying "Failed to install driver (Timeout occurred)". Ignore it. (DRGN-1807)
  5608. - Reset button won't work after programing without cycling the target power. (DRGN-1885)
  5609. - Flashing a software using SEGGER is possible only when NOT in SYSTEM_OFF mode (implies to wake-up the current application with a button press for example before flashing a new application).(DRGN-1925)
  5610. Bluetooth:
  5611. - Only the ..\sdk\nrf5822\Board\nrf6310\ble\ble_app_pwr_profiling\ and ..\sdk\nrf5822\Board\pca10001\ble\ble_app_hrs\ applications are power optimized.(DRGN-1914)
  5612. - ble_bondmngr_store_bonded_masters function from the bond manager cannot be used when advertising nor when in a connection (DRGN-1915)
  5613. (flash erase/write prevents the CPU from running which means the stack will not be able to run properly.)
  5614. If ble_bondmngr_store_bonded_masters function is called while advertising or in a connection, the behavior is UNDEFINED.
  5615. Proprietary:
  5616. - ESB/Gazell: Calling nrf_esb_init() or nrf_gzll_init() will disable usage of the GPIOTE peripheral. In order to use the GPIOTE peripheral, the workaround in PAN 22 must be performed after calling these functions.
  5617. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5618. - Temperature example does not give sane output values. This is hardware related issue described in PAN_028 and will be fixed in future silicon.
  5619. - The nRF24Lxx ESB examples found in the legacy nRFready
  5620. SDKs do not work out of the box with the nRF51 ESB examples. This is due to:
  5621. - The legacy examples do not use "payload in ACK".
  5622. - The legacy examples use RF channel 2 (not 10 as the nRF51 examples).
  5623. - The examples do not use dynamic payload length.
  5624. The legacy examples need to add the following in order to work with the
  5625. nRF51 examples:
  5626. hal_nrf_setup_dynamic_payload(0xFF);
  5627. hal_nrf_enable_dynamic_payload(true);
  5628. hal_nrf_enable_ack_payload(true);
  5629. hal_nrf_set_rf_channel(10);
  5630. In addition, the legacy PTX example must add code for handling the
  5631. payloads received in ACK.
  5632. - The Gazell Link Layer examples are not fully "out of the box" compatible
  5633. with the legacy Gazell examples provided in the nRFgo SDK for nRF24Lxx
  5634. devices. The timeslot periods and channel tables require adjustment.
  5635. - Timeslot period: Edit gzll_params.h file used in the nRF24Lxx projects,
  5636. or use the nrf_gzll_set_timeslot_period() function in the nRF51 projects
  5637. (nRF51 Gazell timeslot period = 0.5*GZLL_RX_PERIOD).
  5638. - Channel table: Edit gzll_params.h file used in the nRF24Lxx projects,
  5639. or use the nrf_gzll_set_channel_table() function in the nRF51 projects.
  5640. - Gazell does not support "Low Power Host mode" (Host mode 1).
  5641. nRF518 SDK v1.1.1
  5642. -----------------
  5643. Changes:
  5644. - Master Control Panel updated to version 3.1.1. Includes fix for issue where pca10000 master emulator devices did not get detected.
  5645. Known issues:
  5646. - When the bundled JLink OB CDC driver installation dialog appears, it might pop up an error saying "Failed to install driver (Timeout occurred)". Ignore it.
  5647. - When using Keil ARM MDK v4.60 the ram retention, temperature and blinky examples might fail during compilation and leave an error message like this:
  5648. C3900U: Unrecognized option '--asm'.
  5649. C3900U: Unrecognized option '--interleave'.
  5650. To fix this Click Alt+F7, choose "Listing" tab. Uncheck "C Compiler Listing"
  5651. - Previous issues from v1.1.0 does still apply
  5652. nRF518 SDK v1.1.0
  5653. -----------------
  5654. Following toolchains/devices have been used for testing and verification:
  5655. - ARM: MDK-ARM Version 4.54
  5656. - N51822 QFAACA on PCA10004 module on nRF6310 motherboard
  5657. - N51822 QFAACA on PCA10000 USB dongle
  5658. - N51822 QFAACA on PCA10001 board
  5659. - Windows XP SP3 32-bit
  5660. - Windows 7 SP1 64-bit
  5661. Known issues:
  5662. - Examples use depracated PERPOWER register. Future silicon will power up peripherals after reset and PERPOWER register will be removed.
  5663. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5664. - Temperature example does not give sane output values. This is hardware related issue described in
  5665. - Segger JLink has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5666. - On some Windows XP machines JLink CDC installer fails with error message saying it could not find JLinkCDCDriver_x86.msi.
  5667. Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5668. - Gazell and ESB examples point to wrong SFR file (should be SFD\Nordic\nRF51\nRF51822.sfr).
  5669. - Reset button wont work after programing without cycling the target power. Workaround is to update system_nrf51.c with
  5670. void SystemInit (void)
  5671. {
  5672. /* Switch ON both RAM banks */
  5673. NRF_POWER->RESET = POWER_RESET_RESET_Enabled;
  5674. NRF_POWER->RAMON |= (POWER_RAMON_ONRAM0_RAM0On << POWER_RAMON_ONRAM0_Pos) |
  5675. (POWER_RAMON_ONRAM1_RAM1On << POWER_RAMON_ONRAM1_Pos);
  5676. }
  5677. Bluetooth:
  5678. - The button on the evaluation board are not debounced in hardware and the application implementing for it does not debounce the button presses either (using software mechanisms). So there will be additional increments/decrements of heart rate measurement while pressing the buttons.
  5679. nRF518 SDK v1.0.0
  5680. -----------------
  5681. Following toolchains/devices have been used for testing and verification:
  5682. - ARM: MDK-ARM Version 4.54
  5683. - N51822 QFAACA on nRF2752 module on nRF6310 motherboard
  5684. - Windows XP SP3 32-bit
  5685. - Windows 7 SP1 64-bit
  5686. Bluetooth:
  5687. - S110 SoftDevice v1.0.0
  5688. - J-Link ARM v4.52b or higher
  5689. This release contains the following:
  5690. Bluetooth:
  5691. - Complete source code needed for writing applications on top of S110 SoftDevice (BLE Stack)
  5692. - Template application that can be used as a starting point to develop custom applications.
  5693. - Example application for Heart Rate Service
  5694. - Example application for Proximity profile
  5695. - Example application for HID Mouse
  5696. - Example application for HID Keyboard
  5697. - Power profiling application
  5698. - Example application using Heart Rate Service for Evaluation Board (PCA10001)
  5699. - Multiprotocol application that implements the Heart Rate profile in Bluetooth mode and the Gazell 'device' mode.
  5700. - Documentation
  5701. Known issues:
  5702. - Examples use depracated PERPOWER register. Future silicon will power up peripherals after reset and PERPOWER register will be removed.
  5703. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5704. - Temperature example does not give sane output values. This is hardware related issue described in
  5705. - Segger JLink has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5706. - On some Windows XP machines JLink CDC installer fails with error message saying it could not find JLinkCDCDriver_x86.msi.
  5707. Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5708. - Gazell and ESB examples point to wrong SFR file (should be SFD\Nordic\nRF51\nRF51822.sfr).
  5709. - Reset button wont work after programing without cycling the target power. Workaround is to update system_nrf51.c with
  5710. void SystemInit (void)
  5711. {
  5712. /* Switch ON both RAM banks */
  5713. NRF_POWER->RESET = POWER_RESET_RESET_Enabled;
  5714. NRF_POWER->RAMON |= (POWER_RAMON_ONRAM0_RAM0On << POWER_RAMON_ONRAM0_Pos) |
  5715. (POWER_RAMON_ONRAM1_RAM1On << POWER_RAMON_ONRAM1_Pos);
  5716. }
  5717. - Spi master function spi_master_init() sends two dummy bytes. This will be removed in a future release.
  5718. - timer_example nrf_timer_delay_ms() will not give expected results using parameter values over 65 ms.
  5719. Bluetooth:
  5720. - The button on the evaluation board are not debounced in hardware and the application implementing for it does not debounce the button presses either (using software mechanisms). So there will be additional increments/decrements of heart rate measurement while pressing the buttons.
  5721. nRF514 SDK v.1.2.0
  5722. ------------------
  5723. Following toolchains/devices have been used for testing and verification:
  5724. - ARM: MDK-ARM Version 4.60
  5725. - N51422 QFAACA on PCA10004 module on nRF6310 motherboard
  5726. - N51422 QFAACA on PCA10006 module on nRF6310 motherboard
  5727. - N51822 QFAACA on nRF2752 module on nRF6310 motherboard
  5728. - N51822 QFAACA on PCA10001 evaluation kit board
  5729. - Windows XP SP3 32-bit
  5730. - Windows 7 SP1 64-bit
  5731. Changes:
  5732. - Added Bicycle Power minimal slave example.
  5733. - Added Stride and Distance Monitor minimal slave and master example.
  5734. - Removed deprecated PERPOWER register from examples and header files.
  5735. Known issues:
  5736. - Segger JLink has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5737. - On some Windows XP machines JLink CDC installer fails with error message saying it could not find JLinkCDCDriver_x86.msi.
  5738. - Try running the installer C:\Program Files\SEGGER\JLinkARM_V<version>\USBDriver\JLinkCDCInstaller_V1.2b.exe manually.
  5739. - When the bundled JLink OB CDC driver installation dialog appears, it might pop up an error saying "Failed to install driver (Timeout occurred)". Ignore it.
  5740. - Flashing a software using SEGGER is NOT possible when the device is in SYSTEM_OFF mode (implies to wake-up the current application from SYTEM_OFF before flashing a new application)
  5741. - Reset button won't work after programming with Keil without cycling the target power. On the other hand if nrfjprog with -p (pin reset) is used to program the device, reset button will work.
  5742. - Using -p option in nrfjprog too heavily might block JLink. This block can be resolved by re-cycling the JLink power.
  5743. nRF514 SDK v1.1.0
  5744. -----------------
  5745. Following toolchains/devices have been used for testing and verification:
  5746. - ARM: MDK-ARM Version 4.54
  5747. - N51422 QFAACA on PCA10001 module
  5748. - N51422 QFAACA on a PCA10005 modulea on nRF6310 motherboard
  5749. Known issues:
  5750. - When having an application which starts up by putting the chip in SystemOff mode, and wakeup source is not configured correctly, the device cannot be programmed.
  5751. Workaround: Use nrfjprog with "recover" option to wipe the application keeping the application in SystemOff mode.
  5752. - For PCA10003 examples using UART, the terminal program on the PC has to release the COM port when PCA10003 is power cycled. It is not possible for the PCA10003 to keep a connection up when performing a power cycle.
  5753. Workaround: Close terminal program for each time you want to perform a power recycle
  5754. Changes:
  5755. - Added examples for PCA10003 Evaluation kit.
  5756. - Added nrfjprog.exe - Nordic Semiconductor command line nRF51 programming tool using JLink dll's.
  5757. - Added custom system_nrf51422.c in templates folder for handling reset after flashing and turning all peripherals on (except GPIOTE) as described in PAN028.
  5758. - Removed references to depricated PERPOWER register in ANT code examples.
  5759. - Added compiler flag to the ANT examples, to easier being able to run examples without any UART.
  5760. - Modified simple_uart_config() parameters. Added new parameters for flow control
  5761. - Added include/boards folder for handling examples targeted for different boards
  5762. - Fixed bug in timer_example
  5763. - Fixed bug in spi_example
  5764. nRF514 SDK v1.0.0
  5765. -----------------
  5766. Following toolchains/devices have been used for testing and verification:
  5767. - ARM: MDK-ARM Version 4.54
  5768. - N51822 QFAACA on nRF2754 module on nRF6310 motherboard
  5769. - Tested on Windows 7 64-bit
  5770. Known issues:
  5771. - Examples use depracated PERPOWER register. Future silicon will power up peripherals after reset and PERPOWER register will be removed.
  5772. - Using Keil versions 4.53 and older will not work unless you change configuration in jlinksettings.ini. See User Guide for more details.
  5773. - Temperature example does not give sane output values. This is hardware related issue described in
  5774. - Segger JLink has some issues with Keil. See http://www.segger.com/IDE_Integration_Keil.html#knownproblems for more details.
  5775. - Reset button wont work after programing without cycling the target power. Workaround is to update system_nrf51.c with
  5776. void SystemInit (void)
  5777. {
  5778. /* Switch ON both RAM banks */
  5779. NRF_POWER->RESET = POWER_RESET_RESET_Enabled;
  5780. NRF_POWER->RAMON |= (POWER_RAMON_ONRAM0_RAM0On << POWER_RAMON_ONRAM0_Pos) |
  5781. (POWER_RAMON_ONRAM1_RAM1On << POWER_RAMON_ONRAM1_Pos);
  5782. }
  5783. - Spi master function spi_master_init() sends two dummy bytes. This will be removed in a future release.
  5784. - timer_example nrf_timer_delay_ms() will not give expected results using parameter values over 65 ms.
  5785. Changes:
  5786. - First public release