![](data:image/jpeg;base64,/9j/4AAQSkZJRgABAgAAZABkAAD/7AARRHVja3kAAQAEAAAAUAAA/+4ADkFkb2JlAGTAAAAAAf/bAIQAAgICAgICAgICAgMCAgIDBAMCAgMEBQQEBAQEBQYFBQUFBQUGBgcHCAcHBgkJCgoJCQwMDAwMDAwMDAwMDAwMDAEDAwMFBAUJBgYJDQsJCw0PDg4ODg8PDAwMDAwPDwwMDAwMDA8MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwM/8AAEQgAFwDaAwERAAIRAQMRAf/EALcAAAICAwEBAAAAAAAAAAAAAAYHBQgDBAkCAAEAAQQDAQAAAAAAAAAAAAAABQIDBAYABwgBEAABBAEDAwIDBAYHCQEAAAACAQMEBQYREgcAIRMUCDEiFUFxMiNRQlI0FhdhkWJyM7Y3gbGDsyQldTZ2dxEAAQMCBAMFBQILBAsAAAAAARECAxIEACETBTFBBlFhIjIUcYGhQiOxM/CRUmJygrJDcxUH8SQ0tMHR4ZKiwuKjdDUW/9oADAMBAAIRAxEAPwAv9q6Fx/wh7keZxEws/pLWHYjJHuSTp+0S2/c9Iil1rjZf7vaz3H6rfb+FOO1f6pH+bb/tGz8WamvKPzGf9LJcdieKcPb4/wCO8IwsEHdjVJDgPuDpob7TII+52/bc3F1fLGHQgZFzaMci9Tbsd33W5vT+9ke4dwc7wj3DDE6l4CYVma8z8fcf3bGOZLY2Q3ciuW3SvraW1tSCALhNFIcWuiSBAEMFRdyp1CuNwhgfQ8lUXJrnZdvhBxZtn6P3Ldrc3FuxmmH0VPliiV6B1I1XsJKHljStueeLKZjFJL+QSrFrOK5y2xb6PUWluUuEyraOPoFdEkEAiroIu9B7rp0l+527A0lxNQUIHOUdvhBw9a9D7vcuna2JrTA8Mk1JIoqXlUasr2Ak0nyrwxLxOXOP5drhdF9bdg3XIUebKw+qsYE6vkS26/8Aefy5cdomiH4oDqCRJ3FFTv042+hLmNVC9aQQQqceICe/EWXpTco4bifTDo7ctErmPZI1hk8mbHODgfym1NBycQcesh5b4+xX+Nfr1+sJePItZMzARhzH1iM3Bm3BJEZZNXVdJsk0a3KOnzInbrJb6GKupyUAF2Ryq4cs17seWHSu5X/p9CKr1Dnti8TG1mIAyeZwppDhm+kHkuIuLzjxtIpMiyN60s6ikxRhqRd2FzRXNSAA8fjaRpLCFHV8zPQUBpDJSUU01IdUDcoC1z1IDeJLXN+0BfdiTJ0VujJ4rcMY+SUkMbHLDKSQFK6cj6ABmXPpagJVAcT2C8j43yG1ZuUDVvGOocabnxbmosKh0fMKm0QhPYYU0IU11HXTtrpqnTttdsuFpXLtBb9oGIO99PXW0FgnMZrBIMckco8JQ5xuchByzTuxlwrkjCORYl7OwvIGbyHjVrJpLuQ2DrQsTYiCrzf5wN7hRDRUMdQJPwkvWW93FcAmNyhpIPtH4ceGE7z09f7O+Nl5EY3SsbIwEg1MetJ8JKHI+Eo4cwMDuHc3cfZ9dBSYtMtLEpDLz9ZcFT2TFXOajEgPHEsHowRnhAl01FzQv1d3TVvuMM7qWEnsNJpKdjkQ4Ibv0ZuW1Qa101jUIDm6sbpWF2bQ+JrjI0kZoW5fMmJ7OeTML45ZrTyy3WJKu3TYoqeLHkT7Cc62O4wiwojbz7qimm5RBUHVNyp07c3kVuBWczwCEk+wBScQdl6cvt4c8WsatYFe5zmsjYDkC+R5axq8lcp5LgfTnHjlrDpWdWdnPx6jh2P0h1q5qrCvnHPURIIrMGRHCS+4aGm1Gmy3d0TuJIjX8xhERkJIAKZggr2IQp92J3/xe5uvm2UTGySOZX9OSORmnmC90jXFjGhMy9zUyXIhdrEOZMCzWXc1dXPm199j8X19xjN1WzamzZiKuiSPRzmWXTaVe28BIdVRFXVdOvYL+GYlrSQ4BSCC0p2oQCmG926R3HbWRyyta6KR1LZI3sljL/ya43OaHfmuIKZ8MZ4/MHG8vjZzl6Lk7UnjpqK5NdyNpiSaCy04rLirHFpX0ITRRUfHuRfinShfwGDXDvpoq5/Zx+GG5Okt0j3QbS6Ei7Lg2glozIqHiWhCMwakI54jMg5042xnJLbEbKwuH8gohjnbwavHby1SOkttHmPI7XwZDSKYLqibv93SJdygjeYyTUEVGuci8PKCMSbDondL21ZdxsjEUlVJfNDFVQaXI2WRjsjlwxuXnNHG+OR8pk29+9HDC5tXXZI23XWD7zEu5aZegMiyzHNx0ngkN6I2JaKWhaKionsm4QRhxc7ykA5Hi5E5Zqo4Yasuj90vHQtiiB12yPjV8bQ5sJc2R1TnBrQ0sd5i1UUKEOMeIc18dZtcpjNVbyq/KCjrKbxi8rZ1NPcZFNSNlixYjk8gp3JWtyInx6yDcYZnUNJDuwgtP4nAL7sK3bo7c9sg9TLG10KpqRvZNGDyDnROeGk8qqV5Y1Md5540yy1jU+PWFzZyZcx6BHlhjl6MEpEdw2Xh9ecAYqIDjZCpK7t1TTXpMW5wSupYSc08rky70T44d3DofdbCEzXDY2gNDiNeCulwDm/TEhkzBBApVDwwRUXKWBZLit9m1FkTVjjOLu2DOQWDbL6FFdqkUpgOME2j25sR3aIGpCqEO5CFVdjvYZI3SNcrWqvHKnjlxwPvemdxsryKzniLZpQwsaS3xCXyEOBpRxyVciochBQItPcnxFTOVjdhcXbaXaRfor7WMZC+zMKbHSXHCO8zXG26Zsru2gSkmhIqIokiR37vbMRSc0TwvzUKE8OeWDNt/TverkPMccfgqrBnt2llDqHFzXSgtAdkpAGYQoQpxjHJ2GZhZN01HYSyt3Kgb1KydW2FbIGvOZIgA8bU6OwQbn4rgoJIhKiIemwhJZEN5FM6lpKoqEEZKRzA5g/2YDbl03fbdEZpmtoEmnU18cjdQMbIWgxucCjHtKjJTStQIGzjHIuF5ldZhj2M3rVtc4DOCuy6E226Cw5TiEotkTgCJ/gJNQUkRRVFXVFTpUN3FM5zGOUsKO7jhrcun77boILi5iLI7hpfESR42hM8iSOIychQg8DiTxXK6DNqRjI8Yn/U6aS/LisTPE6zudgyXYcgdjwNmmx5kx1UdF01TVFRelwzsmbWwqM/gUPxGI+57Xc7ZObe5bTIA0kKDk9oe3NpIza5p45KhQqMEXTuB+PB/hX4f7esRcYqY5QcnYf6zhn3VcSq35Z3DebBneJx+2jNRcJ65EH+4y5L/r6pN5bg2lxb84nBw9hV32VY6h6Z3cR77sm6/Je2/ppO+aH6fxe2LHKraP6F/wADT4j+L9vqn6b+z92v6uOotR3/ABJ7sdIeLpFQftS4bnNgv0DGebax3lhv7Ca9V+WRf2BF+LuHqzWTmfy6I/KJvF+H+7jnXqeOf/7HcGH72XbZPTe2n7fDLjson4k+5er+3HI2PXXuMxTrkUuSw9yD7nFY4+5krXEbhhHyMZKx3US5LYAFGMFE1c29y+XTXXoDd6/rfo01aXzKnm7sbb6fG1HpcDc9UQm/GcVNQ+iFJqBUIuQzwl+PYOQT7D2xJxNksans5fHmWzp1nk8Ap/58m1gvWbJR478VAIZjhiKIWgCO3Todate51voOQ6byrgvFwqyBHzYuG/TW0Ue8fzWEvYLu3aGwv0/C2KRsTqnNeoMQaTkriVXDT5S42yLkHkLBcdt8gis8j1PG2QW+OZnXRziMxL+Bd0LkSUyyTjxAGvyGikSqBGn29Tb20fcTMY5w1BG4hwyRwcxDz/sxWemeorbaNtubiKJxtH3kLHxPIeXwPhuA9jnANBPzNKDxBp5Yr1dZ5N5HxH3a3syuXH8qj0fHFTlVI8BaQLqBaTo8tnRVRSAXRUh0XuKp316FyXJuI7lxCOpjBHY4OIPxxfbPY49mvdjgY/UgMt6+N4P3kMkUbmO7iWlDlk4HLF17fi7kPPMKybEuU+Qah96wfrZeHXuNVB1ztZYV8j1TT5hKlyhf/Oba0D5eyEmvzIo2F9nNPE5kzxmhaWhEIKrmSuaY05adS7ZtV/DdbZayAND2yslkEgkjkbQWgsZGWeEv8WeZaeRBXlxzbn+E4zzdi2dDVWWf8dUVfIxbJcfBxpm2fyEnoVUjkJ0nCjyPUgCGCGQrruHQeosm4zQsmZIhexoQt+atQ3LkVwftOjNt3O6265sq22tzK8SRykF0TbemSZJAAHx6ZNLkBCI7PAFwhSTeNeRI3GWU4HZ4LjvKnHsevMbWZWySs73GGPBYSG3KyZKFvzwpO8t6iv5fbsnaLt0ZtptF7C1skYGZBVzAhPhJ4tPwwc6zvI962w7la3LJ5bS7c7wNkbpwXLqo2kSsYTRKxBSo8efe2cFkZtwhl/GXCN3bQM44/wArj2FbxvkCN+juqxulhFLCJYNipMyWhjgjYPNoBbk+cfmTqdbGWykjt3EOY5Q08HCkKjuRCZKE78Vbe2WHU1lebzCx0F1EWPnYtcMhmeGF8RKOjcXmpzHVBD4TkcSsZ6uY93Nw3ekLdpO41rwwBZGmhtNWMwrUIqr28mvhJwU+dQRF/AnSwQNxNXExin8ZqT4LiLIyV3RkZg8jbx+snImNghL/AM3zhp8tRTzHH3LsiBE519ssi/NGsfKZk8eK9I2pFG+egxxrENS+VHCBJAs/bvX5e+nWXxAu7cu8qu9lSCn38UxnSkcknT28NgzlpgJA82gHu1kTOkHTL/zeOWInl9Yj/PfDDVSonkEHHczkZSjCorjdE5W+Nn1KIikgFOVrxblRNyHp316RfobuKnzBr1/RTn+sie/EvpOtnTu4GX7p0tsI14GcSK6jkohrrTNC1eWKZZa1M4g9tsdhptwuNOfOMKN9tBRVaqcxZqYhu/BNBC0YaU+6r+cC/BC6r84NpYp+7ljb+rJSP2x8Rjb21OZ1D1SXEj1m33so75bQyvDfa63e5P4bhxTFuqmLydI9wXuEXj68xenZAcS+qDkNVNsicJas/GrKxLGCgIibt25C17aaadzrGzm8n0i0eRagT8vc5uNU3Uu0s6b2v18czz/eKdKRkafVC1VxSryRETvws+SP/avcH/8ArXEv/IpOod395P8AxYvsZix9Pf4Ta/8Awdx/auMPTnt+sk5v7dKeCrb+dpyDFsKqOxp6xqnjxZP1d7t8wseLaLmvyku34qnYluZaZYGjz1gjtpQ1e5OOKV0MyVlhusz1Ft6VzXE+QzOczQb2F9SlvMZ9uYX7W6zlVcPobBnLcfDjj+IcqVcZKofK02pe2Qmnr/WI3qr+povg7D8vx+bqPszLjTBqbp1PyQ1eZ3Ne3uwY/qXc7P62WMwS+r0rf6mo3S+4iI+nRV5MvP5s+7FfUamcScVW3JEBtxzBOWqjKcX5LiNopBCuPWWcemt9ERdqObkiPLqiaK0q6qidC0NrbmYeSQPa7ucrg13/ACn3YvdTN/3dm3PI9TaSW80BPF8NETp4O+nOZgzPnAQHFhr7/T/2Tf8A1uI/5Zseisv3Np+kz9h2KFY/+y6h/gXH+ZixL5hl0DAufOTs1s+8HFuEK+zfb10Vz01xbuC2P9oyRBT+lelzziC7kkPBsIP4nOxE2napN16ds7OPzS7k9g7qoYQvsHE9wwluE2sv4v5H4ol5jgdviCcr0c6gzXILKXWux7PJn5EnIY0gQhTJDomRPS2RR4ALaQD9m0R+3CS2njMjC3UaWuJIzepeDkSebhmmLj1k6y3za71lpcxzeklZLExjZA6O2a1tq9qyMY0gBsLzQXBQ481Nlvat/onR/wDnst/zLZ9F9l/wo/Sf+27Guf6nf++k/hW/+WixYforig48OJqC/p+zrMYqYovl0qpH3D86WcjT+EMe4SVjk4dOxyHnX5EYf73okPT7+q1cJ6yY/KIfF8U/043TtcUw6Y22Np+vJuS2/wCiA1r/APupjhv/AMEf3bZ8Ps/Y+/rXFcX4dn+vHbOk344vB7Wf++8G+5nCciT6ZhtrTMTqnKbFUi1Ma7jqgx2HZr21kHXHXIqiO7cqD93Vm2YB1pcRvyZT5vkq/CnGkP6nn0vUGz3tv452yUvjb4pXQO87tPzUMbqqeHxx2O4pubjIOPMIt8jrZlPkM6jhOXtZYMORpDM3wgkkXG3REkXya/FE6vllK6SFrngh6BVCFfZjkfqSzhs9zuYbd7XxNkcGOa6tpYpoRwJXLvwxepWAmBX0uHfxv63dXfzA+h+DZ5g+o/R/U7tfDu3+H1H623Td2116Ypi1Vyrp99K/YuCmrfego8fpdVeB09an8pEro5KtOaYSt9jPtWmQseC/k4QEBp23PF1et47Dam9MU7X0qpJBC0la+VB7CfZdF7dD5YdvIbVQmaZjt8SZ9vHvxcLHcur45JTALmoiPUSNzigYkNfhKfT8hPmbmFGGJhdTxJXuY0mCu0Tj0Wos2cV+nTW5JrVuz2XLJY6o6am0kxGkcJNUE9oqqKqJ1Lt2W7adOngUQr4VFSd1SL34AbxdbzKJvWiVDJGZK2lo1QxwiqyCO0qqRkS1Sh44gruo4Aklyv8AXXcRErNKseZfPOjMqPi1+mfVvzR8Kr38aubVL7NempI7M6lVOaV5j9Wrs7lxNs7vqNnotAT+HU9KjHHj97o5Gv8APpVO7AMmIe0VKC/hpLwb+H56RG78/rjKtCqPoUVSe9Xq0Xl02KhCu7si9R9DbqHBWUlF8Xflzyz4YNndutPURPpudVtRZ9Ir5fGjaPEKfMCCE44Isaxv21VlY9X43IxByBEyWslz3AtWZbi36OItYkqQ5Icccf36eBtwlXX8A9Oww2LWoyhKhzXxfKpXj2A+7A/cdx6pmlElwLgOML2t+mWDQT6tDQ0NDE+8c0DLzHDFzmBxtOcof5guUwPR3Zh479WktxyU1hvDM8G8wU/+lVzyImqePcpdk6lXLYHU6qc0UpyzT3Kvdiv7LPukQl9AJEIbXQ0uyrbp1ICn1KaT+WgGeFvxhjHtooMgiu8WScRfyaZWuLVJXW7VlLSt8mrnowOS+bbG/wDF4kQNfj1Es4bGN40aakyQqU7szl7MWHqXcuqru2cNzE4hDxVXGY2aiZVkNaHPThWrsGHKtTw3dRaKv5edx1kHZZLizl3NagSElIg7vQPk6y8Lmmm7xFrppr1IvWWzwBPTxyUoV7jkfxYE9MXW+Wz5JNpEpRv1NNpkbTy1Go5pbxSsJ2YEmsa9tcDje9ozk4ifGci41yF+bbNSYaW5ozt802RINQk6I1t1cQ0+Xbp26YENi2BzfDprmpUVZcyePDmuCrtx6pl3SKYCf1gj8AbGWv0hV5Y2tCx+ZfDSfEvPEvxzj/A1DIyeDxu/jT9o9HbPLzh2bdlYJFIVRr1b7j78gWtEXahkgp3VPt6XaRWjC4RUr8yFSneVJTETqC/6iumwv3ETBgJ0qmGOOrnQ0Nawu7SBVwXEpklbwu9xVAq8rcxlOHUr61msdsZccKb0QI19OVqS44je3RG/ESH37aKuvS5mWptw19OkgRSKU+XP7MRtuuN9bvDpbUTevreXUNcZqyuqrAKl81YLcs1GC+oi4c1k+XSaUq5ctl+g/jUYzwHMTxsqMH1bYkpN/la+Pciaj3TXp9jYhI4tSrKrt7l93DAq6lvnWkDZq9AV6SghmZ+pQUQ+LzIShwB5dQ8HWcfO42Xv4621Z2dQXIBSbIIhjYttMJU+rcF9s2XlbFnwpqJEm1R11TqNPFauDxJTmRVmmeVK55HgmDe1X2/wOtnWglJayTRRheNMl2tQKSHsqr1MiAalRMYONqLgOgyC2h8aP4u/mJRkO7OFYtWd16VSHTzuuPPyka3bdEItuun9HXlpHaRvIhpr5oVcnfmSmHOor3qK7tmP3ETC3XwVMMcNWflaGtjqReAq44FsexX2rMZTBnYxKwossC1J6AEG5ZckfUvOSkgMBJXVzza6jt13appr0zFDYCQFlFS8jmq+3iuCV/ufV7rRzLkXGhQjqoiG6dOSuLPLSma8OeGXIgcTpxtZ18tzHv5VOsTAtnH5LC1CNOyHPVeR8j8Y6Pke5dybT/QqdTC230CDTp5rmKeOeft+OK7HPvH80ZIwS+tBbSjXaqhooRoFR8CIEzb2g425MDjYqvjtqW5TJUV86CfGKuSW0ZKYEN0IX08lPR0/Sq5sQFJVDcqaomvXpbBSxUQEUZ80yp7clTuwzHPugmui0Sajmv8AUI0rQXgyaoTwjUpqJRHIMQ+bVfDUyfeu5+7jYWDtLXN5GlvMZYNKdqxJ2AskXHA2sLO3IBEm0nNR1Ve3SLhlsS7VpVAqn5VyXuq+OJezXO+RxxCwE1IkeWUNLhqmMCSkgFX6KVAZhiOy44KcwiYRMDGwzc6wBav4L2KLZvAwq3bZEUJIimQKUhV3bBHUi7povfp6dsRp1E8wRfyuSd+Bu0y38ZlNlXnE8SUAu+ifvK0BSPhUTkMs8JjHsV9qzGUwZ2MSsKLLAtSegBBuWXJH1LzkpIDASV1c82uo7dd2qaa9D4obASAsoqXkc1X28Vxb7/c+r3WjmXIuNChHVREN06clcWeWlM14c8WW6L411jE+ujRKqIqIqdl+9P09eORM8eO4Y5Ocm29s1wt7q8kjV813OOQc7ahZDTNsOfUaXGIiINc9axdPJFZdhxnNpOogkLiKP4uqVePItrskeNz0PaGfIe7njqHpu0gO+7HA5wFtb2xdG6oac1y/71sL/LIWyPbUGeIFhXhjlho5+0X7tp+t/if1fHqpap/J/dp+r246gRvd5u0cfxf7e7H/2Q==)

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
|  | | *LLWEB-20133817* | | |
| Draft | | |
| 0.07M | | |
|  | *Unit Design Specification*  for IMP Driver | March 19, 2024 | | |
| Automotive Software Development Division  Automotive Software Platform Department | | |
| Approver | Checker | Author |
| <approver> |  | KSK |

**Table of Contents**

[1 Introduction 3](#_Toc135903269)

[1.1 Scope 3](#_Toc135903270)

[1.2 References 5](#_Toc135903271)

[1.3 Abbreviation 5](#_Toc135903272)

[1.4 Terminology 5](#_Toc135903273)

[2 Software Unit Design 6](#_Toc135903274)

[2.1 Functions of API Layer 6](#_Toc135903275)

[2.1.1 Public function 7](#_Toc135903276)

[*2.1.2* Private function 34](#_Toc135903277)

[2.2 Functions of General Control 41](#_Toc135903278)

[2.2.1 Public function 42](#_Toc135903279)

[2.2.2 Private function 71](#_Toc135903280)

[2.3 Functions of Common Control 82](#_Toc135903281)

[2.3.1 Public function 84](#_Toc135903282)

[*2.3.2* Private function 113](#_Toc135903283)

[2.4 Functions of Core Control 138](#_Toc135903284)

[2.4.1 Public function 140](#_Toc135903285)

[*2.4.2* Private function 181](#_Toc135903286)

[2.5 Functions of OS Dependence Layer 233](#_Toc135903287)

[*2.5.1* Public function 235](#_Toc135903288)

[2.5.2 Private function 277](#_Toc135903289)

[3 Activity Diagrams 291](#_Toc135903290)

[4 Resource Usage 292](#_Toc135903291)

[5 Data Design 293](#_Toc135903292)

[5.1 Data Type Definitions 293](#_Toc135903293)

[5.1.1 Typedef 293](#_Toc135903294)

[5.1.2 Structure 296](#_Toc135903295)

[5.2 Global Pointer Variables 326](#_Toc135903296)

[5.3 Global Variables 326](#_Toc135903297)

[5.3.1 API Layer 326](#_Toc135903298)

[5.3.2 General Control 326](#_Toc135903299)

[5.3.3 Common Control 326](#_Toc135903300)

[5.3.4 Core Control 328](#_Toc135903301)

[5.3.5 OS Dependence Layer 328](#_Toc135903302)

[5.4 Constants 329](#_Toc135903303)

[5.4.1 Definition 329](#_Toc135903304)

[5.4.2 Enum 354](#_Toc135903305)

[5.4.3 Constants Table 366](#_Toc135903306)

[6 Device Specific definition 388](#_Toc135903307)

# Introduction

## Scope

This document explains about the Component Unit Design of IMP Driver.

To enable the coding of each unit of IMP Driver, the following is defined.

- The processing flow of each unit

- etc.

The arrow connects the caller to the callee.

<<Public>> indicates a function called from another module.

<<Private>> indicates a function not called from another module.

![グラフィカル ユーザー インターフェイス, PowerPoint

自動的に生成された説明](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABO4AAARtCAIAAABtPp2SAAAAAXNSR0IArs4c6QAAAAlwSFlzAAAOxAAADsQBlSsOGwAA/7VJREFUeF7svQuYFNWd959GBgIMl4FxRTNmjMnzvI/K+t83ERNXnllZAcELguIFENTNRvJsNj67iSZmzcqyG+N6eXeTJW826q7LxQFj5OKdi0YyizH7akwMIcn7JDEZ9HXcGJhhLsAwQP9/Vae7prq7qrq6uu71qVTapvqc3/mdz/lNVX/73HL5fP59HBCAAAQgAAEIQAACEIAABCAAgQQRQMomqLFwFQIQgAAEIAABCEAAAhCAAARExua0/+e0V3C4IQArN5RIAwEIQAACEIAABCAAAQhAICACSpSNCMg6ZiEAAQhAAAIQgAAEIAABCEAAAgERQMoGBBazEIAABCAAAQhAAAIQgAAEIBAUAaRsDWR37949ZsyYGjKQFAIQgAAEIAABCEAAAhCAAAQCIICUdQv1hz/84VVXXfXkk0+6zUA6CEAAAhCAAAQgAAEIQAACEAiGQJRSVmbrlh3B1NEHq3v37r3ssssefvjh2bNn+2AOExCAAAQgAAEIQAACEIAABCBQB4HIpKyIWHFbFp4yDvmnuhi349e//vUll1zyv/7X/7ryyivj5hv+QAACEIAABCAAAQhAAAIQyCCByKRsUli//fbbs2bNuuuuu5YuXZoUn/ETAhCAAAQgAAEIQAACEIBAugk47Stb1keq9p6tvGhcsUtgR7AsozmZZdGWpdtdVNbs7Lhs1N/97ndtbW2f+tSnPv/5z7vMQjIIQAACEIAABCAAAQhAAAIQCI5AlX1lywYAO8vIShGrhg1X5jLXx5zGrDntinZ2qbLEqlVwhtvd3T1nzpzrrrsOHRtcFGIZAhCAAAQgAAEIQAACEICABwK2vbKGDiwzar5u+d4ugbNzbnKVuWT809mlsnKVwK569PX1iY694IILZIpsPGfwVq0CCSAAAQhAAAIQgAAEIAABCKSPgOqVjUzKVkplS2lq5u5NyrrUruaCjhw5cumll374wx9+6KGH0LHpC31qBAEIQAACEIAABCAAAQgkl0CVAcZlFVO75kRSW7+KdmlnaGjommuuOeWUU771rW9FVeVIOFMoBCAAAQhAAAIQgAAEIACBpBDwuOyTeR5s2Xv3Ky1VCkWjBzWqZZ+OHz8uKxUfOnRo06ZNDQ0NSWlF/IQABCAAAQhAAAIQgAAEIJARAlUGGHumYDfJ1rPBqhn9KvHEiRO33HLLb37zm2efffb9739/1XJJAAEIQAACEIAABCAAAQhAAAIhE6htgHHIzoVfnHQIf+5zn/vZz3725JNPomPD50+JEIAABCAAAQhAAAIQgAAE3BMY4T6py5TGpjgu09efzJcSV65c+b3vfe+5555rbGys3yUsQAACEIAABCAAAQhAAAIQgEBwBPyXssH5Gpzl+++//zvf+c727dsnTZoUXClYhgAEIAABCEAAAhCAAAQgAAFfCCBl3ycrFf/rv/7rzp07/+AP/sAXphiBAAQgAAEIQAACEIAABCAAgUAJZF3KPvroo3fffbfo2JaWlkBBYxwCEIAABCAAAQhAAAIQgAAE/CLgtBmPX2XE1s6WLVv+4i/+4sUXXzz77LNj6ySOQQACEIAABCAAAQhAAAIQgIBBIKjNeJKCeMeOHTfccMO2bds++tGPJsVn/IQABCAAAQhAAAIQgAAEIJBxAiVSNoMsxo4dK2r2wgsvzGDdqTIEIAABCEAAAhCAAAQgAIGEEsh6r2xCmw23IQABCEAAAhCAAAQgAAEIZJmAkrJZX/YpyxFA3SEAAQhAAAIQgAAEIAABCCSUAFI2oQ2H2xCAAAQgAAEIQAACEIAABLJLACmb3ban5hCAAAQgAAEIQAACEIAABBJKACmb0IbDbQhAAAIQgAAEIAABCEAAAtklgJTNbttTcwhAAAIQgAAEIAABCEAAAgklgJRNaMPhNgQgAAEIQAACEIAABCAAgewSQMpmt+2pOQQgAAEIQAACEIAABCAAgYQSQMomtOFwGwIQgAAEIAABCEAAAhCAQHYJIGWz2/bUHAIQgAAEIAABCEAAAhCAQEIJIGUT2nC4DQEIQAACEIAABCAAAQhAILsEkLLZbXtqDgEIQAACEIAABCAAAQhAIKEEkLIJbTjchgAEIAABCEAAAhCAAAQgkF0CSNnstj01hwAEIAABCEAAAhCAAAQgkFACSNmENhxuQwACEIAABCAAAQhAAAIQyC4BpGx2256aQwACEIAABCAAAQhAAAIQSCgBpGxCGw63IQABCEAAAhCAAAQgAAEIZJcAUja7bU/NIQABCEAAAhCAAAQgAAEIJJQAUjahDYfbEIAABCAAAQhAAAIQgAAEsksAKZvdtqfmEIAABCAAAQhAAAIQgAAEEkoAKZvQhsNtCEAAAhCAAAQgAAEIQAAC2SWAlM1u21NzCEAAAhCAAAQgAAEIQAACCSWAlE1ow+E2BCAAAQhAAAIQgAAEIACB7BJAyma37ak5BCAAAQhAAAIQgAAEIACBhBJAyia04XAbAhCAAAQgAAEIQAACEIBAdgkgZbPb9tQcAhCAAAQgAAEIQAACEIBAQgkgZRPacLgNAQhAAAIQgAAEIAABCEAguwRy+Xw+l9NeI2HQ3d3d29sbSdEUCgEIQAACEIAABCAAAQhAAALeCEyZMqWxsdFb3jpzKQEbmZQVEfvJT35y586dkydPrrMmZIcABCAAAQhAAAIQgAAEIACBMAmIoJs5c+aaNWuamprCLFfKiljKXnnllVOnTl29evWoUaNCrjnFQQACEIAABCAAAQhAAAIQgEA9BGR07W233bZ///5NmzbVY8dD3iilbH9//2mnnfb2229PmDDBg+tkgQAEIAABCEAAAhCAAAQgAIFoCQwODjY3N7/11luTJk0K0xMlZaNZ9km0u3RDo2PDbG/KggAEIAABCEAAAhCAAAQg4COB0aNHy3TRgwcP+mjTvalopKx7/0gJAQhAAAIQgAAEIAABCEAAAhAoI4CUJSQgAAEIQAACEIAABCAAAQhAIGEEkLIJazDchQAEIAABCEAAAhCAAAQgAAGkLDEAAQhAAAIQ0AjIGhLGYUlEPi1LptJXJjabskxgzlI1Ac0DAQhAAAIQgEAlAaQsUQEBCEAAAhDQCMhaiMZrpbw0X5GU5sNSi1ZNAHQIQAACEIAABOohgJSthx55IQABCEAAAtUJiKx16HpVEpoDAhCAAAQgAIGaCCBla8JFYghAAAIQyASBMvGp9q/zpebmUcrKoHHFsG/o3soxz5XZffEKIxCAAAQgAIHEEUDKJq7JcBgCEIAABCImUDYVtlaVq4Rx1VxGMpXYrG/dZI+YEcVDAAIQgAAEAiaAlA0YMOYhAAEIQCB1BMrmytZav6oi1tw9W7kSlfvstTpGeghAAAIQgECCCCBlE9RYuAoBCEAAAuERMDpCfRxd7OC9ZXF1aubwYFESBCAAAQhAIHQCSNnQkVMgBCAAAQhkjIAvYpg9ezIWNVQXAhCAAASqEEDKEiIQgAAEIAABjUDl8kuqp9TbgF7zfFqXFsqKU/80DpdGaEsIQAACEIBARgggZTPS0FQTAhCAAASqEDCP5jWSmgWkeu9GUjoMDK7MXlmEuXTDlLropnRaGgIQgAAEIJAFAkjZLLQydYQABCAAAQhAAAIQgAAEIJAqAtq4Kc+jpzyT6OzsbGtrk1fPFlTG7u7u3t7eOo2QPdEEpkyZ0tjYmOgq4DwEIAABCEAAAhCAAAQSSqC1tbWjo0New/RfCdikSlkRscuXL9+1a9ekSZPKqKVvYYz01cjHQJdImDlz5po1a5qamnw0iykIQAACEIAABCAAAQhAoCoBpGxVROUJLr300lNOOeXee+8dNWqUeylrpwkdtGIcPvLXB3+tCXwPVGtub/sM0i1/22237d+/f9OmTT6axRQEIAABCEAAAhCAAAQgUJVAhFI2kXNl+/v7d+/evWrVqkodW5U1CVJGYMKECatXr96xY0dPT0/KqkZ1IAABCEAAAhCAAAQgAAE7AomUstIFN3HiRNEwtCsEhMDo0aMnT5588OBBaEAAAhCAAAQgAAEIQAACGSGQSCmbkbahmjUROHDggHTMDg0N1ZSLxBCAAAQgAAEIQAACEIBAEgkgZZPYavhsQWBgYECkbFdXF2qW+IAABCAAAQhAAAIQgEDqCSBlU9/E2argiRMn+vr6slVnagsBCEAAAhCAAAQgAIHsEUDKZq/N015jUbNpryL1gwAEIAABCEAAAhCAQNYJIGWzHgHUHwIQgAAEIAABCEAAAhCAQOIIIGUT12Q4DAEIQAACEIAABCAAAQhAIOsEkLJZjwDqDwEIQAACEIAABCAAAQhAIHEEkLKJazIchgAEIAABCEAAAhCAAAQgkHUCSNmsRwD1hwAEIAABCEAAAhCAAAQgkDgCSNnENRkOQwACEIAABCAAAQhAAAIQyDoBpGx4ETBOP8zljS09xuiHSqDem68YGd+vH+H5TUkQgAAEIAABCEAAAhCAAARiRgApG1KDGCJW1GtZkYeKx+HDh5WIlVf13vwmJEcpBgIQgAAEIAABCEAAAhCAQOwJIGVj30Q4CAEIQAACEIAABCAAAQhAAAKlBJCy6YmI0aWHqtgo/ah831B6qAQjS4/0oKEmEIAABCAAAQhAAAIQgEC6CCBlw2hPNbp4QD/kTdkYY2PCbNnQ4lo9GzQdSsTaWRAZKx8NFQ95r64YxzH9qNUB0kMAAhCAAAQgAAEIQAACEAiHAFI2HM5OpZjnyhpTZL25ZfTLGtmPHj2qZK1Stuqf6jD6ZcvKQsR6g08uCEAAAhCAAAQgAAEIQCA0Arl8Pp/Laa+hFSkFdXZ2trW1yau3QiXjjBkz9uzZY5ldqmNn1u4jD1mkCJe5ylYtNnwTBau6Z+WNulhm0OikLbuuli8+cuRIWRbRsXJFumblVb03dKxRqFwRa0avbBkodd1SyrqsrNmgQxZv7e6Qq7W1tb29vaWlRdI0NjY2Nzf7XoQbg93d3b29vW5SkiZrBKZMmSKRmbVaU18IQAACPBmJATsCPBlTExvyPbyjo0New6yRErBIWQsN6VKPuVR3xuhiQ68aCjYcKSvlmrtkK6WsoWyRsp7/AuVRvXz58l27dk2aNKnMSJiS3rP/njOmu3aesVRmlAiZOXPmmjVrmpqafDSLKQhAAAKxJcCTMbZNExPHeDLGpCHqdwMpWxvDJPbKqlmycshXfzdS1thgVrKoDljjsNxU1twZa6Q0hhOXSVlJUDY5VqbNGhfpla0tHPXUl1566SmnnHLvvfdWTlF2FnsufxBxL4/jU5y3qqm/EbsmCPMjD2HgkEW662+77bb9+/dv2rTJX8tYgwAEIBBPAjwZK9vF21OMJ2M8IxyvDAJI2dqCIYlStrYaxiy1iFsPN98w++uiHWDc399/2mmn/fSnP50wYUJNz62QH04hF+chZhQ9bxl9z+X7X6H83iRD3996663Krnvfy8IgBCAAgWgJ8GS05O/tUcWTMdpgpvSqBCKUsiz7VLV16k2gFi42DmORp8o3suaT5SG9snaHedXisvfSJWv0yqr36jAWLq58oxYurjzqRZD2/NLVNnHiREsdm/aqU78aCMgM9smTJx88eLCGPCSFAAQgkEwCPBmT2W5he82TMWziqSsPKZu6Ji2tkFnQpryqVA8CSSBw4MCBnp4eNaSfAwIQgAAEIAABnozEgGcCSFnP6MgIAQhAoGYCMkBDpGxXVxdqtmZ2ZIAABCAAgTQS4MmYxlYNqU5I2ZBAUwwEIAABg8CJEyf6+voAAgEIQAACEICAIsCTkUjwQAAp6wEaWSAAAQjUS0Ce2fWaID8EIAABCEAgRQR4MqaoMUOqClI2JNAUAwEIQAACEIAABCAAAQhAAAJ+EUDK+kUSOxCAAAQgAAEIQAACEIAABCAQEgGkbEigKQYCEIAABCAAAQhAAAIQgAAE/CKAlPWLJHYgAAEIQAACEIAABCAAAQhAICQCSNmQQFMMBCAAAQhAAAIQgAAEIAABCPhFACnrF0nsQAACEIAABCAAAQhAAAIQgEBIBJCyIYGmGAgERGB86RFQKW7Mvl8/7FKONh2jRo1yYzCINCP0IwjL2IQABCAAgWgJxOeBWBMH9XiUJ6M6asrrY2Kejz7CxFRoBPhKFxpqCoKA/wTksS1G+4qHvG9sbPS/mLotykNabAwWD3lfz9N6pH7U7RQGIAABCEAgPQQqH4jqSswP4/l4VD94Psa8vXAvbgSQsnFrEfyBgFsCxmPbyCCSNoZq1nhOG37W/7R2y4h0EIAABCCQAQITJkyQWqqHoDrU+5irWZ6PGYhNqhgsAaRssHyxDoGQCfTrhypUemjNh7o4ruIwPBxbeqjrcm2M6ZAr5n86jCh2rrjx87MkM0ZVmcdWNVQcyqDRH2v0zao3JxUPlcz4p7xhRHHIQUhxEIAABOJAQI1Ycnggqkek8VQ0PyKNJ6D5waieieowKmh+Jsp7dV3NuDEf7oFYPh/VI1EZKXs8mh+LxoNSXTQ/CuW9+fmohhPzfHTfLqSMJwGkbDzbBa8gUBsBY4KQejBLZvWqlK0St2Vjjwf0Qz251eNZXg8VD+OK4cdh/ZB/qjfGPz2rWWVZjTRWT27VW2s8rVWCIf0wrh87dkxdlzfGe3XluH7IG/XAVv9UV3ha1xZPpIYABCCQIgJuHohSXfU0ND8ZDQbybJT3xoNS3ivVql7Nz0RDzaq8R/RD3nh4Vpqfj+bnoOGV8XxUwrWm5+MJ/eD5mKIwz2hVkLIZbXiqnTIC5umy5qoZvbJl9VWP6sqj8vdmlUaJWOMwfoT2jNHl4hbq4e3mUJKVAwIQgAAEIKAIqB95q9IwPxAtH45Kx6rD/L6qZSViaz14PtZKjPRZJoCUzXLrU/f0EzB6Zc0Djx2qbfTKqjeWKc0/QqefIDWEAAQgAAEIQAACEIglAaRsLJsFpyDggkDlmhYOPz8bA49dGNaSlM0FcpnLMpmsWyzX1eIW6jAGTdVjlrwQgAAEIAABRaC3t1dezQ/BypURY8iK52MMGwWXkkUAKZus9sJbCJQQMNRs5TAqY36sIWKN5aAsIRoTgQwRa9crqwYbqzHGLtvDeFqr3fMkl5oWa7wx76dXdVCxmg7ksCWPMWNWrXghidWMIA4IQAACEEgrgcoHorHmU60PRPeIzA9EY8iS++yS0ng+GuOKLZ+PahUJH5+PxppPPB9rai8Sx40AUjZuLYI/EKiNgDFLVr0xDyS2HF1srPakijH/03J0sVwsmygruYwlLowFLeSi+X1lHYxNZeWN8ZxWyYw1n8zLNhqrWag0Zf9Uaz4pTVu5/pNcNNZ8kjfm57Sx0EVtlEkNAQhAAAKxJ1D2QDT7a/lAND8xzU9D4715rk3Ze+PJaF4K0bhY9kB083w0L39oeG5cND8ELR+IRhbz89FY+9CMQl1UT0Oej7EPahysQiCXz+dzOe01TFSdnZ1tbW3y6q1QyThjxow9e/ZYZpfq2Jm1+8hDFikitFz+FuSvNQcODgV5a3eHXK2tre3t7S0tLZJGOiGbm5t9L8LBoOeArDOK3KxmESaHxJUlj/Awo1T4RBuoiWsgHIYABJJLIOQno9pXlsMvAmHqAp6MfrVahHakETs6OuQ1TB+UgEXKasxDU3feyvLXPX+tIWWFQMgPbG9RpG4uobW+57I8Z/S9akHcjnlgB0EVmxCAQAwJ8GS0bBRvjyqejDGMcFwyE4hQyjLAmFCEAAQgAAEIQAACEIAABCAAgYQRQMomrMFwFwIQgAAEIAABCEAAAhCAAASQssQABCAAAQhAAAIQgAAEIAABCCSMAFI2YQ2GuxCAAAQgAAEIQAACEIAABCCAlCUGIAABCEAAAhCAAAQgAAEIQCBhBJCyCWsw3IUABCAAAQhAAAIQgAAEIAABpCwxAAEIQAACEIAABCAAAQhAAAIJI4CUTViD4S4EIAABCEAAAhCAAAQgAAEIIGWJAQhAAAIQgAAEIAABCEAAAhBIGAGkbMIaDHchAAEIQAACEIAABCAAAQhAAClLDEAAAhCAAAQgAAEIQAACEIBAwgjk8vl8Lqe9hul4Z2dnW1ubvHorVDLOmDFjz549ltmlOnZm5aPu7u6+vr6yBM5ZHKyF9pGPBYVWWYeCqrb7lClTGhsbqyYzErS2tra3t7e0tMgVydjc3Ow+b/0pPQekFB1ac6hqhlmct7Li42T9gVFpIdpADaJG2IQABCBgSYAno4fvqA6x5O2R6nuuIKKdJ2MQVEO2KY3Y0dEhr2GWqwRshqRsT0/PX1/1sZ17eyY3jvQDtK1grtu4veV6y6w3v03V/DfbPTA4c9rUNdt/0tTU5IZntPdBHtg8sN1EqaSJNlBdOkkyCEAAAvUT4MnIk9FlFPFkdAkqzsmQsrW1jrf74/KLzpw6cdTqJWeOGinDqovqS/uvocRMkqyka9cxcYmForVCjgrL7hOXW9AtO100V0TrfSsyNetMw0JprYeTVCVQak2VYd8NXlu7mlL3Hhq6be3r+/sHN72yz42RaO+D3gKyCM9pEIFd3b39zqq3VXjFeSsrPk66Cbxa00QbqLV6S3oIQAACngnwZETKugwenowuQcU5WYRSNitzZfv7+1/6xcH7rzlD17EcZgKhji13iX7C2IbVf37ejh93SV+6yywkgwAEIAABCEAAAhCAAASyQyAruu7AgQNN40ZOGOPL0OLshEeUNR3dcNLkxtEHDx6M0gnKhgAEIAABCEAAAhCAAARiSSArUjaW8HGqOgH5DUI6ZoeGhqonJQUEIAABCEAAAn4TOO+886655ppnnnmGZ7HfaLEHAQjUSwApWy9B8gdKYGBgQKRsV1cXT9BAOWMcAhCAAAQgYElg586ds2fPvueee2SbgL/6q7/60Y9+FPK2F7QLBCAAATsCSFliIwwC3f2Dne/1W579h6v3uJ44caJyC6Uw/KYMCEAAAhCAQLYJyFYCt9xyy8v6MXHixKuuuurcc8+9//7733nnnWyDofYQgED0BJCy0bdBuj0QEbvw3u99cMXWti+/YHme9qnN8+/ZJcmcOYiaTTcoagcBCEAAAhCIM4GPfOQjq1at+vWvf/2///f//r//9/9OmzZt7ty5GzduPHToUJzdxjcIQCDFBJCyKW7cKKsmfa2qD3bRA/85ZtRJr98/b+/XLut8cEHl+fZDV02dNOaT3/yvKN2lbAhAAAIQgAAEXBAYMWJEW1vbv/3bv7399ts33njjunXrZODxJz/5ye9973v86OyCH0kgAAE/CSBl/aSJLUXggSd/dnqhG3bnG7/tefkX781a9V25ItcrEal9d3a+0dUzcBSAEIAABCAAAQgkgsDYsWMXL178/PPP792796yzzvrLv/zLD3/4w3fdddcvf/nLRPiPkxCAQAoIIGWDasTc8p3KdG75Dv11u3Yuk3ObOh0Kzt3wrOWnuSVPF2wuecoue27x1kKa67cEVTdHu9Ife/emva/eO1fvgF34+zWL5FXeyxW5bjkztrDvziGkbCQtRqEQgAAEIAAB7wROPfXU22677Sc/+cmWLVtkYYsZM2ZceOGF7e3tdNJ6Z0pOCEDAHQGkrDtONaYSHZtfN1vp2Py6OSp3ft0l+fVyzlWns5qtscDh5PmNC5SazT+2MBeFmt3fPzhhTMNHTh1fVgW5ItflU89VIyMEUkDgkUce+ZB+3HfffUZ1/u7v/i5XcchFEggVOKjQgAMczDeJGMaDDDz+n//zf37ta1/73e9+9/3vf//OO+9kXagUPLOoAgRiTiAnK6rLzTHkddU7OztlooW8eqMjGeU3vz179lhml+pUXt+3b9/lM6d33je9+FExjfZfI70pY4kRx8QlFjRruRsNHStvlI7NSZesSFm9qII1kbL59fP0D5VTw25Ir2y+/bLSi7qRpU/nN1xhSqnnGvba9G7xVpGy2sfXb8k/dtVwra0Si+FyLHppJowGgaoX3yfzY2V5J+mGrWyF1hVbO74yq/XkRpcfSfr2LdtkEo6kb2xsbG5utguY1tZW+QHYTUpvIeecy0NAGgYtw7UQEFaRXM9Heqta/HXUY9N3g/FxMohQiTZQg6gRNiEAAQgoAm+++ab0ysrx05/+VJaDku9psn+PjD225OPw7Aj5KRBycd4emvFxMoho58kYBNWQbUojdnR0yGuY5SoBS6+sz8w1HbtW9ccaOtapiNyy580f5254rqArlj6b085nrJ8BxQHGuSVP5hYXTnNKo0tWdGzu+s0+VxJzEIAABCAAAQhknoB8j/zxj3+8cuVK2Z7nggsukGWNpTP2v//7vx977LErrrhC+mkzTwgAEIBAsAS4y/jJN3fjCyYdqwnaEplaOldWxhg7lC29svp5uZ2a1dTykqfyG67MbyycxixZZTYqNTulcXTv4aFfdfWV1e6X7/T2HRmST/0kji0IQAACEIAABMIlcPz48f/8z//83Oc+J+s8yTaz/f393/zmN2U48UMPPTRv3rzRo3nQh9selAaBDBNggLEmCYsB4MMA44KalWG/Jb2yFgOM9UJz0iubf1QfZqwGH9/wXP7Ry8wDjEXKiqAtJC4OMNZF7HwlZS0HGGsDSbWhxTLGWN5sLo4xth6N7O8AY3FVVir+6ua949/fIL/XHj56fOzokXJR9O2XF037/PyzLP/cLMceM8DY7taU9BFK8Rla5uyJ748GhlH5jhSDEIBAaASOHDny4osvyhDip5566rTTTlu4cOGCBQukP9byRup+6k1PT09vb6+5Ft6ecd5y6V/FfJ5649Ai3soKwknPnniLtylTpshMMetvgJHOEfNWHXKVEYhwgDFS1mcp636ubKBSVnpoo5orq4JbViqWFZ7e3n/o2gd2f/8ebcKw9Mc2jmmw++NHylaS8faYSYRKTISTQTyokLJBUMUmBCAQKAHRmc8995wo2O3bt//hH/6hUrBnnnmmc6FupKyI2L++6mM79/ZMbtR+8vb1sFWnvpZi/g5ZYdg3F3wz5Fj3YEvpHhicOW3qmu0/aWpqqlRBES534nc8ZNQeUra2hndzfyyzGOayT9qNrbDyk3TGqhWMXfXKqomynntlZdKsLF+slW6tY/UbbvDLPpnJOywBVX4js1oRil5Zuz8MbypXiwC/f3v23WB8nKztruQuNVLWHSdSQQACMSJw3nnnnXLKKaJgZfqrvHHpmZuvassvOnPqxFGrl5w5aqSa72a5ymapXKxYa7Pgj9P1MsFZrZTyxTiL2S2uO3xk841L1dHyy5jdl7SS6xV1sTZls3in/ogtbUHLdT1dNnINyXoPDd229nXp5Nj0yr7yb4D0ytYAMqZJI5SyzJUNJCZkJx61r6zoWLWvrN0hixjnbnheP2Vo8aVGMn3NJ23Zp+LoYgsD+hjj4WWfhnWsErSFAcaBVLCqUemVFR0rvbLHjp+QN3Ja7ihb1Q4JIAABCEAAAhCIkMBrr7327LPP/vmf/7l7HevGW5lh+9IvDt5/zRlFHesmE2mSSmDC2IbVf37ejh93SVd8UuuA37EkgJQNqlnUvrJKzeqvl9iq2UfnyXRZpWOLr2rNJ23ZJ3MufSce3eaG+cU3w8s+Fa7oOlZLo2/GE8khc2VPX7FVtuRZ/E8vHz12Qt7IKVfkeiT+UCgEIAABCEAAArEicODAgaZxIyeM8X1ocaxqiTPDBEY3nDS5cfTBgweBAgEfCSBlfYSJKY2A9L7evWnvq/fOla1l9z208L01i+SNnHJFrtM3S5RAAAIQgAAEIACBbBKQnzCkY3ZoaCib1afWvhNAyvqONOsGZSLEhDENHzl1fBkIuSLX5dOsA6L+EIAABCAAAQhAIJMEBgYGRMp2dXWhZjPZ/v5XGinrP1MsQgACEIAABCAAAQhAIK0EuvsH1Uoolaeb8XcnTpzo6+tLKxzqFSYBNuMR2iX7yub+7HuVDZD/j5naxZL18cpXwJMdZSVJfq0+RbZ8mTvH5fIsE1suoOd0URYuftLw3DRR1rxUnbaeXu66TZqf3140XM3h5eyKBVz7uJbmO9cV01gucGe96p3cwmRarAwnLuuY/eU7vR//0vZ931pguSVP6jfjqdw3T7H1fQXgkPe5cbhbeatayEx82VfWYbu8Mj6sYBzm442yIACBCAlUXcG4YmsJ0/cxu+WIy7+JuchitxxxFVPmL4fF96xgrMeTiNg/+98/eOEn78rEV8sAk313LjrnlLWfvaCpIoHlzhQ8GSP8O/Wr6AhXMEbKmu9W+r1Tl7L5/7jIaN3czbv0KzMdpGxRx84qqFivUtbYj6dCDOt+2ktZpWONRYy194Vln0zLtF+/2aiUnZTN6SJWHd6krGSU5Z2+unnv+Pc35PP5w0ePjx2tLerQe3joy4umfX7+WZZ/NimWsrLCQZL3zStbtb+09Rw/rOX+6Jsh+0IDLMJhu7wyf3hg1xIVpIUABBJMAClru+OO+YunKZHtjonx2IxHOirUHDHRsadMfP+q6849tWmMZeeE2nfn932Dm7/QVv4QXLG1fcu2lpYWud7Y2Njc3CxveDIm+O+86DpStrZGrHp/rDTnfl/ZJEpZs47V7pCLt1pKWXWXDLpXVsFXtzzZjOfaB3Z//x5tDecpjaMtb3kqfYql7I0zP1zbvnnlv0abHnp2P1S7vV40ZfcrdZVfr0sev+4eumUC0n6fPdNPLqa/X3P60tJLdsYzleLqem03nKqpHbbLK3+Ks3teVZokgAAEUkGg6lc1emX1di4fOldsfLvrLrP4vK+sdFHIyp2y4ol0cwwMHh83+iQpQLoo7rz6nNuuPLsyYAeHjjff9MRbDy2cNG6U+VN6ZVPxx21RiQilLHNlawuq3E3fLZ4v5m56UWVWXbIlb5bvlH1lZUdZdRY+Xb49t0zObeqsLFh1yWp2btA2lS28X/qM7C6rn0/nljxdm7vRpRbV2npy49ktE+VON3XSGHnvoGMPDhyVfi3RutH5G1TJ7JsXFNk42WW7vDi1Br5AAAIQ8Eggt3x74avXMu2N8YUtt+x57bzheQe7xte2sjTGN7fckqfssqseCK3E67d4dD3IbOadKTofXPh7bWeKhc47UxT23Tl0NEi/sA0BjQBS1joOZFCxcUoKNVc2d9NL2vs1f6qfF+tXNDWbXyvjirVDvcnduFN7v2627CirNpU1bo6FZOvn5tfPrSxYbSqr5X1U21RWy7j0Ge2f7Zfrp7aprKWazW/UdpdVeUu7ZCOOcpkmMevcqbf++2vSbWXnivx0d/u6H8m0CgetG3E16ii+u7ubffPq4JeYrGyXl5imwlEIQAACVgTkq1p+3SXa96hl2/PrtTfaFzD9C1t+/TztfHSes5r1zFVmhxlf3mKoZtmZwnPLkjEEAkhZa8gyV9aYLltY86mY0OiVdW4eo1e2LJmliPWrpQu3wo0L/DJYv51HPvOJru7DLbdsllEllqcMQZEJFbI8QP1lYQEC0RJgu7xo+VM6BCAAAW8EZABdQceKoC3qWG+m7HLlN8x3MKirWa1LVhY6iaGa9RcF1iDgIwGkrBNMpWZzN2udscZh9MpKx6zqm7U8jF5ZvW+28POejy1XaSqGOlaclI7Zp7500f97+KqOr8yyPPc9uEAWBqhc5i5QVhiHQBAE2C4vCKrYhAAEIBAoAV3HFsbQufnCZkwHU17JpLDCm+KMMEtvjQHGuSVPyhIn6iz5ermxIGJ1NTu8Tmegdcc4BJJOACnrvQVldLExXdbBij5dtjD7wnth1XKWrfxULXnYn4/Xp85anojYsBuD8qoRcNguTzbQq7pjHtvlVQPM5xCAAATiQsBZxxanyxbmysoYYwe/i9PBLlezw2wE7ZP5DdqkMHUas2RVYqNLNv/YVfFRs7KUiax78quu8m1gZZPFviNDqVzoJC7RiR8uCCBlq0Ayd8zm16gZs2rlJ32WrFWvrNpa1jzA2M2PfIW7mD5d1lj2SW6L2j+Lyz5pJW7QZsyWHcYPe3JPLJzFlQPkVlj1bpi79jtyuoiWlCf52Mc+NmfOnNWrV//2t79NeVWpng0BEbEL7/3eB1dsbfvyC3bnaZ/aPP+eXZLSgaKoWRhDAAIQgED8CUh/rFqeU76qVXY8lM2V9b06ag9F45ChxWonRfnmJmrW9+K8GZSlTGSl4vPv2CbTxD54y5aTb3pCzRc7/47td149LZULnXgDRa5ICCBly7HnH/kTOc1XZa6sMV22OLpYW/bJrGNlwSdj8Sf9hihrPhWWfVKjVtRd0s0EDG3Np+KyT1quwppP2rJPljpWS1P4eW+B3BMLZ2FTWfmF76qyu2H+21fLWVLBx6/JP35N6ZVrTZvKRhKZERS6a9euFStW/PCHPzz//POnTZv2pS996fvf//7x48cjcIUiwyUgHa3S3Srnogf+c8yok16/f97er10myzNanm8/dJUsyv3Jb/5XuD5SGgQgAAEIBELAWc0GUqSVUZkrW9Sx8iYuOlZ5Kjvu7PvWApkmtvFzF44aOULNF3vrwQWfn39WaHwoCAKWBJCyBAYECgTGjx9/9dVXr1mzpqur6+GHH87lcqJsp06deuONNz7xxBO9vb2QSiUB2S7v9EI37M43ftvz8i/em7Xqu3JFrlvWV229s/ONrp4BthlIZURQKQhAIHMEdDWrzQXT+mb1nXhcHsZEWZfpy5INb8OzeGt+o+qPLQhabwaDy6U2WWyZMnbkSSPUfDH6Y4OjjWX3BJCy7lmRMisETjrppAsuuOCrX/3qnj17Xn311fPOO0+U7Qc+8IGkDz8e3uK4fMc82ehYmwjk0MD+7JinL88Yq8PDdnniPzvmxaoRcQYCEIBA/QSMAcYygM5ZzcrWibLykzplGJ1RdHE62DNqdpjlIRNlzcs+qQHGImgLb+KqY8VJNXzp7f2Hjh0/ocYxVV05ov5GwQIEqhJAylZFRIJMEzjjjDM++9nPbt++/Z133kn08OOSlS3Kd8wrbJoX+I55xeUZ4xNSbJcXn7bAEwhAAALREjBWNlHTwRx2TxQ1q04tma5m8+2XGTPCzLUwpoYZm/GYl31SKY0Zs2qAcQwPY/jS4n96+eixE2otCYfhSzGsAi6llQBSNq0tS718JuAw/Pi5556L+TI/te404IGdix3ztmoPbHbM8wCXLBCAAAQgAIGICJiHL+17aOF7axaphSRevXfu3Zv20jcbUbNQbIEAUpZQSBWBr33tayeffLJMczUff/d3f2dUUt6XfSr/rCnBP/zDP/zxH//xPffc89Of/vT3v//9unXr/uIv/kL6bGPL0aRjC1vAO7tqv2Pes2r0lGV2Fzvmsf97bGMExyAAAQhAAALWBBi+RGTEmQBSNs6tg281E/irv/qr9957L196lCnVsk/ln7UmOHr06PPPP79s2bJJkybNnj37/vvvP+2002r2NZQMpTq2sJi2UXJxx7zCXNlqO+YVRk857pj3lNOOefHb/53t8kIJQwqBAAQgAAEIQAAC/hNAyvrPFItpJSCjiHfv3v2Zz3xGloBatWqVLAf185//fMeOHddcc82IETH9UzLtMVDYOs/cOsUd8wpzZX1vuPId8+K30wDb5fne6BiEAAQgEDKB3M0v5W6S87um80U3PsivvcaCiG7S+55GFnwyTkvjssFs7vpNuesKp4MDuWsfl9N3D8Ugv/kGQRWbfhGI6fdvv6qHHQjUT0C6bd94440vfvGLH/rQh2TlJ9GxP/jBD1555ZVbb71Vtuqp337QFkrVbA17DPjrmL5CYxx3GmC7PH8bGmsQgAAEIiGQX/OnxikO5G6qomZzy3dKMnlE1umt7Mdjt8i/s+Xc4ic1BzYuKK5jXL7Iv+hYLcFjV+e/rZ1apa7bVGkzd+135KyzFg7Z+c03OLZYrp8AUrZ+hlhILYFf//rXX/nKV6ZNm3bllVdKv+vTTz8t82P/5m/+5swzz0xWnT3v/+7rjnkLtMdwLHcaYLu8ZMUz3kIAAhBIOgFDx9Zfkfzj18hZvx0HC/zmGyhejNdDAClbDz3yppNAV1fX17/+9Y9//OOyu+y7774rm8q++eabss7TueeeK2tEJbTOJWrWcf93+x3zCss+Oe6YN99px7ziAOO4MWS7vLi1CP5AAAIQ8ItA7sYXcze+YJzKbO5GrUtWe7N8R/HN9txy/VymnYWLy2QticJyEpb71Rk/+ErHrLGQhL5E4tO5JYXTc0Xyj10lp+fs/mZUv/me3TKx9/DQ1Elj5L1csSvi4MDR7oFBGZnsrw9Yg0AlAaQsUQGBAoGenp5HHnlk1qxZZ5999uuvv/73f//3si7xN77xDVmvOLZTYWtqPGMYldcd8wrLPpkLrW3HPH2AcdwOtsuLW4vgDwQgAAEPBMxzZSV7fs3FumTVhhnn185Sp35FH1e8drYqQj0ZlaCVfWW1U99UVhRsycNu/TzLlRHVprJaXn1fWS2jvs5/vv0KeT6qR6Sxwn+JwY1X5jdeqa7IBBwti80j0pgrq6XRhxlHeDQ1jp517tRb//213kNDdm4MDh2/fd2PLjrnFAetG2EVKDplBJCyKWtQquOdgIjYZ5555tOf/rQo2LVr115yySUjR470bo6cSSDAdnlJaCV8hAAEIFCdgJooq9IpHWscZV2ydraMXtmyBPn186oX7zVFUccusDNQda6s15I95nvkM5/o6j7ccsvm1hVbLc/mm574fd/g2s9e4LEAskGgFgJI2VpokTbVBF577bXNmzcvWrRozJgxqa4olRsmwHZ5RAMEIACBNBFQarZszSejV1Z/U+iPray10SsrHbOywn8IWJx1rL58sbbyU6wO6Zh96ksX/b+Hr+r4yizLc9+DCzZ/oU2SxcptnEkrAaRsWluWekEAAhCAAAQgAAEIDBPQu2cLs2QduOjTZUsGGAcB0ceVn4Jwz9nmeH3qrOWJiA2/ObJcIlI2y61P3ZNBQNsxT52mffPcuC47DcR8xzztt3PTpnlOXyy0zQb83zGP7fLcBBJpIAABCCSIgLljNr9WzZgtLPsk7y17ZYszZgvLPmnJXPfKqumyxrJPxRmzw2s+5TfMr6SndKyWcXhr2cJmPLLUf3EbHm3NJ8u5srnrnpAzQY2CqxAIiEBO9syURVnlNaACLM12dna2tbXJq7dCJeOMGTP27Nljmd1yjdl9+/ZdPnN6533Ti1mK69Bq/zXWpDUtTluyUK1j4hILRWuFHBWW3Scut6BbdrporoiktarUsAUXia0JmNfvNbAEtaivzMFo37KtpaVF3G1sbGxubrYLmNbW1vb2djcpvYWccy6HgHzrrbdKA89E3jIYCp+XIM3dvEt7rP7HTD0A9P/f9F3tijEXyMpUYWWL8h3zdMuWgWRzXS3PKAta6BBKA2D4XxbXzb83D69pUZrF2DRPi019u7z8txeZaGsxb94uL//4tYVPLeNTc9AqRMuvl7SnLPv01c17x7+/QW6Dh48eHztamyAtKzR+edG0z88/yzbkVmyVgVXyg7SRwE24RhuoQQQ/NiEAAQhYEqj6Va3ii5mL56PFI9LyG1qZqYqHl/LY6SlslcXi0VlM5v7rmXqMOj49HZ+2Lh/E7p+GgX+XM4eH5YOSJ2MK7iHSiB0dHfIaZl2UgKVXNkzmlAWBrBBwM27K/KuzA5egd8xju7ysBCX1hAAEIAABCEAgXQSQsulqT2qTPQKyuIV507zCb80WO+btkMHGZcsz6tvlDW+aVwmvdMc8rXtW+0FY2zFveNO8FCCvabs8qS875qWg0akCBCAAAQhAAAJJJ4CUTXoL4n9WCJjnykqdy+YCmXbMe0H71HrHvDlqeUZNjhb3f1f4ZKcBy80GSnfMU9OB1I55l6tN87QrS56ubAPZLq9ix7wFZcnMm78XRxdHuWOem+3ypArsmJeVPznqCQEIQAACEIBAvAkgZePdPngHgSIBmSubXzOzoDyLW+epfxq9ss60jF7ZcknpenELD61Rdcc8zf/r1SzZKHWsqlrV7fJkng875nkIA7JAAAIQgAAEIAAB3wkgZX1HikEIBEig2BmrLftkHLJCo3nTPLviZYVG86Z5AXpZNO1Ox2qb5sVBx4obVbfLk6We2DEvhMihCAhAAAIQgAAEIFCVAFK2KiISQCAxBNR+A1Xd1XfM2141WZ0Jaln5Kfr+WHNlHbbLkyWL2TGvzsAgOwQgAAEIQAACEPCFAFLWF4wYgUB4BMwds2o/HvMAY+merXSluGNeYdknSZBfr82YdXOYdsxTu/JcrpVYXPZJu6LPmC07rHbM26rS6DvmabvnqRWM9TebZK6sOgtX2DHPTduQBgIQgAAEIAABCGSYAPvKal+kiwFg2pGSfWXZV9b1fSHofWWHQ9TtVrR2++wVo72WfWULGGraNM96xzy9dL8203O1f6zdX7Trpq0lIfvK1kKLtBCAQMoJsK+s7fPO/MWzlt3aLb6s2j5V2Vc25X9fcase+8rGrUXwBwIQgAAEIAABCEAAAhCAAATiS4ABxvFtGzyDAAQgAAEIQAACEIAABCAAAUsCSFkCAwIQgAAEIAABCEAAAhCAAAQSRgApm7AGw10IQAACEIAABCAAAQhAAAIQQMoSAxCAAAQgAAEIQAACEIAABCCQMAJI2YQ1GO5CAAIQgAAEIAABCEAAAhCAAFKWGIAABCAAAQhAAAIQgAAEIACBhBFAyiaswXAXAhCAAAQgAAEIQAACEIAABJCyxAAEIAABCEAAAhCAAAQgAAEIJIxAVqTshAkTDvQfGxw6kbD2ybC7BweOdg8MNjU1ZZgBVYcABCAAAQhAAAIQgAAErAlkRcpOmjRp9jmTbt34Zu/hY8RCKYFcDIEMDh2/fd2PZk6bOm7cuBi6h0sQgAAEIAABCEAAAhCAQLQEcvl8PpfTXsP0o7Ozs62tTV69FSoZZ8yYsWfPHsvsUh3L6z09Pbcu+OhLvzjYNG6kt3LDUoD22rJe1Vlvfhtu/ps90D84549OvetbT0+cOFEV2tjY2NzcbNdwra2t7e3tLS0tVVP60fTlNhwC8q233rp85vTO+6ab8hRxaf81o7O7bkrmNks1U4XPK0q3uz7sQmmW4X+5ua5bqS2LOX0prpI/c1Pprq4HEQXva12xtX3LNucgjDZQA6k2RiEAAQhYEaj6VW3fvn01Px8LzwE3j07zc9Dl07ZaFotHZNGy5dPT7nlX4o6bp6f9o9D2qSrPWytKWtFl39mMWvv/Xa4yLiwflDwZU3ALkUbs6OiQ1zDrogRshqSs/veb6+/vP3DgQG9v75EjRwzcZTeJkmZw0pVeNKeHsjxkKRMNgdYoiKiVAeFymC0jZTUaSNnhP1o3D2k7iRtEzCJlA6GKUQhAIKEEkLK2P90iZUs7HpCyCf0bN7uNlK2tEaveH+3MGR22vQd7Bw4NIGXLQIWmmWtrbz21DBGXwy5jtPdBemXLu5etf4ou+4Glvp+iXf3ejJT18KdGFghAAAI+EKj6VY1eWZ1yfY9CemV9CFVM+EAgQimblbmyZa00dtzYEbmM1t2HgA3dxIgRI5g0Gzp1CoQABCAAAQhAAAIQgEB8CWRUzo0cOXJK8xQZszpGHWNtz7FjxtqdTrnG+nqMGyva2/IcN3ac3WmbRUShv0fjuHFWp+D15ZCRxqeeempDQ0N8/4zwDAIQgAAEIAABCEAAAhAIl0Dm5spa4rVbKUoSx+Ejf33w15oDIoeCfA9yBhjXtoIUyz75HoLvY65sAEwxCQEIJJYAA4yZK1sZvCz7lNg/6CqOM8A4rS1LvSAAAQhAAAIQgAAEIAABCEDAfwIZHWDsP0gsQgACEIAABCAAAQhAAAIQgEBYBJCyYZGmHAhAAAIQgAAEIAABCEAAAhDwiQBS1ieQmIEABCAAAQhAAAIQgAAEIACBsAggZcMiTTkQgAAEIAABCEAAAhCAAAQg4BMBpKxPIDEDAQhAAAIQgAAEIAABCEAAAmERQMqGRZpyIAABCEAAAhCAAAQgAAEIQMAnAkhZn0BiBgIQgAAEIAABCEAAAhCAAATCIoCUDYs05UAAAhCAAAQgAAEI6AQmTJhwoP/Y4NAJeGSEwMGBo90Dg01NTRmpL9UMhwBSNhzOlAIBCEAAAhCAAAQgUCAwadKk2edMunXjm72HjwEl9QQGh47fvu5HM6dNHTduXOorSwXDJJDL5/O5nPYaZqmdnZ1tbW3y6q1QyThjxow9e/ZYZpfq2Jm1+8hDFikitFz+FuSvNQcODgV5a3eHXK2tre3t7S0tLZKmsbGxubnZ9yIcDDoE5FtvvXX5zOmd9003ZS/Gp/Zfc6zaXTclc5ulmqnC5xWl210fdqE0y/C/3FzXrdSWxZy+FFfJn7mpdFfXA4mO1hVb27dscw7CaAM1kGpjFAIQgIAVATdf1Xp6em5d8NGXfnGwadxIvynafhUMryDfXPDNkGPdgy3lQP/gnD869a5vPT1x4kTlhvFtjSej3zEZgT1pxI6ODnkNs2wlYJGyGvPQ1J23svx1z19rSFkhgJQt1+TWehUp+z4e2GE+5CgLAhCIkIAbKavc6+/vP3DgQF9v35EjRwoO26uqsh84SyroLZf+aLI7/C/OW1kBOBlybMh4cjnMhSJlQ26CQItDytaG1/39scwuvbLetLS3XPTKCjd6ZUv/BumVjXL4QG33WVJDAAIQqINArV/Vent7Dw0cQso6qOo46O06IqI8q4wwl0Ou8iOvj1SjMhWhlGWubFSNTrkQgAAEIAABCEAAAhqBsWPH5kYEO8YV0PEhMGLECCbNxqc5Eu0JA4y15gttzK23svx1z19rDjWiV1bg0Ctben+kV5Ze2UQ/MXEeAhBwS6DWXlmxe+zYsSOHjxw/ftxpxK/DeiiOA4Ud/Hb6XuTJpu8Gq3x79N1Je8hum98xnejY8ePHNzQ0qFT0yvpCNVojEfbKImWRssPB76/KRcoiZStmICFlkbLRPm0pHQIQCImABylreObvtxFnHeitjyHkXCEXF+b3N6RsSH+QARcToZRlgHHAbYv5bBOQ3x3ZNy8LIcB2eVloZeoIAQhAAAIQgECsCCBlY9UcOJM2Auybl7YWtaoP2+VloZWpIwQgAAEIQAACcSPAAGOtRcIcyuKhLA9ZHCrlrzVvBfn+ZxDtRAvnYVQHDx5M8r55jotw+LZCh2+G7EMrwCIctssr8yfaQPX97w6DEIAABOwIMMDYkoy372Dx+aYaRMDzZAyCasg2IxxgjJRFyg5Hu7c7rIctjnz/A4v2PujmgW2xb56i4G2LOW+5Qi4uNk76Hm9lBh22y0PKBg0f+xCAQDwJuHky2nnu77cRZx0YH5XoPEM1TCbMlY3n31ScvULK1tY6nu+PHkRXHO4d/vrgrzWHZ0CYt8L4S1kV4iX75iFlbb/F2N4Qwtytvra7UmlqY7s8pGw9GMkLAQgkl4Dnr2oha8uQi/P2HSw+TgYRkNF+hQuiRhm0GaGUZa5sBuONKkdGgH3zIkMfYsFslxcibIqCAAQgAAEIQCC7BBhgrLW9tx/JQsvlb0H+WnOgR6+suq+UcRjeN6/wse3dJ/Eb03na6a7K36Mnm95i3ttjoWy7vDIj/PbsjSq5IACBxBGgV9ayyTw/j7xl9D1XEHHIkzEIqiHbjLBXFimLlB2Odn9veUhZSylbdnPxl7mzDoz/rzZViYWMy/cnAQ9s35FiEAIQiCcBpCxS1mVk8mR0CSrOySKUsgwwjnNg4BsEIAABCEAAAhCAAAQgAAEIWBBAyhIWEIAABCAAAQhAAAIQgAAEIJAwAkjZhDUY7kIAAhCAAAQgAAEIQAACEIAAUpYYgAAEIAABCEAAAhCAAAQgAIGEEUDKJqzBcBcCEIAABCAAAQhAAAIQgAAEkLLEAAQgAAEIQAACEIAABCAAAQgkjABSNmENhrsQgAAEIAABCEAAAhCAAAQggJQlBiAAAQhAAAIQgAAEIAABCEAgYQSQsglrMNyFAAQgAAEIQAACEIAABCAAAaQsMQABCEAAAhCAAAQgAAEIQAACCSOAlE1Yg+EuBCAAAQhAAAIQgAAEIAABCCBliQEIQAACEIAABCAAAQhAAAIQSBgBpGzCGgx3IQABCEAAAhCAAAQgAAEIQAApSwxAAAIQgAAEIAABCEAAAhCAQMIIIGUT1mC4CwEIQAACEIAABCAAAQhAAAJIWWIAAhCAAAQgAAEIQAACEIAABBJGACmbsAbDXQhAAAIQgAAEIAABCEAAAhBAyhIDEIAABCAAAQhAAAIQgAAEIJAwAkjZhDUY7kIAAhCAAAQgAAEIQAACEIAAUpYYgAAEIAABCEAAAhCAAAQgAIGEEUDKJqzBcBcCEIAABCAAAQhAAAIQgAAEkLLEAAQgAAEIQAACEIAABCAAAQgkjEAun8/nctprmI53dna2tbXJq7dCJeOMGTP27NljmV2qY2dWfdTd3d3X12dOUzWLt4J8zOVco5oKCq2yDgW5afcpU6Y0Nja6SSlpWltb29vbW1pa5L3kam5udpnRl2SeA1JKD605VE3DLM5bWfFx0pfYKDMSbaAGUSNsQgACELAkwJOxpu9mzs8+noz8lcWcgHy96ejokNcw/VQCNltStqen56+v+tjOvT2TG0f6wdpWM9dt3N5yvWXWm9+mav6b7R4YnDlt6prtP2lqaqrKM1qFwAObB3bVEFUJog1Ul06SDAIQgED9BHgy8mR0GUU8GV2CinMypGxtreP5/rj8ojOnThy1esmZo0bKyOqi+tL+aygxkyQr6d11TFxioWitkKPCsvvE5RZ0y04XzRXROuCKWM0607BQWuvhJFUJlFpTZdj3hNfWtKbUvYeGblv7+v7+wU2v7KtqJNr7oOeA1MlVGUSQymehc499mEzqHDtQNTLLEkQbqLV6S3oIQAACngm4fzJKN0Nvb6+5oDCfAkE8iB2geataEE569sRDSDiPs+PJ6AFp3LIgZWtrEff3R7Pd/v7+sz7S+vYD0yeMUV2ySFlL1RoXKSstNDh0vPmmJ97qem/SpEnOIRLtfdBbQBZ/BEDKlrett+er77lquyu5Sx1toLrzkVQQgAAEfCDg5sno91i5EjnsQx2qm3AckubbeDXfDNlXKNginMfZ8WSsHmixT4GUra2J3NwfKy3u27fv8pnTO++bXvwIKRt3KSst1bpia8dre6sOvo/2PugtIJGydn/2votSbwZruyu5Sx1toLrzkVQQgAAEfCDg5slYOlZOCrX8Yma6XnhrOTqsNFmJKauPLMe4FR7MJf/R/6GntstSw3XdiuU4ONvrnrJYjivULFmhK7/uQ+uXmXAeZ8eT0X/ioVuMUMqygnHorU2BNRI4cOCA/HA7NDRUYz6SQwACEIAABCAQUwIyVu6lXxy8/5oz9DlfHGkmMGFsw+o/P2/Hj7vk61ya60ndoiDA7SMK6pkss7t/sPO9fruz/7CtUh0YGJB7X1dXF2o2k4FDpSEAAQhAIIUE5HfqpnEji3O+UlhBqmQmMLrhpMmNow8ePAgWCPhLACnrL0+sWRAQEbvw3u99cMXWti+/YHee9qnN8+/ZJSntCJ44caJsCyVYQwACEIAABCAAAQgkhQDj7JLSUgnyM0Ob8TBXVo9Lm0kalssdW6/hXPMKxlfcs+u0pjGrP3neqIaT7P421DyK3/cNbv5CmzmNzJVt37Kt6oax0U60cDMjqHKFRlVNb9M4veUKojiHm118nPTsictbufs9kKMNVJfVIRkEIACB+glUfTJWfCvTv6IUHo2m9+qri3FYbgNRSGI3h9bKGnNlS6gGu+yTaj3jG92IESNOPfXUhoaGwvXW1vb29qrf9OqPSSwERyDCubJIWXWHNP6Gq67fa5XY8sZafpd0vEFbJra8zzpdLLvdW1UqRCkrY4ZlK53+I8c+/sVtP/jHuePHjJzSOLpxTOHOVfnnVFiv+KGFk8aNMj5NgZSV4TS+7mZsJhfCs8exCN/K982Q/W06wCLc74GMlA3uOYplCEAgVgSQslbLROnf0xK+7JMMoOu1nxTm8E3P/I1uwoQJkydPRsrG6m+2HmeQsrXRq3p/tDRHr6yOJaRe2Qee/Nndm/ZOGNOQz+cPHz0+drS2AZLc++68+pzbrjzbrr219Yq/Mqv15MY0SdkbZ37YtJux6ecGtz8te8hi97tJ0VQNyy2aTZX+VhLG89gcrna/1Hi4XtsNp2pq93sgI2WrwiQBBCCQDgJVv6rRK1vS25yEFYxFxP7Z//7BCz95V2a92kWp/LZ70TmnrP3sBU0Vaew6J3gypuBPPkIpy1zZQOInd+NOZTe3fId6zS3fXjiXbc8t22ZXau6G53x0KHf9loIb12/20WxVU9IfKzr21Xvndj64YN9DC99bs0jeyClX5LrDCk9VLScuASs0Jq7JPDjM2oweoJEFAhCAAASSRWD56lf+YOL79xe/1KmvdmXn2w9dNXXSmE9+87+SVTW8TS4BpKz/bSc6Nr92tq5gd+bXzVEF5NddUjjXX5JfP9dBzbp3KLfkKefE+ccWKjWbf+yqXIhqVsYVS3/sR04dX+aeXJHr8qn7OiY9ZXd3Nys0Jr0R3fjP2oxuKJEGAhCAAAQSR0B6IGT7ib1v9by0593PXvo/unoOyz/tuiXUb7s73+jqGTiauJricBIJIGV9brXcjS+YdKwmaGs68o9eWlP6qol1Nat1yYasZqs6RgIIpI8AazOmr02pEQQgkG4CavScHDJ0Tr3mtNFz2gA6ddpV3+dhdIuNYXSFNzHBLvPFTtd3oJj3Dy+NGTXysrt3qa0o5KJ8ZOlk4bfdQ0jZmLRhyt1AyvrZwLqOnaXdCqVjdl11Hatukbllz+dueL5wJ9UHGOdueNZwK7f0Ge3K0mf08+nckqcLKfUuWemYzS15snBl8ZO5xVvVaa6VIWL1N5v8rDC2IJBGAuyBnMZWpU4QgAAEygmIjlWj5/Q3l6iP89roOW0AnTpDGka30RhGV+iBiENr2c0Xy+aUsTi0CD5UEkDK+hYVJTpWH2BsPsrmysrNsaA/lz2fXz8v/+g8Zz/y7Zfr5xX5DVcoNZvfMF+95jdcqd2FFz+Z33hlfuMCddqr2atz1wWuZmX9Olnh6VddfWWV+uU7vX1HhuRT36BjCAK+EmAPZF9xYgwCEIBAfAkYs8AMQVuTr8EMo4tgUphDre3mi0mWDE4Zqyk8SBwaAaSsb6ilP1bUrCYv1842ln0yrJfNlR2+vr6KiDVSlvXKVvotatayV1YTutdvli5Z/c2m/Lev9q3ONoZkxx1Zqfj8O7bJanUfvGXLyTc9IW/kPP+O7XdePc1hP56gHcM+BJwJ+LWmxYkTJ0ANAQhAAAKxJaDrWLWsSaFj1tlVGUCnJb5BhtEVludUb2yG0T1tM4yusMSJ/oWt8J3NXG5US5zEtplwDAJVCSBlqyKqIUGJml1eWMS4hvzFpPlHL1M3x9zSZ6UzVn/zjNEra2fQ3CsrHbNGMpOOFUEbuI5V5cqOO/u+tUB21tn4uQtHjRwhb+R868EFn59/lgcgZIFAoAQq17RwWGebNS0CbQuMQwACEAiagDELzFLHls2VHR5Gd8PzMoauamds4dua9TA6bTxdcRhdYSRdxTC6GC1xYjfITmrBOLugoxT7LgkgZV2CcptMV7OaiJVf++Q3P7fZ/E5n3BllBeNif2yhY9bvorAHgWQTsFzTwmFBC6kta1oku8nxHgIQyDYBbfSc/g1NJsoayz4ZSMrmyg5frzYXzEipdcmaFjephG3XK6sJ3Th9bbMbZMc4u2z/AcWr9khZ/9vDGGCsq9nCyni1FqN1zGpdspepjPIjX+UAY5koayz7JF2y5gHGqldWvyEu1N+ErWMNebD4n14+euxE1fXuauVD+poIlK/QWLo8o+MKjcMrkNVUomXiXPxWaGQP5PqbFQsQgAAEEkfA6G+wVLPuq6O+rWlftPTRc8U3V6jFTezs6MPohtc3GdbA0X1ts3PVcpAd4+zcRwgpgyaAlA2EsNqPR5Og+sp4xu6yZYUZo1aM6+aBK4aOLZgqLvtkvjkayz5ppVTcFpWO1T7SJ8qGdiAPQkPtpiD7FRoLyzPqKzQW1tB2Y9AuTfWNjuO3QiN7INfT4uSFAAQgkFwCRn9DnWq2TgKlw+ii6X5wroL0zbae3NgyZezIk0bIG3Wy7kmd7U52vwggZf0iiZ1hAsiD+ERDqY7Vflip6ZDfm2tKXzUxa1pURUQCCEAAAhAIh4AhYvU32r6yHg7peDBWNpHs+jC68gHGxWF02rJPxWF0hWWfCsPoFhvD6Arzwjx4ElAWtZzE2/sPHTt+Qt6o02FFiYDcwCwELAkgZQkMCKSWQK07Daj9jWVVRtMKjfq4KeuNjrVdjj1tdGzsnicbHW9OLX0qBgEIQAACsSdgjJtT+8oau8uWOS77JpZfefRS40rFMLrCAOOKYXTask9KzRoj6YpXjGF0hTcxIWc5X0xmjTmvKBET53EjCwSQslloZeqYRQIuVmjcJrNk1Wk8pEXNyih3tys0bvC80XFcVmhkD+Qs/m1QZwhAAAIQcEHAbr5Y54MLXr137t2b9tI364IiSYIlgJS15pv7s+/lbt5lOl/K3fySm6aQrWUrN5V1k9GvNMbWsrLmk4PN3HWbctc94ZTg2sdz13xbnbX6hjyolVgQ6V2s0Dg8V3b4p+WaVmg09cpWVsFxo+O4LKzNHshBxB42IQABCEAgBQTs5otJ1T5y6vgJYxokQQqqSRUSTQAp69R8+f+4qHjOlHRV1azoWElmrPnkOTJkPKd5SKd7O2rxAJl3YaxgbCEwNBG7ydlm7trHNTvfuU5OreI1qlnkgfsmCzSlX2ta2K7QqPfK2lXBfqPjyBbWtnSVPZADDUKMQwACEIAABCAAgYAIIGUDAhuBWekEUzrWuez8t6+W0yFNQcc+fm09dUAe1EPPx7yla1p43Bqqfn/iv0Jj/XXEAgQgAAEIQAACEIBAmASQsl5o5276rn6+qE5lQnXJ6m+0fbe1N8t3yvqxxbOwMl5O29JzeI5iZfHDK+4sfVZtVqaZWvqMsa+ssdCOF9dDzKNWbz+7ZWLv4aGpk8ZUXbr94MDR7oFBGZwcoo+ZKCrAFRpLBxhX3+g4lis0sgdyJv4MqCQEIJBeAjJoLneTnOq7WeEbmpvqqm9oblIGlGZ4Ulhx3/WygmRxxNz12mA6ddq5IZ0Qxumjq3bzxaSIX77T23dkiO9sPtLGlDcCSFknbua5spIu/x/6MOObvqu9X/On+TUXy6lduVFTs/m1s5QtNcBYdKz2ft0cdepXStZ5l808K/eV1bIU18STBfHUmngiYrXrxX1ltStLtPXcyw41nlNdLIw0Lu4rW1Nw5B+/Vs6CHX1osRpm7O1oahw969ypt/77a72HhhwsDA4dv33djy465xR2KvPG2TlX+QqN67V1Gi1CqGKirHkzHosVGvUBxjVsdLwxdis0sgdyEPGGTQhAAALhE9C/mBVO7YtQsafBzhPje1qdrkqvg9HxUJOpqpPC1CL/+ce0wXRqPJ3lKie5a7+jJSt+eVNj63w57OaLta7Yev4d2++8ehrf2XzhjJF6CCBlneipibIqhdKxxmH0yjrTN3ply5JZith6GrLENzVj1pOOLbFTt45V1h75zCe6ug+33LJZ7n12Z/NNT/y+b3DtZy/wCwJ2IOCGAHsgu6FEGghAAAIQ8JeAy0lhVQs1dGzVlN4SWM4X6/jKrLceXPD5+Wd5s0kuCPhIAClbHaZSs2VrPhm9slrf7Fqtb9byMHplZacyu83KqntQSwrjR75aMlmkNVZ+qtOOZJeO2ae+dNH/e/gquffZnfseXLD5C22Ssv7isAABCEAAAhCAAAQUARk6p+8uUTgLF/Whc9qnxQHGMnSucGoTwYxJYWpG2PPaqW+9XnYYi3SqiWAFm0ufzsmpz8GxHEbnsmnyj10lp8vEwSWrnC/mPGWM+WLBtQWWKwkgZeuNCm26rD7A2PlQ98dqqer9PIY61qjSeH3qrN2JiK237ckPAQhAAAIQyDAB81xZwVA2BUxmgamJYGpBE1nhX6EqTgHTZsyqXoe8PgdHFKyZpey+nrfarM6YhqPPArtcy1iYFDY8AafOSWHGXFnNw28vKmvh/OPXyKku+rJsp10EMV8sw39bsa46UtZV8xRmyepby0p/rHa/KC77pF2x6pVVd0nzAGP3vbLqzmjMvjBujupHPq3EDfMr/VaDVbSMi7dq5/VbjK1l9WUDtBkXDoeMUVHDVIxZFsa+srVuxuOKKYlcE9AWtFCnaVkLN7nVwmNuUgaUxrSgxVa7IsxrWtim0YNTrWnhr6vsgewvT6xBAAIQiIqAmiirSlc61jjKumRtnzWqY7bYJWskEx0bXKWKnRCFtSQqC6o6V1ZlCVTHqiKYLxZcGGDZM4FcPp/P5bRXzyY8ZOzs7Gxra5NXD3kli2ScMWPGnj17LLNLdSyv79u37/KZ0zvvm178tJhM+6+RxZS3xI5j4hILRWuFHBWW3Scut6BbdrporoiktarUsAUXia0JmPEaWKyZe2tfcy6ZW9u+ZVtLS4tcbGxsbG5utrTZ2tra3t5eNVn9/lhacAjIt956qzTqTNgtI6HweQlPWX5MLmu/pxSzFNceKz6qrUwVf3jWlhwzHbplyyiyua5GTxXXfCpt/eF/WVw3TwQaflSXZjHWtNACU1+bsfQnZy3gixOB5Ffn3PCj2jI4tSpYxWf59RIisoLxVzfvHf/+BrkNHj56fOzokfKxLLv95UXTHCYCSWTKaHkZZWDYchOr0QZqQPGPWQhAAAKVBKp+Vav4Vubi+WjxiNSff6aeBu2fheU59YU59cWfjIU5dT8Lz0Hzsk/qZ99Cl4PpEan6ZgtS1ubRWXxKal2ymvVir2yhnPIeCOOLnP5kUoubaGt2llwvmCou+1QwVf6UHM5SPmPW1aPQ7htvlXDuOzx0oH/QLtGEMQ124+zsnpI8GVNwA5FG7OjokNcw66IELL2yYTKnLAhkhYCbBS2KOtZpIpBJxwaFjj2QgyKLXQhAAAIxI6B3zxZmyTq4pvZNDNp3/yaFFVYwDtphZZ/5YuFwphSXBJCyLkGRDAIxJaBma5cvaDG8uXFhgLGxv7F59JRpi2NtTYvKGpoWtEj2LsfOjcceyDENbtyCAAQgUDuB4kQw1R+rNk0cXvNJ7ZhYdhibJhqPSPc7TRj7JhpbJ2olFpd90nxwMylsscWkMLXmk+VcWdmVJ3edmhSmvepvAtlatnb85IBAqAQYYKxGmjDA2D0BBhiX/4mGM8C4/LmrzQjKFYdOyaNaj+MbX9Cf3Po87cLKFmpPYzV0St7ryfQVyOQ5bfzq7DB6qmyAselRrY/+tZi8XT5KynkAlXoEy6Nac0nbN89uDLMx0ljf9DiY0VML7/3eH0x8//3LPzphbIPdnVj2QP7sv732bs9hWZfbnIYBxqE+uygMAhCIN4EwBxjrDwXzdznT+1om1BSI1pqlhvS6Y45zc9QzsbRta88SzCOyzohjgHGdAOOcnQHGcW4dfINALAjIXNn8mpnKFWNlC/VPo1fW2VG9Y9ZiJW33vz17AOFmAJVJx9qWEPTWeapg1rTw0MRkgQAEIAABCEAAApEQYIBxJNgpFAIeCRgLaJvzywAqtc2AsdmApXV9l+PCTgNqs4GgD3c6VltbW++PjVjHSvHsgRx0SGAfAhCAAAQgAAEI+EUAKesXSexAIHoCajpQVT/0BS1C2OX4SU2jagsz2mtUY3nG6jq2sG9e1drVn4A1LepniAUIQAACEIAABCAQNAGkbNCEsQ8BnwmYO2aNLeANEVu65UChaGMLeGOAsfteWRe7HF9RWcPyXY71vY5VMmPHY2OvY2NNC7Ufj5ZGW9DiCe3N8IIWhX1lfd9a1ufmwRwEIAABCEAAAhCAQCgEWPaJZZ+UdGDZJ+9/cEEv+zS8AoTbrWiLrVmeXmtpvbkLgtFUZ8frdlkCX7vCvNbFsBOlEevhuve2dsjJsk+BYMUoBCCQTAIs+2T1qNUfWIE/OoNaGbHOSGTZpzoBxjk7yz7FuXXwDQIQgAAEIAABCEAAAhCAAATiRYABxvFqD7yBAAQgAAEIQAACEIAABCAAgaoEkLJVEZEAAhCAAAQgAAEIQAACEIAABOJFACkbr/bAGwhAAAIQgAAEIAABCEAAAhCoSgApWxURCSAAAQhAAAIQgAAEIAABCEAgXgSQsvFqD7yBAAQgAAEIQAACEIAABCAAgaoEkLJVEZEAAhCAAAQgAAEIQAACEIAABOJFACkbr/bAGwhAAAIQgAAEIAABCEAAAhCoSgApWxURCSAAAQhAAAIQgAAEIAABCEAgXgSQsvFqD7yBAAQgAAEIQAACEIAABCAAgaoEkLJVEZEAAhCAAAQgAAEIQAACEIAABOJFACkbr/bAGwhAAAIQgAAEIAABCEAAAhCoSgApWxURCSAAAQhAAAIQgAAEIAABCEAgXgSQsvFqD7yBAAQgAAEIQAACEIAABCAAgaoEkLJVEZEAAhCAAAQgAAEIQAACEIAABOJFACkbr/bAGwhAAAIQgAAEIAABCEAAAhCoSgApWxURCSAAAQhAAAIQgAAEIAABCEAgXgSQsvFqD7yBAAQgAAEIQAACEIAABCAAgaoEkLJVEZEAAhCAAAQgAAEIQAACEIAABOJFACkbr/bAGwhAAAIQgAAEIAABCEAAAhCoSgApWxURCSAAAQhAAAIQgAAEIAABCEAgXgSQsvFqD7yBAAQgAAEIQAACEIAABCAAgaoEkLJVEZEAAhCAAAQgAAEIQAACEIAABOJFACkbr/bAGwhAAAIQgAAEIAABCEAAAhCoSgApWxURCSAAAQhAAAIQgAAEIAABCEAgXgQyJGUnTJhwoP/Y4NCJeLUA3tgTODhwtHtgsKmpCUgQgAAEIAABCEAAAhCAAATMBDIkZSdNmjT7nEm3bnyz9/AxgqCUQC6GQAaHjt++7kczp00dN25cDN3DJQhAAAIQgAAEIAABCEAgQgK5fD6fy2mvYTrR2dnZ1tYmr94KlYwzZszYs2ePZXapjp3Znp6eWxd89KVfHGwaN9Jb0WEpQHttWa/qrDe/DTf/zR7oH5zzR6fe9a2nJ06cqAptbGxsbm62dKC1tbW9vb2lpcU5mR+NbmHDISDfeuuty2dO77xvuilbkZX2XzM3u+umZG6zVDNV+LyidLvrwy6UZhn+l5vrupXaspjTl+Iq+TM3le7qeiCB0Lpia/uWbc5BGG2gBlJtjEIAAhCwIlD1q5p8JZv2Pz78+69/fHSD0a1S7flYeA64eXSaTVk9bWt93tk9B2u77uE56CmLq0eh3aMzkICWcXanr9jyyqs/Vv0T5m90PBkDIR6uUWnEjo4OeQ2zWCVgsyVllcrt7+8/cOBAb2/vkSNHFPGy78slzeAkKr0ITg9lecjiVCm/axRQ1MqAcDnMxpGyug6s9RFe1t76P5GyAUQtUjYAqJiEAASSSqCqlJWK3fynHz55fMP915wxYYzqYEDKFr+Wln0Tre1XYAFp9VVBA+zmuv8hJ+PsPvtvr/33wSNff/w/lXWkrP+UI7WIlK0Nv5v7o6VFc4dt78HegUMDxXtGSKLUm2yOuZS1dc8eam3tXUwtQ8TlsMwb7U969MqWC2zrh25Z+LvpyKVX1tvfCrkgAAEIREzAzVc1v8fKmavs91cQa5yOpfjmgm+G7GMi2CKcx9lF+xUu4r+TtBSPlK2tJd3cH6tK2WPHju3//f4TeW0VKJ+1om7R7vBQlocsTpXy1TdvBdXW3nrqESNGnHrqqQ0NDUhZE4FqP2CX9+IWQ5NeWQ8hWC0LvbLVCPE5BCCQIQLuv6qpsXJ9vX3GWDl/v0RV+Zrn93e2QL5VBuBkmLHoPM4OKRtmWwRUFlK2NrDu749ldsum0YqaPXz48PHjxx2m13qUkfbzdT0Y9Nc9f61pd1ebyjoUVFt76zp2/PjxdjpWrEV7H6RXll5ZLQiZK1vrHzbpIQCB9BKo9auaTPs6NHCowCO039xVeWEW562s2DjpV8Cax9lF+xXOrxpl3A5StrYAqPX+aFj3ILqchJ+DXvX1I3998NdaOFK2anxEex9EyiJlkbJV/0hJAAEIZIpArV/VtLFy+/fnT+irkHrTe95yhVxcwp30JYbLxtlF+xXOlxphBClbWwzUen9Eypr5ImVrizYXqZGySFmkrIs/FJJAAAIZIuDhq5qo2SOHj8hYOScp6+uoN9UeoY1W01Wzl8VZwnbSHnL9EVw5zg4pWz/VyC0gZWtrAg/3R+e7VWjqrsrNqPaRuh4895DFd7dra28XqaO9DyJlkbJIWRd/piSBAAQyRMDzVzVvXzk85/KcMbRvU9X1tq8jAZ2BBBHB0X6FC6JGGbQZoZQ19vLKIHaqDAEIQAACEIAABCAAAQhAAAKJJICUTWSz4TQEIAABCEAAAhCAAAQgAIEsE0DKZrn1qTsEIAABCEAAAhCAAAQgAIFEEkDKJrLZcDopBGQPoQP9xwaHtO2LOVJM4ODA0e6BwaamphTXkapBAAIQgAAEIACBWBFAysaqOXAmbQRk57TZ50y6deObvYePpa1u1KdIYHDo+O3rfjRz2tRx48ZBBQIQgAAEIAABCEAgHAK5fD4vi7DJazjlqVJkXbu2tjZ59Vao52Xx2FdWgIe25p5DQd7a3SFXtMvfOQfkwYMHb13w0Zd+cbBp3Ei/K26/pr9vJTkW4Vv5vhmyr3eARRzoH5zzR6fe9a2nJ06cqBxobGxsbm6udCbaQPUtKDAEAQhAoBoBz1/VwvyioioR2vciz2V5zuh71ao1u5fPeTJ6oRazPBGuYJxIKdvd3f3BD37wV7/61ejRoyub0sPfrYcsYd5W/HXPX2sOHEKTsqIVTz/99FdeeUX1idmpiOD+6t08sPv7+w8cONDX23fkyJEST7ztlu4tl9Zathi8bXbnf64AnAyu6ZXlCfphLgUpGzRz7EMAAjEn4ObJaFeF0L6oIGUtmyC072+qdKRszP+W3biHlHVDqSTNFVdcIZ0eq1atKvsG6U1hhnnT9FCWhyzeFGZoBdXc3vYZBgcHP/vZz/73f//317/+dZUqnlJW+dbb23to4FBJbcLUllpY2KL0X5R6Kys2TtYTpTKwXI5KCzyw66FKXghAIEEEkLKWjeXti5a3L7dB5AoiAnkyBkE1ZJtI2ZqBS8fs0qVLd+/ebYzoM0yE/GNSza7XniF9NaqdgW0O6eqcM2fOXXfdVXVsp4+Flply/8A+duzY/v378ydM4/m96T1vuWKjEp1kc2yc9BwwI0aMOPXUUxsaGpCynhmSEQIQSDoB90/Gypp603vecgWh97x54vxlz3eb3gwGEZZI2SCohmwTKesRuAzaFGEgYmZgYMCjCbIlnID7sZ3BVbSmB7ao2SOHjxw/frzgj4Mozdl+5q0HtcoD27HH1o6e07PQk8GwnbSH7C1gRMfKstWWOlYM8sD2RpVcEIBA4gjU9GQsq503leUtF1K2pp8SgohDnoxBUA3ZJlK2LuAiZWXcZl0myJwiAnZjO4OrIg9sS7ZJ/1YRRMDwwA6CKjYhAIEYEuDJyJPRZVjyZHQJKs7JIpSyadiMR/pApCckzg2Mb6ERkEhgQ5TQaFMQBCAAAQhAAAIQgAAEoiKQyBWMK2ENDQ3JGGMZuhkVR8qNAwHnsZ3Bechvz/z27DK6+O3ZJSiSQQACSSfAk5Eno8sY5snoElSck0XYK5sSKRvn1sW31BPggc0D22WQ88B2CYpkEIBA0gnwZOTJ6DKGeTK6BBXnZBFKWcblxjkw8A0CEIAABCAAAQhAAAIQgAAELAggZQkLCEAAAhCAAAQgAAEIQAACEEgYAaRswhoMdyEAAQhAAAIQgAAEIAABCEAAKUsMQAACEIAABCAAAQhAAAIQgEDCCCBlE9ZguAsBCEAAAhCAAAQgAAEIQAACSFliAAIQgAAEIAABCEAAAhCAAAQSRgApm7AGw10IQAACEIAABCAAAQhAAAIQQMoSAxCAAAQgAAEIQAACEIAABCCQMAJI2YQ1GO5CAAIQgAAEIAABCEAAAhCAAFKWGIAABCAAAQhAAAIQgAAEIACBhBFAyiaswXAXAhCAAAQgAAEIQAACEIAABJCyxAAEIAABCEAAAhCAAAQgAAEIJIwAUjZhDYa7EIAABCAAAQhAAAIQgAAEIICUJQYgUC+BCRMm9PT0DA4O1muI/KkmcPDgwe7u7qamplTXkspBAAIQ0AjwZCQO3BDgyeiGEmkcCCBlCQ8I1EtAxMlFF110xx139Pb21muL/CklIL903H777TNnzhw3blxKq0i1IAABCAwT4MlINFQlwJOxKiISVCWQy+fzuZz2WjWpjwk6Ozvb2trk1UebmIJAhASkt23p0qW7d++eOHFimRvy9xWhY0EXne7a+UjvwIEDc+bMueuuu4wIaWxsbG5u9rEITEEAAhCIFQGejLFqjhg6w5Mxho3izaXW1taOjg559ZbdWy4lYJGy3uiRCwIWBPr7+/fv3y+35oGBAQBBwExAxtrJYb6ClCVCIACBLBDgyWhu5UceeeTP/uzPstDuburIk9ENpUSkQcomoplwEgKuCIiUZaSxK1LZTjRJP7LNgNpDAAJZIcCTUbX0hz70od/85jdZafXa68mTsXZmscgRoZRlrmwsIgAn0kRg/PjxI0bwl5WmJvW/LhIhTJr1HysWIQCBuBLgyRjXlomRXzwZY9QYyXGFAcbJaSs8TQ6BoaEhGWN87Nix5LiMp+ERkKe1fKtraGgIr0hKggAEIBA1AZ6M0gL33XffF77whaibIo7l82SMY6u49inCXlmkrOtWIiEEIFALgb/Tj1pykBYCEIAABCAAAQhAIGEEIpSyDINMWKzgLgSSQmDVqlVJcRU/IQABCEAAAhCAAAQSRwApm7gmw2EIQAACEIAABCAAAQhAAAJZJ4CUzXoEUH8IQAACEIAABCAAgRAIMO8mBMgUkSkCSNlMNTeVhQAEIAABCEAAAhCIhgBTb6LhTqnpJYCUTW/bUjMIQAACEIAABCAAAQhAAAIpJYCUTWnDUi0IQAACEIAABCAAAQhAAALpJYCUTW/bUjMIREpg5cqVkZZP4RCAAAQgAAEIQAACaSaAlE1z61I3CERIgMUtIoRP0RCAAAQgAAEIQCD1BJCyqW9iKggBCEAAAhCAAAQgAAEIQCBtBJCyaWtR6gMBCEAAAhCAAAQgEEMCTL2JYaPgUqIJIGUT3Xw4D4H4EmCAcXzbBs8gAAEIQCAKAjwZo6BOmWkmgJRNc+tSNwhESIDd8yKET9EQgAAEIAABCEAg9QSQsqlvYioIAQhAAAIQgAAEIAABCEAgbQSQsmlrUeoDAQhAAAIQgAAEIBBDAgwwjmGj4FKiCSBlE918OA8BCEAAAhCAAAQgkAwCTL1JRjvhZXIIIGWT01Z4CgEIQAACEIAABCAAAQhAAAI6AaQsgQABCEAAAhCAAAQgAAEIQAACCSOAlE1Yg+EuBJJCgN3zktJS+AkBCEAAAhCAAASSSAApm8RWw2cIJIAAi1skoJFwEQIQgAAEIAABCCSWAFI2sU2H4xCAAAQgAAEIQAACEIAABLJKACmb1Zan3hCAAAQgAAEIQAACIRJg6k2IsCkqEwSQsploZioJgfAJMMA4fOaUCAEIQAACcSbAkzHOrYNvSSSAlE1iq+EzBBJAgN3zEtBIuAgBCEAAAhCAAAQSSwApm9imw3EIQAACEIAABCAAAQhAAAJZJYCUzWrLU28IQAACEIAABCAAgRAJMMA4RNgUlQkCSNlMNDOVhAAEIAABCEAAAhCIlgBTb6LlT+npI4CUTV+bUiMIQAACEIAABCAAAQhAAAIpJ4CUTXkDUz0IQAACEIAABCAAAQhAAALpI4CUTV+bUiMIxIIAu+fFohlwAgIQgAAEIAABCKSUAFI2pQ1LtSAQNQEWt4i6BSgfAhCAAAQgAAEIpJkAUjbNrUvdIAABCEAAAhCAAAQgAAEIpJIAUjaVzUqlIAABCEAAAhCAAATiRYCpN/FqD7xJPgGkbPLbkBpAIJYEGGAcy2bBKQhAAAIQiIwAT8bI0FNwSgkgZVPasFQLAlETYPe8qFuA8iEAAQhAAAIQgECaCSBl09y61A0CEIAABCAAAQhAAAIQgEAqCSBlU9msVAoCEIAABCAAAQhAIF4EGGAcr/bAm+QTQMomvw2pAQQgAAEIQAACEIBA7Akw9Sb2TYSDCSOAlE1Yg+EuBCAAAQhAAAIQgAAEIAABCCBliQEIQAACEIAABCAAAQhAAAIQSBgBpGzCGgx3IZAUAuyel5SWwk8IQAACEIAABCCQRAJI2SS2Gj5DIAEEWNwiAY2EixCAAAQgAAEIQCCxBJCyiW06HIcABCAAAQhAAAIQgAAEIJBVAkjZrLY89YYABCAAAQhAAAIQCJEAU29ChE1RmSCAlM1EM1NJCIRPgAHG4TOnRAhAAAIQiDMBnoxxbh18SyIBpGwSWw2fIZAAAuyel4BGwkUIQAACEIAABCCQWAJI2cQ2HY5DAAIQgAAEIAABCEAAAhDIKgGkbFZbnnpDAAIQgAAEIAABCIRIgAHGIcKmqEwQQMpmopmpJAQgAAEIQAACEIBAtASYehMtf0pPHwGkbPralBpBAAIQgAAEIAABCEAAAhBIOQGkbMobmOpBAAIQgAAEIAABCEAAAhBIHwGkbPralBpBIBYE2D0vFs2AExCAAAQgAAEIQCClBJCyKW1YqgWBqAmwuEXULUD5EIAABCAAAQhAIM0EkLJpbl3qBgEIQAACEIAABCAAAQhAIJUEkLKpbFYqBQEIQAACEIAABCAQLwJMvYlXe+BN8gkgZZPfhtQAArEkwADjWDYLTkEAAhCAQGQEeDJGhp6CU0oAKZvShqVaEIiaALvnRd0ClA8BCEAAAhCAAATSTAApm+bWpW4QgAAEIAABCEAAAhCAAARSSQApm8pmpVIQgAAEIAABCEAAAvEiwADjeLUH3iSfAFI2+W1IDSAAAQhAAAIQgAAEYk+AqTexbyIcTBgBpGzCGgx3IQABCEAAAhCAAAQgAAEIQAApSwxAAAIQgAAEIAABCEAAAhCAQMIIIGUT1mC4C4GkEGD3vKS0FH5CAAIQgAAEIACBJBJAyiax1fAZAgkgwOIWCWgkXIQABCAAAQhAAAKJJYCUTWzT4TgEIAABCEAAAhCAAAQgAIGsEkDKZrXlqTcEIAABCEAAAhCAQIgEmHoTImyKygQBpGwmmplKQiB8AgwwDp85JUIAAhCAQJwJ8GSMc+vgWxIJIGWT2Gr4DIEEEGD3vAQ0Ei5CAAIQgAAEIACBxBJAyia26XAcAhCAAAQgAAEIQAACEIBAVgkgZbPa8tQbAhCAAAQgAAEIQCBEAgwwDhE2RWWCAFI2E81MJSEAAQhAAAIQgAAEoiXA1Jto+VN6+gggZdPXptQIAhCAAAQgAAEIQAACEIBAygkgZVPewFQPAhCAAAQgAAEIQAACEIBA+gggZdPXptQIArEgwO55sWgGnIAABCAAAQhAAAIpJYCUTWnDUi0IRE2AxS2ibgHKhwAEIAABCEAAAmkmgJRNc+tSNwhAAAIQgAAEIAABCEAAAqkkgJRNZbNSKQhAAAIQgAAEIACBeBFg6k282gNvkk8AKZv8NqQGEIglAQYYx7JZcAoCEIAABCIjwJMxMvQUnFICSNmUNizVgkDUBNg9L+oWoHwIQAACEIAABCCQZgJI2TS3LnWDAAQgAAEIQAACEIAABCCQSgJI2VQ2K5WCAAQgAAEIQAACEIgXAQYYx6s98Cb5BJCyyW9DagABCEAAAhCAAAQgEHsCTL2JfRPhYMIIIGUT1mC4CwEIQAACEIAABCAAAQhAAAJIWWIAAhCAAAQgAAEIQAACEIAABBJGACmbsAbDXQgkhQC75yWlpfATAhCAAAQgAAEIJJEAUjaJrYbPEEgAARa3SEAj4SIEIAABCEAAAhBILAGkbGKbDschAAEIQAACEIAABCAAAQhklQBSNqstT70hAAEIQAACEIAABEIkwNSbEGFTVCYIIGUz0cxUEgLhE2CAcfjMKRECEIAABOJMgCdjnFsH35JIACmbxFbDZwgkgAC75yWgkXARAhCAAAQgAAEIJJYAUjaxTYfjEIAABCAAAQhAAAIQgAAEskoAKZvVlqfeEIAABCAAAQhAAAIhEmCAcYiwKSoTBJCymWhmKgkBCEAAAhCAAAQgEC0Bpt5Ey5/S00cAKZu+NqVGEIAABCAAAQhAAAIQgAAEUk4AKZvyBqZ6EIAABCAAAQhAAAIQgAAE0kcAKZu+NqVGEIgFAXbPi0Uz4AQEIAABCEAAAhBIKQGkbEoblmpBIGoCLG4RdQtQPgQgAAEIQAACEEgzAaRsmluXukEAAhCAAAQgAAEIQAACEEglAaRsKpuVSkEAAhCAAAQgAAEIxIsAU2/i1R54k3wCSNnktyE1gEAsCTDAOJbNglMQgAAEIBAZAZ6MkaGn4JQSQMqmtGGpFgSiJsDueVG3AOVDAAIQgAAEIACBNBNAyqa5dakbBCAAAQhAAAIQgAAEIACBVBJAyqayWakUBCAAAQhAAAIQgEC8CDDAOF7tgTfJJ5DL5/O5nPYaZl06Ozvb2trkNcxCKQsCEAiTQPg3FnPturu7e3t7w6wvZUEAAhCYMmVKY2MjHCBgRyDaJyPtAoGACLS2tnZ0dMhrQPYtzaq/JqRsmMwpCwIZIhDVA1tE7PLly3ft2jVp0qSacIvDNaUncZwJ0Jpxbp0U+yb3n5kzZ65Zs6apqSnF1aRqnglE9WT07DAZIeCGAFLWDSXSQAACSSIQ1QP70ksvPeWUU+69995Ro0bVxKse8eM5b/gZhUn4hXou0bO3nksMP6PnOkaSMapCa/pbjjCxDAa57bbb9u/fv2nTpgjdoOjYEojqyRhbIDiWDgIRSlnmyqYjhKgFBGJHIJLd8/r7+3fv3i2LJ9eqY2OHD4cgAIEEEpgwYcLq1at37NjR09OTQPdxGQIQgEDCCCBlE9ZguAuBpBCIZHEL6QyZOHGifJtMCiX8hAAEUkZg9OjRkydPPnjwYMrqRXUgAAEIxJAAUjaGjYJLEIAABCAAAQgkmMCBAwekY3ZoaCjBdcB1CEAAArEngJSNfRPhIAQgAAEIQAACiSIwMDAgUrarqws1m6h2C9zZSKbeBF4rCoBAdASQstGxp2QIpJpAJAOMU02UykEAAgkjcOLEib6+voQ5jbtBEuDJGCRdbGeRAFI2i61OnSEQAgFZeymEUigCAhCAQJwJiJqNs3v4BgEIQCDRBJCyiW4+nIcABCAAAQhAAAIQgAAEIJBFAkjZLLY6dYYABCAAAQhAAAIQCJkAA4xDBk5xqSeAlE19E1NBCEAAAhCAAAQgAIHoCTD1Jvo2wIN0EUDKpqs9qQ0EIAABCEAAAhCAAAQgAIEMEEDKZqCRqSIEIAABCEAAAhCAAAQgAIF0EUDKpqs9qQ0EYkOA3fNi0xQ4AgEIQAACEIAABFJIACmbwkalShCIAwEWt4hDKyTdh7Fjx44pPSprpD6X6+aE7y8eDgSMNOpNVKxGjRrV0NAQVemUCwEIQAACEEguAaRsctsOzyEAAQiknMChQ4dUDQ8fPqzeKNVqHGX/VCnlOKIf8k87jaquq2TOKd0gHj16tChSNylJAwEIQAACEICAXwSQsn6RxA4EIAABCCSDgKFjDXfrV7PJqDleQgACkRJg6k2k+Ck8hQSQsilsVKoEgTgQYIBxHFohlT4YPbGVXbL11NfonhUj0stqPpTZsovyT+O6eiMds6pvVr0xDvOnZRfrcZi8EIBA4gjwZExck+FwzAkgZWPeQLgHgaQSYPe8pLZcwv1WM2aN6a+qu7WmQ2nUweKhRKzZgvrEuK7ey3FUP8wpjStK4qp/qjQMSK6pUUgMAQhAAAIQqCSAlCUqIAABCEAgPQTMc2Vr0rEuF38yhGtVZGWytmp6EkAAAhCAAAQgUBMBpGxNuEgMAQhAAAJRElDrPxmrFhvLQUXpE2VDAAIQcEeAAcbuOJEKAm4JIGXdkiIdBCAAAQikg0DlIk+VC0Glo6bUAgIQiBUBpt7EqjlwJgUEkLIpaESqAAEIQCCdBGRfWVUx8wpPRk9sPV2yhpqtnFVrzINV6zxJ6VUHFasExrJPlY1hzI810jD8OJ0hS60gAAEIQCBEAkjZEGFTFAQgAAEI1EJA9pVVc1+NQ+VW/yx7b77ophBjU1nz2sUqo7Hmk7HCk3HRsGz+SC6al3SqXP/JnKDsU/nn0NCQG4dJAwEIQAACEICAmQBSlniAAAQCIcDueYFgzZhR6ZVV02JrPVRfq4ejcscdl1fKNuCp6Z8NxSNjzUt1IQABCEAAAnURyOXz+VxOe63LTI2ZOzs729ra5LXGfCSHAAQg4ERA7iozZszYs2ePB0xyJ/SQS2XxnDf8jBnxNnywnkvMSIvUU03Pf5hRZWxtbW1vb29paREHGhsbm5ubo/KEcuNGIPyv3HEjgD+pJCA3vY6ODnkNs3bqr4le2TCZUxYEIAABCEAAAhCAAAQgAAEI+EAAKesDRExAAAIQgAAEIAABCEDAmQBTb4gQCPhLACnrL0+sQQACBQLsnkcoQAACEIAABMwEeDISDxDwlwBS1l+eWIMABAoE2D2PUIAABCAAAQhAAAIQCI4AUjY4tliGAAQgAAEIQAACEIAABCAAgUAIIGUDwYpRCEAAAhCAAAQgAAEImAkwwJh4gIC/BJCy/vLEGgQgAAEIQAACEIAABCwIMPWGsICAvwTYV9ZfnliDAAQKBCLZPc/ffWV7enp6e3vdtKjnPUXDzyjVCb9QzyXW461lw02ZMkX2+XRoU8+uGhm7u7tdho3hRv2FuolScxrPJdbTIvUUWmsF/UpfNWAsC2JfWb/4p89OaE9GDzei9NGmRpUEvN3TqpKMcF9ZpGzV1iEBBCDghUBoD2yzc35JWRGxf33Vx3bu7ZncONJL5W3z5Hy1ZmnMvgh/CvfHiiOHAIvoHhicOW3qg0+92tTUZI0v57F0CXj57vjpeWcTNlZgPVJ1/fcSlH0VMGu2/8QuYJCyrtuIhBqBEJ6MciNavnz5rl27Jk2aVAY9iT8nuYybFFfNJQGXySQ8Zs6cuWbNmpruaVWNI2WrIiIBBCCQMAIyIyj8SUF+SdnlF505deKo1UvOHDVSZmGYviWX6Bzzde0riqmFiu+1//p13cpUwXZFEZbXh1OVpvd+vdQlWzhWBPTvdBbEyq/7HPa9h4ZuW/v6/v7BDbt+6buUXXT+1OSHjbtYKml5v8LJzo6LMPP6A0TV8DICZtMr+6omNhLQK+ueVdZShiBlL7300lNOOeXee+8dNWqUeynrLAUdPg3zI/VbQK237kRULTQpLoOGbrvttv3792/atMnHv74IpSxzZX1sR0xBAALDBMLXsX7R7+/vf+kXB++/5gxdx3KkisCEsQ2r//y8HT/uko53fytG2PjLMybWgguYmFQQN1JGQG5Eu3fvlhm5lTo2ZTWlOt4ITJgwYfXq1Tt27PD9IejNn/pz8UWtfoZYgAAEUkXgwIEDTeNGThjj79DiVCFKdGVGN5w0uXH0wYMH/a2F/MhN2PiLNCbWAgqYmNQON1JGQG5EEydOFLmSsnpRHR8JjB49evLkyb4/BH30sCZTSNmacJEYAhCAAATSQECe4r0He4eGhtJQGeoQPAH5hUs6MQiY4EmnvISVK1emvIZULyEEUnNPQ8omJOJwEwJJI5DcAcZJI51pf7v7Bzvf67c7+w/bKtXDhw7LlKHf/e53x44dyzTBjFXeIWAcokUgDQwMiJTt6upCzWYsZHyuLk9Gn4FiziuB1NzTkLJeQ4B8EICAIwF2zyNAAiUgmmThvd/74IqtbV9+we487VOb59+zS1LaeZI/ke/v6w/UT4zHhEDVgKkaLVKREydO9PX1xaRGuAEBCECgTgIpuKchZeuMAbJDAAIQgEAEBJavfuUPJr5//5pFnQ8usDvffuiqqZPGfPKb/+Xg34n8iQi8p8jQCVQNGDfRotRs6L5TIAQgAIGgCCT9noaUDSoysAsBCEAAAr4TkFGgMpx471s9L+1597OX/o+unsMO40LV8rM73+jqGTjquycYTAQB9wFDtCSiQZPuJAOMk96C+B83AkjZuLUI/kAAAhCAgDWBB5782en6iOJ5//DSmFEjL7t7l7yXK3LdDllh+dlDSNksBlWtAUO0ZDFKwq0zU2/C5U1p6SeAlE1/G1NDCEAgoQRyy7crz3PLtDe5ZdtM5/O5Zc871Cu39FnLT3NLni7YXPKUXfbc4q2FNNdviQ866V67e9PeV++dK8OJ9z208L3i0GK5Ited1+yJTy0C8iS3fEehyfQ3EjnauUydWtjYtvUNz/noUm5xIWByMYgcAsbHlsUUBCAAgXgSQMrGs13wCgIQyDoBESf5dZcoWZJfr72RI79+bvGcl18/L3eDk5r1TDC/cYHSJPnHFsZBk6iK7O8fnDCm4SOnji+rl1yR6/Kp5/omPWNu+c78ujl6qEjMaG+0tlt3iYSNfmox46Bm3Vc/Z//zR6HQjYWA0SNns3vLQaQkYIKgik0IQAACsSKAlI1Vc+AMBNJDgN3z6mlLQ5NoOlYXtL4f+Q3zHWzm46RJfK97mgzmbhQdO7tMx7qvYP7RS90ndpPS+Pkj/9hVkatZNw6TBgIQgAAEkksAKZvctsNzCMSaAItbeG6eWnVsrnSMaO6GwtDi3NJn1GnpidHDllv8ZPHcak4ZN00ypXF07+GhX3WVb4Xyy3d6+44MyaeegSc3o6Zj19agY9WgdOnMN/rzVfAYMaO91wNGj5yntbN0RLqETW7Jk4qYETbGiHR1PSaRQ8AkN7DxPH0EGksPcwXHlR5jx46tWv0x+lE1mZsEo/TDTUrSxJMAUjae7YJXEIBARgmYdGxhgLEZRNlc2fyj8xww5dsvV6edmtXUyJIn8xuvLJ4yrnir2WBMNIlyqXFMw51Xn3P+HdtaV2z94C1bTr7pCXkj5/l3bL/z6mnyadYixqRjCwOMS0KldK6sjDFWn4qalbBxjhxNjmqRc4V2brhCqVnVjS+v+Q1XanYWG5GzQB+RXhk52gDjCPtmCZis/UVQ39gSEBkrvvUXD3kv6lV5q94MmA75pxs1G9vK4ljIBJCyIQOnOAhAAAJOBGSuo1rCR39TWPbJyFA2V9Z3lKJJzDZloqyoWU23XL9ZNInvxdVq8LYrz973rQUdX5m18XMXjho5Qt7I+daDCz4//6xaTaUgvfTHiprVQ2W2sezTcKiUzpU1hZDTzx8lrV/aK1tJzK5XVg8YiRwtYKKNHAImBXGesipkcOqNoWONphRJa4jYlLUv1QmfAFI2fOaUCIFMEGCAsedmNqnZSyrVrGeztWaMm45V/ktXW+vJjS1Txo48aYS8kTOD/bHDunRYzRZ+Aam1lVX6/KOXqTHG0oEv/bHFN4VeWTubRme+/AJi/hEkVpFDwHgLCXIFRIAnYxlY6Y5Vstbopz2kH5b8pbfWcmixXHy/6VB5jQuj9aPWBpVRxw2mQ2VXF9T7kfphfq+unHTSSeqivDEftTpAepcEkLIuQZEMAhCojUA9u+d97GMfmzNnzurVq3/729/WVmpaUntWs+ZJjx5gDG/Ds9jojy10r3mwFkQW2WGl873+t/cfOnb8hLyRM+Pb8Gh9s8tV32xdarbOxjJv4BSrnnwCps6WJTsEgiagBhdLKWZBW1moGnV8WD/Mn6pJs0eKh7wXEWskkMuDg9r69rWq2aNHjw4VD8luKNhKx5SgPVY8lIg1JzuuH0FjzKx9pGxmm56KQyC+BHbt2rVixYof/vCH559//rRp0770pS99//vfz9qTwBhgLCsYq31l7Q5ZhFYW71GndK8ZyYxln1Q/m+Uh8x7Nyz6pvjWRJbKCsfamOMA4JrHywJM/O33F1rYvv7D4n14+euyEvJFTrsj1mHgYiRvGAON61KzWMbv0WSNU9CnWJcs+SdVkoqyx7JN0yZoHGBcjJ16/gBAwkQQkhULAAwFD0HqbKGv0wXoo2i6L0SlrJBBtK+/luiFfjY9Ul6zRT2tcz9pXFx/5uzSVy+fzuZz26jKDL8k6Ozvb2trk1RdrGIEABGJIwJcbizwD/s//+T9P68e777576aWXXnHFFdJhO2HCBMsqy11lxowZe/bs8QBEHFa59u3bd/nM6Z33TS8aKVzX/llMo39kvl76T+MjLYkpWV3XrUwVbFcUYXl9OFVpeu/XyyBY1dQJmpv0wy0p3WuiWl+9d27Z1rKypvH0L26TGbN2I41laSiZUitDkQ1bcmX9E8994AMfkCtjx42dPHmy8ZERBrWGkITNxZ+YlvywcRdLJS3vVzjZ2XERZiV/mIWm8xYwldEi5uRi+5ZtLS0t8l4m/jU3NzuHR2tra3t7u/v0tQYb6ZNLQAYYuxljfN55551++ulLliy5/PLLa1qq1/kh6HB/c771ecuoclXOlTUuinw1ln0y2lRdqRxjbPTKyqeKieqeNXply6JC9c1Kr6y4obpkVfds2aE+kj7YsutqWWNDu5a9V4mlI1Zey2StwUr1zZqlrDeMQUS77/coMdjR0SGvQXhrZ1N9z6RXNkzmlAUBCNRGQJ4EF1xwwVe/+lVRp6+++qo83R9++GFRIBkfflwbxLSk3t8/OGFMQ5mOlcrJFbkun6alotTDHwIEjD8cseIrAZdTb1544YX58+c/9NBDp5122vLly7dt26Y0VRIPtciTErTqUO/VoGLfD9U967tZw6DREErHVh5qfmxwDmC5jABSlpCAAASSQeCMM8747Gc/u3379nfeeYfhx8loM7yEAAQgAIHaCUyaNOnmm2/euXPnz3/+c/kNVzpy5Tfcz3zmMy+//PKJEydqtxdxDkPNqs1lzTrWPEvWmCtrueyTuli57JPqmzUPMJaeWKPCct2hS9ZIpnaXNQ65rvppzes82UE0+maNAcYMKg4z4JCyYdKmLAhAwAcC48ePv/rqq9esWdPV1SWdtDLCRJTt1KlTb7zxxueeey6Jj3kfoGACAhCAAARSR0AebbfeeusPfvCDV155RXpob7nllg996EN33HHHG2+8EfLcwDrRGpvKqjdma+ZNZeW93fLFkkU+Uss+lS3+JP80ln0y61jJopZ9shxarHwQyVp5qI+MZZ/UG3VRrf9U1iVrrPkkbwwdy2pPdcaMy+xIWZegSAYBCNRG4E/+5E9EZJYd5jlC8r7OBP/wD//wx3/8x/fcc89Pf/rT3//+9+vWrfuLv/gL6bOtzdEAUudufqlw3vRS7qbvqtNNObIUbeUGoW4y+pVGFnwqnlscbOau26ROpzTXPp679nG/HBM7UxpH9x4ekpmxZTZ/+U5v35Eh+dTHssI3lbt5V2XYuHFDtpZVKxhHdZhiZms9MSPRYpy+1CXdAeMLIowkiMCHP/zhO++8Ux52snKEuC3Dj2VNxLvvvvvNN9+MeS1UT2zZoTpgLQ+ZE+twqF7ZysO8GY95jLHqlXU4yvpjzf80b8ZTtgSUschT5ZuyPXjYjyfo+GTZp6AJYx8CEAiQgPxQ+uKLL27YsEGe7tOnT5c5tP/8z/+8d+9eD0X6uOyTyBJxIP8fM/VlnvT/61I2v+bigmNWy0GJJtHSrJtjcr64EE4tyzup/Xjy7bKUcW3r8ciCtFrG4iLG2vvHtHWMK+0YIjb/7UXD3haX3sld+x3jYv7xa+3Xyqpt2SexKQvSfnXz3vHvb5DuiMNHj48drW2BIPr2y4umfX7+WXaNnohln4ZjphgyxZj502H+FWFTjJnZ9quLVTTf8AXTel83PGcdM1aJC2Xpue1jprzc3PWFHz5KYkZCVNnRY0aLFu299gtI/jvXWfwhaB9brqNmvjicz0PAsOyT3d8R130h4MuCiOKJjD+SftqNGzc+/vjjZ5555uLFi6+77jrpwo3hsk+W3DwvgGSX0XeD+s3G+sYS8ke+BF6ZEZZ9CoIqNiEAAQi4JSBP8d27d8vEIZk+JKtoyFQimVC0Y8eOa665ZsQIBpu4xWhOZ9YkzvmdO2N1QXKN0iS+H7ddefa+by2Q5Yg3fu7CUSNHyBs5Ze1iBx3ruw8YNAjUEDNFHWv9pdakY/3FS8D4yxNr8SEgT7oLL7zwG9/4hgxEkofg66+/ftZZZ82ePVuULbNs4tNMeBICAb7zhQCZIiAAAX8ISF+cTBD64he/KJOFZH6s6Fg1g0imEsmv0f6UEbyV3E0v5m6U8wV1qgJV95r2ZvkO401u+fbCWdxXNrdsW/F8Prfs+UpnVZesZmfps7KvbPH9M9oeoUsKZ/BVDLAE2XFHttU5u2WidMZOnTRG3tvtwaOcODhwtHtgMPHDjyVmTGFTETPDwSPxY4RNIdlwzEjwWMaM1iVrHTPFsAmwRQM2XVPApCNaAiaK+boIrFy50shf/ywbsSADX+fOnSvza3p6emTd4y984QtxmGVTFyMyQ6AWAkjZWmiRFgIQcE3AzdZ5ro2979e//vVXvvIVmRp05ZVXyq/RMpxYpgz9zd/8jQyscm8k5JTa1MfiXFkpOr9GRorKSOMXtfdrL86vnSWndkVXs/m1MkZUO9QAYyVo8+suUad2pahmC8nWz8uvn1dZo/yjMq5Yt9N+Wb79ci2jLmjz7VfkN2indmXJUxYZN16phhZrCRZv1bIURheXpFXDRPPfvjpkmGXFNTWOnnXu1Fv//bXeQ04bVAwOHb993Y8uOucUZ7kbbV3MpZunWGuczTGzRmJGCxutgcpjRgueYszMsY+ZuTYxc6ltzOhh4xgzV5bEzEY1Ir0sZjY7x4zejX9NwY4aXfy4eXSxD+3jJmASFy0+cMFE6ATKFoyQ32fLjloTyJJFzz///LJly2TRY+mVvf/++2V1qNCrRYEQiIwAUjYy9BQMgXQTcLl7njMEWaP461//+sc//nHZXfbdd9+V9YpliQtZ5+ncc8913s89Dmxlrmx+zcyCSNA1iXEYvbLOfpZ1rxmJ8+vnBlfBgo71pEmC86rS8iOf+URX9+GWWzbL5Ea7s/mmJ37fN7j2sxeE6Vg9ZWkxI1Os9UPp2OGYKfbKVouZQq9sWbJQYmZBpW+563Ud+5ir3z4Ks2SDGZ1eNWASFy31RBp5k06AWTZJb0H894sAUtYvktiBAAR8IyADpR555JFZs2adffbZMgXo7//+72XElEwKkvWKEzcVttixVrKCsdEra/TNWrIzemXz6y+R0ze+9oaKOtZCkwxrKtPaxbnrngjBK8sipJ/tqS9d9P8evkrNmLU89z24YPMX2iRlVE56K1f9AlK26rWsGWYOGzvL0qtvDhtvDtSUy1XMXD+83rVdzASqY6VGVQMmodFSU2OROOkE0jHLJumtgP+xIoCUjVVz4AwEIKAREBH7zDPPfPrTnxYFu3bt2ksuuUTWu08lGvN0WYcKyujisgHGQdCoqknyj10l3WsyutgYYFy6Gm0QTlWxOV6fOmt3Jk7EuiHoNmZkonXpoHQ3xmtNU3XlJz1mCmGjjFvGjHkF41p9qCm9Q8CkMlpqgkPiOBNI4iybOPPEt9QQQMqmpimpCATSQ+C1117bvHnzokWLZO+4FNTK3DGr9uMxDzBWsx/LjuKM2cKyT5oAcN0rq6bLGss+FWfMDq/5lN8wv7JEpUm0jIWtZbfkri9sLStjRNUwUYdDutrMe/CkoNWirYJFzJgGGDvGzPAAYx9iRl/2SQs/VzEjmxIbMSPx4yJmrtP24DEix7S17Lej5U/pEIgJgUTPsokJQ9xINwH2lU13+1I7CERGwK/d82qqgPOWelXEWHEHuX379l0+c3rnfdOL6U07y1nuaal9GS/8vzyLn9etiqhlv1nTLrO17Tdrvz9tqUu2cNzsH2sHuab2d5tY5tauf+I5WQFbMowdN3by5MlGTs9zsCVsLv7EtOSHTUVjVYmxirA07VZrao/C/rH6lVrDz0WY2W//6DYmHNNJwLRv2dbS0iKpGhsbm5ubnc36vmejL7XASIIIyCwb+T1Xtkz/4Q9/OH/+/CVLllx88cVuRiexr2xlKzvf1WOyeaznR4+3qPb9HiUGOzo65NWbP95yqe+Z9Mp6o0cuCEAAAhCAAAQgAAEI+E8gO7Ns/GeHxYwRQMpmrMGpLgTCImDePS+sMikHAhCAAAQgkHgCKZtlk/j2oAIxJoCUjXHj4BoEkkzA331lk0wC3yEAAQhAAAIQgAAE/CeAlPWfKRYhAAEIQAACEIAABCAAAQhAIFACSNlA8WIcAhCAAAQgAAEIQAACEIAABPwngJT1nykWIQABIcAAY8IAAhCAAAQgAAEIQCA4AkjZ4NhiGQKZJrBq1apM15/KQwACEIAABCAAAQgESQApGyRdbEMAAhCAAAQgAAEIQAACEIBAAASQsgFAxSQEIAABCEAAAhCAAAQgAAEIBEkAKRskXWxDAAIQgAAEIAABCEAAAhCAQAAEkLIBQMUkBCAAAQhAAAIQgAAEIAABCARJACkbJF1sQwACEIAABCAAAQhAAAIQgEAABJCyAUDFJAQg8L73rVy5EgwQgAAEIAABCEAAAhAIiABSNiCwmIVA1gmwr2zWI4D6QwACEIAABCAAgSAJIGWDpIttCEAAAhCAAAQgAAEIQAACEAiAAFI2AKiYhAAEIAABCEAAAhCAAAQgAIEgCSBlg6SLbQhkmAADjDPc+FQdAhCAAAQgAAEIBE4AKRs4YgqAQDYJrFq1KpsVp9YQgAAEIAABCEAAAiEQQMqGAJkiIAABCEAAAhCAAAQgAAEIQMBPAkhZP2liCwIQgAAEIAABCEAAAhCAAARCIICUDQEyRUAAAhCAAAQgAAEIQAACEICAnwRy+Xw+l9Ne/bRazVZnZ2dbW5u8VkvI5xCAQFIJhH9jEVJyV5kxY8aePXs8UBOHVa59+/ZdPnN6533Ti0YK17V/FtPoH5mvl/7T+EhLYkpW13UrUwXbFUVYXh9OVZre+/UyCFY1dYLmJr2HlqyepXXF1vVPPPeBD3xAko4dN3by5MlGHiMMqlspTSFhc/EnpiU/bNzFUknL+xVOdnZchFnJH2atTVc9vQRM+5ZtLS0tkrSxsbG5udk5T2tra3t7u/v01T0gBQTcEXB+CFbe33p6enp7e/X7tPkPsLwwh0/D/Kiqn5aQElE1z48ec5WnTJkiNyg3keL7PUoMdnR0yKub0v1Ko75nImX94okdCECghABSVsOBlEXKOhEoFWl1/dJh94uJVRFOv4AgZS3u5EhZHm9JIeBeyoqI/eurPrZzb8/kxpG+1s5JEvtUkH0R/hTujxX7ygZlv3tgcOa0qWu2/6SpqSnkn9uQsj7FNmYgAIHYEJDNeMLfj4de2UInML2yjn8I9MrqeCxVK1IWKRubpwiO1E7AvZRdftGZUyeOWr3kzFEjZbJhQgcfcb8qCZHeQ0O3rX19f//gplf2ZUfKMle29vsEOSAAARcEwtexLpwiCQQgAIEwCDzyyCMf0o/77rvPKE/uijJcpeww3ypJoFhFxeGiiy4KIzhiUEZ/f/9Lvzh4/zVn6DqWIyUEJoxtWP3n5+34cZd0uaekSi6qwQBjF5BIAgEIJIQAvbL0yroJVXpldUr0yroJFi0NA4zdkkp4ukgGE/nLzGWvbFqWhKBX1iJ85H7V8dpe52mraZory48x/t5DsAYBCEAAAhCAAAQgkDwCDCZKXpvhsRWBAwcOSMfs0NBQFvAgZbPQytQRAhEQ4DtBBNApEgIQgAAEIACBbBMYGBgQKdvV1ZUFNYuUzXawU3sIBEZg1apVgdnGMAQgAAEIQAACEEgzge7+wc73+u3O/sNVOl1PnDjR19eXZkB63ZCyqW9iKggBCEAAAhCAAAQgUIUAg4kIkZgQEBG78N7vfXDF1rYvv2B3nvapzfPv2SUpHXwWNRuTGgXnBlI2OLZYhgAEIAABCEAAAhBIBgEGEyWjndLrpXS0qj7YRQ/855hRJ71+/7y9X7us88EFlufbD101ddKYT37zv9LLw1XNkLKuMJEIAhCAAAQgAAEIQAACEIBAEAQeePJnpxe6YXe+8duel3/x3qxV35Urct2yOLX1zs43unoGjgbhT1JsImWT0lL4CQEIhERgwoQJB/qPDQ6lf1hOSEBjVszBgaPdA4OTJk3y1y/Cxl+e8bGmAqapqSk+LuEJBNJBILd8h6pIbvl27XXZ9tyybabzeYdq5pY+a/lpbsnTBZtLnrLLnlu8tZDm+i0xISn9sXdv2vvqvXP1DtiFv1+zSF7lvVyR63bTYkc3nDS5cfTBQ0jZmDQjbkAAAhCIAQERObPPmXTrxjd7Dx+LgTu44CeBwaHjt6/70cxpU8eNG+en3fe9T6QOYeMv0jhYCy5g4lA7fIBAhAREx+bXzVE6Nr/uEuVJfv1c0zkvt8xJzXp2Pr9xgVKz+ccW5uKhZvf3D04Y0/CRU8eXVUquyHX51HNlU58xl8/nczntNcyqyg7ObW1t8hpmoZQFAQiESSCSveadd4d3rr7cCY0Esor9rQs++tIvDjaNG+krNPN+7r4aHjZmX4Q/hftjxbHyARZxoH9wzh+deuc3tk6cOFH5MHbc2MmTJxv+mMOgphaSjN3d3Z+65CzCxopbgG2qFxeUfRUwd33raSNgGhsbm5ubnWOjtbW1vb29paVFkrlJX1OkkTg4AuF/H/a9Ls4PQeP+tm/fvstnTu+8b3rRAdNfkOlRWPKXpSUx/6EV33u6btKxImh1HZvTemVFx5qY5ETK5h+dV/E3rhd5w7P59svNiQtGljyd3zC/8nplTUXNipTVTF2/Jf/YVSVZhitaWuXq10spWcIsuVgoVubHyvJO0g1bGRKtK7Z2fGVW68mNltFS+alcad+yzfn+4/s9Sgx2dHTIq+8h7WBQ/cEiZcNkTlkQgECwBPySssrL/v5+2We8r7fvyJEjVfz2+kVant0eiXjNp74whFyo9xLLvju59tuuxPHjx8tIYLMZH6WsETb79++XX0MOHzrs1l/vDeI9p1vfsp1OoqUsYNxIU9+/Jma7EcKrPVJWYx28lM0t31nsjy3qWPVkspGyuRtE0F5qxEHuhufyj14mUta4omta/WYoRopSNrfkKV3T5nJLnhxOuXGBKZ5yucUiYivVrPkBgpR19QeIlHWFiUQQgAAEnAn4K2VVWb29vYcGDlUh711QeM/pORi8C0vvznrN6beUrYSmKZWJw+K2nl5Zs3Hpoe3v63fbRl7xhN+U6rui23qVpfOaz2NxwWSTCQhVJ1ojZYNhH7jVSAYT+Vur+PfK5m4061gZYDzcuytStoxGfv087Y5jI2WNXtnc0mfy7VdYSlld0F45XMjiJ2V0cbEU7Wamd8mKms3lrt9c7JuNQMrKbFhZ4UlmxpaNMf7lO70f/9L2fd9a0DimwTJU6JVl2Sd/7yFYgwAE0kZg7NixuRGp+A6etpbxoT7SsmPGjvHBUIUJ6f4lbIIAG63NESNG+D7LOtoaUbqZAPvKhhAP+XWz1WpP0jFrLPtklFs2V9Z3f0w6Vle+BR0rbwwd63uZrgyKUr3z6nPOv2ObSNMP3rLl5JuekDdynn/H9juvnmanY12ZTnsiBhinvYWpHwQiIhDJz9tB9MoKv2PHjh05fOT48eO2LL1KXe99gJ57xrSnt8eYSJC3blwdkRvROL5x5MiS6dBuMlriq8w4NDR06NAhCZ6quL0X6r0tqzplH+xWE73cmPNcTTfGQ0gjOlZ+oWhosO4bMTtAr2wIzUERlgTi3yur37RyLufK6nLTz15Z8/MvVnNlVWtK36ys8PT2/kPXPrD7+/doa2JNaRztrGPplUXKcjOEAAQCIRDJpKOApGxVQJ6/o4efUf8S4VHLhp/Rs7fhu+q5RM91jCRjVIVW/RuMVQKkbKyaI1POJEXKaneSwgrGImv1FYyt5spWSlmZKCsX1VzZegYYazp240LzAGNTnEQwwNgcpQ5LQFUGM1KWAcaZusVRWQhAAAIQgAAEIAABCwIMMA4zLIwBxqJj1b6ydocsYiwKVp0l6z8tfUZmyeoTZc1LGZeYkYmysuxTbnHhVAOMdR2rvykOMA6z4g5lSa+s6FjplT12/IS8kdNuR9mYOBwHN+iVjUMr4AMEUkiAXlk3jeq5K89zRu3hTa+sfduEDycjLVJPNd38KcUqDb2ysWoO985E8thy756blAnqlS1Wx7ypj3afMFWzsCixfsXyek2JleFaVySuNX1pEa4345FsDzz5s7s37ZVdZGWDmcNHj48drU1+6T08JHNob7vybLvWp1eWXlk3dwbSQAACEIAABCAAAQhAAAIQ8J+A9L6KjpUVjGVr2X0PLXxvzSJ5I6dckev0zToQR8r6H45YhAAEIAABCEAAAhCAAAQg4IaArPYk/bFlO/FIRrki1+VTN0aymQYpm812p9YQSCcB2SK0p6dncJCbfjrbl1pBIP4EDh48KLsKNzU1xd9VPIQABCCQdAJI2aS3IP5DIKYEVq5cGb5n8vXxoosuuuOOO3p7e8MvnRIhAIGME5Df0W6//faZM2ey/WzGIyHd1c/dvCt380uF86aXcjd9V043Vc7duDO3fKeblAGlkQWfjLOyCNldVj835a4zzifsPMld+7icfvkpm+7ItNhfdfWVGfzlO719R4bkU78KSp8dln1KX5tSIwhkmoD0hyxdunT37t0TJ06sCYTn9X5qKoXE4RCgNcPhTCllBA4cODBnzpy77rrLuP80NjY2NzcDKhEEWPZJaybLlYq064X/a/+5eZe85v9jpp5ez6NL2fyaPx1eV8mUXm/9nOhYLc262RZrOJlsm0LFetmnwn487ZfVuEaULFz8pOZAcRFj7f1jC4vF6e5ev1m/eLVpcSiLZZ9y137HcDL/+LX61rfmADf9o8Zln766ee/495cv+/TlRdM+P/8su78gln1Cyibi7oqTEIBAbQT6+/v3798vXysHBgZqy0lqCEAAAl4JyBwHOcy5kbJeWUaQTzbjSfp+POGsYJxEKWvWsZpqXbzVs5QtKHO9S9ZHKSvWZHknmRYrm/Fc+8Du798zR65If2zjmAaHPwakLFI2gnslRUIAAuEQECnLSONwUFMKBCBgSWCSfgAHAuEQiIOUzd30ormy+bWzNOl44wvGRdlRVruyfEdJsvWXaBeXlWwwm18/r9jhWejqVF2yw6b0HWVla9mSixvmm/5Z6Np1L2WHjX/7aofNe9ToYn+lrCq6u3/wgyu2/n7NotENJzmHzcGBo6ev2PLOw1eZ5a6I2/Yt21paWiSv3U9pvm8YJgY7OjrkNZw4V6WoYRTMlQ2TOWVBIEME4vDb9vjx40eM4C6XoaijqhCIFQG5/zBpNlYtgjM+EjDPldVEnTa6+H1Kx+bXXJxfK+ewiM2vlXHF2qEPMC7oWNG0+XWXyKldKRexczUdW3HkH720YKf9srxJx+bbr9DODVdoppY8ZZFx45X5jVcWJJDqkt1ojC4uSS4DjPOaiH2fzJj1EZd7U02No2edO/XWf3+t99CQQ67BoeO3r/vRReec4txt677chKakVzahDYfbEIg7gZhMOhoaGpIxxseOHYs7L/yDAATSRUB0rPya1tDgNDgwXTWmNtETCL9XVgStJgt1HavJP6v1n3RNWzJXtqxLtqBO11+iBG1+/VxlzHgx946WzZVVXbKiY1Xi3JKntX8Od8yajWgpCkOLtRmz5jmuVnNidSmb//aiYruWpA+uV1aKk47ZG1e/smvvfzeNs13w6UD/4Oz/79R//4uPi/Q1R17WemWRstHfd/AAAqkkEBMpm0q2VAoCEIAABHwnwFxZXQ2WijqDsv2yT7mbhtVscf2ni83LRCldal72SUlZfaRxsTglOQOWsqXDjOMrZRX1vsNDolft4lz2my0TsSpl1qQsQ+98vxNiEAIQgAAEIAABCEAgYQRWrVqVMI9j765MkTXPkrXzN7d8e9kA4yBqVjZdtrIItRmPuq5GF5u6ZIPwqIrN8WMaWk9utDstdWwEXkZdJFI26hagfAhAAAIQgAAEIAABCCSTQHGWrNqP52JNB970Yu5GObWlntSM2bLDWPlJE7HL1aBibcasmyP/qGzDI0s9PVscWqxWfnpaO8tHFw/bUzpWSzm8teyWwpXrtxS34blKS6DvK6u5pM+YLaS57oncdcN78LjxkzThEGCAcTicKQUCmSPAAOPMNTkVhgAEIJBkAil4bIUzV1ZJwqLIM72v97qVqeLSxabIMqa/VoyFdkpc0KQldoYNWMyVLammqlr19KVVqGVfWb/+dBhg7BdJ7EAAAhCAAAQgAAEIQAACEIAABAIhwADjQLBiFAIQWLlyJRAgAAEIQAACEIAABCAQEAGkbEBgMQuBrBOIw76yWW8D6g8BCEAAAhCAAATSSwApm962pWYQgAAEIAABCEAAAu4IMJjIHSdSQSBGBJCyMWoMXIEABCAAAQhAAAIQiIQAg4kiwU6hEKiHAFK2HnrkhQAEbAnwnYDggAAEIAABCEAAAhAIjgCb8QTHFssQyDSBaHc16O7u7u3tzXQDUHkIQCB0AlOmTGlsbAy9WAqEQIEAm/HoIOw26an4qPrmOrVu0lNaBJvxBPmnqb5nImWDZIxtCGSYQFRSVkTs8uXLd+3aNWnSpJrwi8M1pSdxnAnQmnFunRT7JvefmTNnrlmzpqmpKcXVTGvVZDBR0scTIWWRslnbVxYpm9YbMvWCQMQEopKyl1566SmnnHLvvfeOGjWqJgT1iB/PecPPqP1i7FW0h5/Rs7fhu+q5RM91jCRjVIXW9LccYWIZDHLbbbft379/06ZNEbpB0d4IRPXY8uatZS6kLFI2a1KWubI+3kAwBQEIREygv79/9+7dq1atqlXHRuw3xUMAAqkgMGHChNWrV+/YsaOnpycVFaISEIAABGJNACkb6+bBOQhAoCYC0hkyceJE+TZZUy4SQwACEPCLwOjRoydPnnzw4EG/DGIHAhCAAATsCCBliQ0IQAACEIAABCDgJ4EDBw5Ix+zQ0JCfRrEFAQhAAAKlBJCyRAQEIBAIAfaaDwQrRiEAgSQQGBgYECnb1dWFmk1Cc+EjBCCQVAJI2aS2HH5DIOYEkr4OZMzx4h4EIBB/AidOnOjr64u/n3gIAQhAIKEEkLIJbTjchgAEIAABCEAg7gREzcbdRfwrEmAwEbEAgcQRQMomrslwGAIQgAAEIAABCEDAZwIMJvIZKOYgEDwBpGzwjCkBApkkwHeCTDY7lYYABCAAAQhAAAIhEUDKhgSaYiCQNQKyuWvWqkx9IQABCEAAAhCAAARCI4CUDQ01BUEAAhCAAAQgAAEIxJQAg4li2jC4BQF7AkhZogMCEIAABCAAAQhAIOsEGEyU9Qig/gkkgJRNYKPhMgQgAAEIQAACEIAABCAAgWwTQMpmu/2pPQQgAIG4EhirH2OKR5mbxnX1xvi07J9y/f36YVdL9alxRAWjQT+iKp1yIQABCEAAAkkkgJRNYqvhMwQgAIGUExARKzU8dOjQYf2Q92V6Va6ojyo/dY9GSdwjxUPejx492n32spSj9MNzdjJCAAIQgAAEIFATAaRsTbhIDAEIuCXAXvNuSZGugoChY41PzHpVaVp1RR3mT9V7oxvWEKuVmCs/Eklbp5qlMSEAAQhAAAIQCI0AUjY01BQEgWwRYCnIbLV31LU1umfrdGRQP5QR6aE1H5YXjV5coz/W6JtVb4xDZbe8WKfPZIcABCAAAQhkkwBSNpvtTq0hAAEIQMCJgNKoStkqcVs29rjs+tGjR5U5eWO8L7ui5K5KoNIwIJkohEB8CDCYKD5tgScQcEkAKesSFMkgAAEIQCC+BMyrPRljjB1GF9vVRHXDVq2n0XNbNWWZrK2angQQgEBUBBhMFBV5yoWAZwJIWc/oyAgBCDgR4DsB8QEBCEAAAhCAAAQgEBwBpGxwbLEMgUwTYK/5TDd/fZWXhYvFgFr8SR3mpZ4cFjSuqVi1yJN5nx713n2Pa03FkRgCEIAABCAAAX8JIGX95Yk1CEAAAhDwgYChZo2Rw5ZLFlt+KsUrmWp+Y+mToWaNvWcNHWvMjzWGHFeVuMb0V7sZsOYExrxZH2BhAgIQ8IMAg4n8oIgNCIRKACkbKm4KgwAEIAABlwREzRr7ypp1rMpubCprt3ax2iy2alnGprKV6Y01n8zLGpvfi/Gyf5qXdKpc/0nSGwnKPh3Sj6rekgACEAiOAIOJgmOLZQgERAApGxBYzEIAAhCAgEcCMrTYOFS/a62H6mX1cJRtwOP+n2W77NT0z4bSwyM1skEAAhCAAAQyRgApm7EGp7oQgAAEYk9A9ceW9cqWdcM6/7Osr9X9P8t6Yt3/s6y7taZ/qi5Z44h9++AgBCAAAQhAIBYEkLKxaAacgAAEIAABCEAAAhCAQAgEJkyYcKD/2ODQiRDKoogwCRwcONo9MNjU1BRmodGWhZSNlj+lQyC1BNhrPrVNS8UgAAEIQCDJBCZNmjT7nEm3bnyz9/CxJNcD30sIDA4dv33dj2ZOmzpu3LjsoMnl8/lcTnsNs86dnZ1tbW3yGmahlAUBCKSegNxVZsyYsWfPHg81lTuhkaunp6e3t9e9EXNe97kkZfgZIynUczXr8bayIaZMmdLY2OjcQJ5dNTJ2d3fXFDz11LF+b2sKV5U4kkI9+OlLFjcxU1lQa2tre3t7S0uLfCQh19zc7IszGAmaQPjfh32vkfNDsOwxd+uCj770i4NN40b66sbwk9RXs2Zj9kX4U7g/VuyrH5T9A/2Dc/7o1Lu+9fTEiRNV6Xb3H9/vUWKwo6NDXgNrdAvD6g8WKRsmc8qCAASCJVC/lBUR+9dXfWzn3p7JjSl6umv6wxfy/lhxdCXAImTYlfxc/eBTrzoMvqpHp4mI/fS8s9MWPP40iD9Wwv9qqGJmzfaf1DRgz/evib789WKkKgHZjCfp+/G4l7KKRn9//4EDB/p6+44MOq33nnN4hDjpSi+a06ks+2eZNw91e347GfTdzj6OZdy4HObPkbJV/+o9JqBX1iM4skEAAo4E6peyyy86c+rEUauXnDlqpJp/UXwoaf81P6DquW5lqmCvooharw/bLjU1/C+/rpfWwtSnXQKqrus+h3vvoaHb1r6+v39ww65f2pmuR8ouOn+qKXhMnG0h+BhUdsFZa7DVGoEV9iOJtBLCfoaNETObXtnn3i5S1j0rUvpLoFYpq0qXgSRqK2/bG2OIei/FUtabbK4nQmQkuRyVFny/R0XYK8tc2XoihLwQgIAtgST+ti2/T8toq/uvOaOoY2nfVBGYMLZh9Z+ft+PHXdL37nvFCB7fkcbBYKAxE4cK4gMEhIBsfjYihyJIWyyMGDEiC5NmGWCctsClPhCICYFIJh3V2Su7b9++y2dO77xvuolhPb2vfnWUiTuu+8qG0/rV+2pnp9Srunpf7TowA4nl1hVbd778ut2UHs+9shI8F39imil46JX1KwJdRFpgvbIqBCVmOl7b634amO89HoH8JWA0jQS89coKiePHj8sOZ/JqScXhxuitp9GjwbKHoflRbX8T8NbNqxXlzabDgGUHg37fxETHjh8/XvYst2xQ3+9REfbKImXTeCejThCIAQGkrP2A5FqkKQOM/Q5mkSVPPPfSGa1njBk7pvIxj5Qt/x2nSgRWBHO6BhgbUnbrjv/80Ic+JF0cdl8NzXHq+9dEv/8IsGdNID5zZc8777zTTz99yZIll19++ZgxY9w3mGcp63zrcxJ1nuSZN4MO8tJ3g1WkbLi1dh8ALlP6fo+KUMoynMBlo5MMAhCAAARSQuDwocMyN+x3v/vdsWNsRJGSNg26GgMDAzIuvaura2hoKOiysB8VgVWrVkVVdFm5L7zwwvz58x966KHTTjtt+fLl27ZtI/Bi0jS4ETcCSNm4tQj+QAACEICAKwLd/YOd7/Vbnv2Hq+uN/Il8f1+/q5JIlBYCdcbMiRMn+vr60gKDesSXgCzVc/PNN+/cufPnP/+59NBKd/EHPvCBz3zmMy+//LIEYXz9xjMIhE4AKRs6cgqEAAQgAIH6CIggWXjv9z64Ymvbl1+wPE/71Ob59+ySZM7lnMjzpbC+lkhObt9iBiGRnEZPgadTp0699dZbf/CDH7zyyivSQ3vLLbfIQPc77rjjjTfekB01U1BBqgCBOgkgZesESHYIQAACEAiJgPS1qj7YRQ/855hRJ71+/7y9X7us88EFlefbD101ddKYT37zv0LyjGLiSoCYiWvL4FdtBD784Q/feeedP/3pT59++mnJKcOPp02bdvfdd7/55pu1GSI1BNJFACmbrvakNhCIDYGVK1fGxhccSQOBB5782emFbtidb/y25+VfvDdr1XflilyvrJ7aQ2XnG109A0fTUHnq4IkAMeMJG5niS0AWNzr33HP/8R//8Te/+Y3MpJXJ25/Qj69//evvvvtufP3GMwgERgApGxhaDEMg2wSSuK9sfFost3yHcia3bLv+us10Pp9b9ryDq7mlz1p+mlui/ZavWVvylF323OKthTTXb4kPDfFE+tbu3rT31Xvn6h2wC3+/ZpG8ynu5ItctZ8aObjhpcuPog4cyIWWHA0aPnNzy7dq5TJ1a8Ni2+A3P+djQucWFsMnFIH6IGR9bFlNxIyBbrVx44YXf+MY33nnnHVmt6vXXXz/rrLNmz579+OOPM5k2bo2FP4ESQMoGihfjEIAABGomILIkv26OEiT59Zeo/Pn1c4vnvPz6ebkbnNRszUUWM+Q3LlBqNv/YwjioEaMi+/sHJ4xp+Mip48uqJlfkunzqucopyJhbvrMYMIXI0Vpw3SUSPPqpRY6DmnVPwOFHkEKUbiyEjR4/m91bDiIlMRME1XTb/JM/+ROjgvJrrHSBlh3mn2hjkkB2h5o7d+66detkhW1Z9/gLX/iCiNt0NxO1g4CZAFKWeIAABCAQIwIlOnZdQcf6619+w3wHg7qa1frW4qZm/YWQGmu5G0XHzpbqGJFTU9Xyj15aU/qqiY2wyT92VeRqtqq3JICAmcD3vvc9s5SVdZXKjjIpG3mCv/3bv5U1jWUVqHPOOefkk0++8cYb//Vf/1VWh6JZIZAdAkjZ7LQ1NYVAqAQYYOwBt0nHSvdadR2bKx0dmruhMLRYxhjnlj4jp6UPRt9absmTucWF05wyH6e+NQ8Ys5NF07Fra9Cxami6dOkbvfoqhIzI0d7rYaPHz9PaWTouXYJHwkYRLgbPVmNcurqOms1OBFLTSAjItthPPPGECFdZ33jFihXSdfzwww/LvNk1a9bMmzdPxh5H4hWFQiASAoR7JNgpFALpJxCfveaTwtpymKjhfNlc2fyj8xzqlW+/LN9+uZx2albTIUueym+4Mr+xcMZcjUxpHN17eOhXXeVbev7ynd6+I0PyaVJa2Uc/TTq2MMDYbLxsrqyMMS7oz2XPS/A4x48mR7X4uUI7N1yh1KzqzJdXCRulY4vBs8AYl244YAwwjrBvlpjxMdgwFQcCstTTv/zLv8yZM0f2mBXtOn369FdffXXPnj1f/epXL7jggpNOOikOTuIDBEImgJQNGTjFQQACELAmIMNE1eI9Mu/RWMVnWBuUzpX1HaKokRIhdP0WUSOaYrl+s6gR34ur1WDjmIY7rz7n/Du2ta7Y+sFbtpx80xPyRs7z79h+59XT5NNaDaYgvfTHiprVA6YQOeZKlc2VNQWS048gJTFQ2itbScyuV1YPG4kfLWwijB9iJgVBThWOHz/+/e9//0tf+pJsvfPxj39clneSbliZDbt9+/a//Mu/POOMM0AEgYwTQMpmPACoPgQgECMChojV32hrF0dyyFzZoo4tCJJI3Cgr9LYrz973rQUdX5m18XMXjho5Qt7I+daDCz4//6w4uBeJDyY1a/Hzh3uX8o9epsYYSze+9McW3xR6Ze3smHtlzT+F6Do2Fr+DEDPuY4CUsSLgMIT46quvHj++fAG8WDmPMxAIkwBSNkzalAUBCECgCgGTmr2kJjVrnu7ogfLwNjyLt8pcWU3MFAWJB2sBZZF+ttaTG1umjB150gh5I2c2+2PNeDU1u1z1zdalZutsMvM2TjHRsapGxEydLUv2SAjMnDmTIcSRkKfQxBFAyiauyXAYAhBIOYESNavvK2t3yPKzsmyPOqVjzUhmLPuketgsD5n0aF72SfWqiSApvImfjhX3ZKfQzvf6395/6NjxE/JGTssdZVMeHxXVcx6a7pKG1jG79FkjYPSJ1iXLPmlqWYuZwrJP0iVrHmBcjJ/Y9ecTMy4DgGRCYOXKlTHh8MMf/pAhxDFpC9yIOYGcrCQuS5/Ja5iOdnZ2trW1yWuYhVIWBCAQJoHwbyxSO7mrzJgxQ5bB8FBTcXjfvn2Xz5zeed90U/Zc4b323+J77VI9161MFexVFFHr9WHbpaaG/+XX9dJa5KzgaEnquV7SjA88+bO7N+2VXWTlgXX46PGxo0fKx7IWlMyhlXGkli0uk2llELJ03po/lYvrn3hO1k2Ri2PHjZ08ebL5UwkDD8EjWSR4Lv7ENFPwmOzYQvAxqOyCs9ZgqzUCK+xHEmk2reZjzLRv2dbS0iK1bWxsbG5udg6S1tbW9vZ29+m9hRy5IFBJwPkh6HB/c771ecvoey79kWJ9i/ZWloPB+HwURJz7fo8Sgx0dHfIahLd2NtX3THplw2ROWRDIEIH4/LydIejprar0rYmOffXeuZ0PLtj30ML31iySN3LKFblO32x6W957zYgZ7+zICQEIQCAhBJCyCWko3IRA0gjUs6/seeedt3Dhwu985zuHDx9OWr3xNxAC+/sHpT/2I6eWL3YiV+S6fBpIqRhNMgFiJsmth+8QgAAEXBFAyrrCRCIIQCBMAi+88ML8+fMfeuih0047bfny5du2bRsaGgrTAcqCAAQgAIGsEajnF9issaK+EIgJAaRsTBoCNyAAgWECkyZNuvnmm3fu3Pnzn/9cemjl64XMbPzMZz7z8ssvnzhxIs6kcje/VDhveil303fV6cZhWYRWrUMb1SELPhmngw+56zap0ynNtY/nrn3c34pMaRwt02J/1dVXZvaX7/T2HRmST/0tLnxruZt3VQaPGzdka9l0RI7EjHG6qXjVNKmPmaoESFArgVWrVtWahfQQgEC0BJCy0fKndAikloAvP29PnTr11ltv/cEPfvDKK69ID+0tt9zyoQ996I477njjjTdCXqyupnbK/8fM/Bo5/1ROyVhVzYoakWSyDm1NpVQmlv14vG3JI0vRag5sXGCsQ+vNk9y135HTW17nXLKliizvdP4d22TRpg/esuXkm56QN3Kef8f2O6+elpotebTIKQZP1iJHi8DHr5VTq/i1364/ijISM/WDwgIEIACB5BJAyia37fAcArEm4O/P2x/+8IfvvPPOn/70p08//bRUW4YfT5s27e67737zzTdjTSEJzhk6tqqzueudOmN1KXKNnFXteEsgyxTv+9YCWZF44+cuHDVyhLyR860HF3x+/lneDJKrTgJ+RY76+UOJWH8PYsZfnliDAAQgEDcCSNm4tQj+QAACtgRk4fVzzz33H//xH3/zm9/ITNqurq5P6MfXv/71d999N/7gcje9mLtRnS/IqRxWXbLam+IA49zyHfq5XTuL+8rmlm0rns/nlj1fWVmjP1bfVPbZgs2lz+S08+ncEu2MPyJnD6WfTXbWObtlogw2njppjLx36I89OHC0e2AwBWOPtdiQyCkEj+vIWV7YkdgUORJClpHzXDFaJHKeMUVOYV/ZREdOZmMm6X/s+A8BCEDADQGkrBtKpIEABOJFYMSIERdeeOE3vvGNd955R7p/X3/99bPOOmv27NmPP/54HCbTapMei3NlBVxxmPGL2vu1F+vnLF3Eamo2v7YwrlgNMBYRq11cNye/7hI5tStFNavaIL9+npyV7ZF/9LJCgvbL8u3aeyVL8u2X59uvyG+4QrtipWbzG6+UsyBgFm/VsmxcWGk/d/1m7aNvXx15KDQ1jp517tRb//213kO2i4ENDh2/fd2PLjrnlGSNPTZPtC6PnDX1R85cm8i51BQ5l5si5wpT5DxlEXI+RY65M1/Nss4/fp2/YZbimPEXFNYgAAEIJIsAUjZZ7YW3EEgSAelELTvME2jlff0JGhoa5s6du27dup6eHln3+Atf+IKI28gZqemOBXmgT5c1DqNX1tlJo1e2LFl+/dzgaifLPuk6doGtjn0seh2rfHvkM5/o6j7ccstmNWO28my+6Ynf9w2u/ewFweEKwrKaK2sdOcVe2RRHTlHH+j/SOMUxE0QcYhMCEIBAUgjkZOkU+TYZ8gIqnZ2dbW1t8poUTPgJAQjUSiCcG4ts0vPiiy9u2LBB5tBOnz59zpw5//zP/7x3795avZX04vC+ffsunzm9877pZu1ZeJ/TklS9LuvQampQ1IieXi34pPfKyvtCr6xupMSUadmnnNErW0hTSJiTYaKaKU3K6peK180uqTHGqktWK7HYK6ullv/pXbL5DfNLalF0pHTeo5a+eOg10btky478txcNX8mZMpinPpqul9Ta1fUqzdh3eOiAzY6ystmsdMRZ5hfdu/6J52RNbPl07LixkydPNieTMKhSqs3HEjwXf2KaKXhMdmwra2pII3L0a9KrX4ycwrJh+TUXq6AqafHhBcMqIqeYVvXqF38EsQ6e3A3aGGM9cvQyCpGj9eRbRY7ZyPvqi5zhSCudMWuOwNJaW8J03WqeY6Z9y7aWlhZxpbGxsbm52TlIWltb29vb3af3FnLk8p2A/MDqy4KFvjvm3qB8tZ4xY8aePXssszjc35xvfd4y+p5LuxfY/LF7K8vBYHw+ct/67lP6fo8Sgx0dHfLq3of6U6rvmfTK1k8SCxCAQNgEZBTx7t27ZXseESQywFg27JFte3bs2HHNNdfI2OOwvfFUnnm6rIMB0SFlA4w9lVYlU9X1e/KPXaWfVxsDjOMw0ni8PnXW8rTTsUHQC9mm28gxTbQOzkNPkWP6BaToWXArP5XVPZsxE1wApMxy0nVsypqD6kDADYFkfOdzUxPSQAACsSKwcuVK3/2Rn99kG54vfvGLsiXPihUrRMeqfXpkwx7Ztsf34uo3aN6MR+tV0+bHFpZ9kvdqxmzZIbNktWTFZZ+0ZOu1GbNuDjVd1lj2SWbJ6v8sLPukmdJnzJYdSo1oKYe3lt1SuHL9Fsv+WLOF3HVPyOnGPdK4J2AROaYBxkFGTmF+tR45hWWf9Mgxd+YX6uFH5GhrFxsbOJm2lvVhMx73tEkJAQhAAAIJJcAA44Q2HG5DIFsEfv3rX2/Uj4GBgcX68Yd/+IeVA4qcx1Y5I/NlgPHw+E+nAcnat3eTM7YDhnV9WRCVbtPbZSkdMFy0Vj6QuJbrpbVwNWDYzZhbj+N73f89xHOAse6/MdrbKkIK16qPci+1U2uw1RqZFfYjiTTXA4zdx4k5pcQMA4y9oSNXyAQYYFwJPBFjpz3PbfEWYAww9saNXBCAAARqIyDb7chGOx//+McvuOAC2W7n4Ycflo1k77nnHtmSJ+T7fm1+kxoCEIAABJJGgAHGSWsx/IXA+xhgTBBAAAKxIyDLET/yyCOzZs06++yzZaOdv//7v5d1iWXrnT/+4z9OylTY2DHFIQhAAAIQcCQgKy9ACAIQSBYBpGyy2gtvIZAYAvX8vC0i9plnnvn0pz8tCnbt2rWXXHLJyJEjE1NzHIUABCAAAQhAAAIQCJ4AUjZ4xpQAgUwSqOfn7ddee23z5s2LFi0aM2ZMJuFRaQhAAAIQgAAEIACBKgSQsoQIBCAAAQhAAAIQgAAEIAABCCSMAFI2YQ2GuxCAAAQgAAEIQAACEIAABCCAlCUGIAABCEAAAhCAAAQgAAEIQCBhBJCyCWsw3IUABCAAAQhAAAIQ8J3AypUrfbeJQQhAIFACSNlA8WIcAhCAAAQgAAEIQCABBOpZeD8B1cNFCKSRAFI2ja1KnSAQAwL8vB2DRsAFCEAAAhCAAAQgkFoCSNnUNi0Vg0C0BPh5O1r+lA4BCEAAAhCAAATSTQApm+72pXYQgAAEIAABCEAAAtUJ8AtsdUakgEDMCCBlY9YguAMBCEAAAhCAAAQgEDqBVatWhV4mBUIAAnURQMrWhY/MEICAHQF+3iY2IAABCEAAAhCAAASCI4CUDY4tliGQaQL8vJ3p5qfyEIAABCAAAQhAIGACSNmAAWMeAhCAAAQgAAEIQAACEIAABPwmgJT1myj2IAABCEAAAhCAAAQgAAEIQCBgAkjZgAFjHgIQgAAEIAABCEAAAhCAAAT8JoCU9Zso9iAAAQhAAAIQgAAEkkZg5cqVSXMZfyGQdQJI2axHAPWHAAQgAAEIQAACEGDhfWIAAokjgJRNXJPhMASSQYCft5PRTngJAQhAAAIQgAAEkkkAKZvMdsNrCMSeAD9vx76JcBACEAiKwCOPPPIh/bjvvvuMMuSumKs4zLdKEihWceAQVGRgFwIQ8JVALp/Py31VXn01W8VYZ2dnW1ubvIZZKGVBAAKpJyB3lRkzZuzZs8dDTeVOuG/fvstnTu+8b7ope67wXvtv8b12qZ7rVqYK9iqKqPX6sO1SU8P/8ut6aS1yVnC0JPVc99CM1bO0rti6/onnPvCBD0jSsePGTp482ZxHwqC6CasUEjwXf2KaKXhMdmwh+BhUdsFZa7DVGoEV9iOJNK+t5rKtJWbat2xraWmR9I2Njc3Nzc4ZW1tb29vb3ad36QbJgiYgEjrpP8I6PwQd7m/Otz5vGX3PpT9SrG/R3spyMBifj4IIe9/vUWKwo6NDXoPw1s6mErBI2TCZUxYEIBAsAaSsSWX7JVnt7CBlS4IZKavjyJl+8PErAl1EGlI22DtrVqyH37XjO9lapWxPT09vb6+zbIuVqPPwa2MiVLqHelUGz5QpU+S3NjdBhZR1Q8kpDb2y9RIkPwRiTyCSn7eRskjZqn8Z9MoW1aZlByy9shYRRK9s1T+rdCTIlJQVEfvXV31s596eyY0jfW0+jwNbavHBvgh/CvfHin2NgrLfPTA4c9rUNdt/0tTU5MwTKVtLvFmlRcrWS5D8EIg9gUi+EyBlkbJV/zKQskjZqkFSlgApWyuxhKaP5LHlLyv3vbLLLzpz6sRRq5ecOWqkrJvDhIg0jCLpPTR029rX9/cPbnplX3akLMs++XsPwRoEIAABCEAAAhCAAATiS6C/v/+lXxy8/5ozdB3LkRICE8Y2rP7z83b8uEu63FNSJRfVIIJdQCIJBCAAAQhAAAIQgAAEUkHgwIEDTeNGThjj79DiVKBJeCVGN5w0uXH0wYMHE16PGtxHytYAi6QQgAAEIAABCEAAAhCAAARiS0B+qpCO2aGhodh66KNjSFkfYWIKAhCAAAQgAAEIQCCRBFauXJlIv3EaAqUEBgYGRMp2dXVlQc0iZQl/CEAAAhCAAAQgAIGsE0j6prJZb7/U1b+7f7DzvX67s/9wlU7XEydO9PX1pY5KeYWQsqlvYioIgWgI8PN2NNwpFQIQgAAEIACBJBMQEbvw3u99cMXWti+/YHee9qnN8+/ZJSkdKipqNskYXPmOlHWFiUQQgECtBPh5u1ZipIcABCAAAQhAILMEpKNV9cEueuA/x4w66fX75+392mWdDy6wPN9+6Kqpk8Z88pv/lVlcquJI2YwHANWHAASGCUyYMOFA/7HBofT/ipnZVj84cFQ2kZ80aZLvBAge35HGxKCKmaamppj4gxvBEeAX2ODYYrkqgQee/NnphW7YnW/8tuflX7w3a9V35Ypct8yrtt7Z+UZXz8DRqsZTnAApm+LGpWoQgEBtBEThzD5n0q0b3+w9fKy2nKROAoHBoeO3r/vRzGlTx40b57u/InUIHt+pRm4w0JiJvHY4UEZg1apVMAmBQG75DlWKepNbvl07l6lzm5x2PuRueM5H93KLtxTcuL7wxkfjtZqS/ti7N+199d65egfswt+vWSSv8l6uyHW7abGFrXcOZVrK5vL5fC6nvdYKvZ70nZ2dbW1t8lqPEfJCAAJxJiA/b4f/C7fcVWbMmLFnzx4PZOROKLlk0b9bF3xU9o6XPfc8GLHPohkP+HAswp/y/bHiyCHAIg70D875o1Pv/MbWiRMnKh/Gjhs7efJksz8qDDwckrG7u/tTl5yVtuDxyKMMoT9Wwv/7UjFz17eeNmKmsbGxubnZOUJaW1vb29tbWlokmZv0HuKNLEEQCP/7sO+1cH4IGve3ffv2XT5zeud904sOmP5CS+6B5uuS1vyHXHyv/beG67kbd+bXzdHyLN+hv8mJjs2vu6RoQze3bFt+/dyC2YJt/foNz+UfvdR0vaJcc+IlT+U3zC81Uu6qqNn8Ywu1q9fLm6uGaQwbLi2i+vXSIixhWj1lZFCxzIkV7VoZEq0rtnZ8ZVbryY2W0VL5qVxp37LN+f7j+z1KDHZ0dMir7yHtYFD9wSJlw2ROWRDIEIFIvhPUL2VVC/X398u2bH29fUeOHHHVZl6/qOdKvgG4KqqQyGuJ+mPWa2bv+bzmLPvi4ZqQZR3Hjx8vw4DNNvyVskbw7N+/X34TOXzosFt/veIJvynd1igt6SRgymLGjTT1/WtiWnDGvR6RPLb8hRJzKavr2Nm6fFU6VrvFu5eyw1Kz8GioV8pqj0NNxIqazeWu31xUs+Y7K1LWVYQiZV1hIhEEIJAgApF8J/BLyirOvb29hwYOuWKeKCkSvv7xXqKvUrayKTWZMrFE3NbTK2u2Lz20/X39roLHax0j+VUiqkLdkgw+nUxDqDrXGikbfDsEUkIkjy1/axJnKavp2LWzNfW4vNAx6yxl9b7Zebllz0syvTO20Cur981epv8km8stfSbffrm8GhjzG67Qri95ynTlSq3QxU8OX9m4QBWtftc1umSLahYpW3NURihlmStbc2uRAQIQyAiBsWPH5kZ4FakZYZTkakrjjhk7JqAaSA8wwRMQ2wjNjhgxIoiJ1hHWiKIhEA6Bgo7VxhWbdWyh8LK5svroYl1kLns+/+g8OZ2dFDWbb79COzdckVvytCTWhxZrr/kNV2p2Fj+Z33ilfi6QM7d4q9mg9MqKiNXSP3aVehP+MaVxdO/hoV91lW8D+8t3ZHjYkHwavktJKZEBxklpKfyEQMIIRPLztr+9skL82LFjRw4fOX78eBX6XgWv9z5Az4OEtae6x1hKkLdVXR2RG9E4vnHkyPIZ0VUz2rGrzDg0NHTo0CEJoaq4vRfqvS2rOmWbwLu3Xuche/fV15yiY+UXioaGhqpW6ZWtiiieCSJ5bPmLIh29soqJ6pUtmUOrz5Wt7JXVEpd0zGo6VjpmjbmyuSXDXbLKuAjaWPXKikuyUvFXN+8d//4Gmf95+OjxsaO1x5Po2y8vmvb5+WfZxQlzZZGy/t5DsAYBCBQIRPKdwHcp67I5w/9y77lE7QHvVVGEn9Gzt+G76rlEz3WMJGNUhbr8S4xJMqRsTBqiVjciWa2wVied08dZymp3D3dzZZ2lrPYQu+HZfPtluaXyernSsdIlq8tfUbBPqy7ZMikrXbK62fK5rzGZK6uqLCsV7+8ffHv/oWsf2P39e7S5xNIf2zjG6eczpCwDjP29h2ANAhCAAAQgAAEIQCB5BMJfdT95jOrzWObKygBjsSFrPhlb8tRn0ktuY4BxUcfKdFljzScvBv3KI6pVVipumTJ25Ekj5I2czjrWr3ITbQcpm+jmw3kIxJfAypUr4+scnkEAAhCAAAQgEDoBWcFYidh61Kws+2R0yWqmtJWfntZOfaKsOqRvVjpm1dBi6ZKV6bL6uVVOfXSxTKC13IkndCKmAqVXVnblkV7ZY8dPyBs57XaUjdLLmJWNlI1Zg+AOBNJCgJ+309KS1AMCEIAABCDgG4HiNjyamtU17SWWprWJsqWHWse4oFTbLzN/aCz7pK9gXExTXPZJqVlj2aeChY3ajrLaR/rWspEfMlf29BVbZXfZxf/08tFjJ+SNnHJFrkfuW5wdQMrGuXXwDQIQgAAEIAABCEAgDAL8AhsGZcqwIiC9r3dv2vvqvXM7H1yw76GF761ZJG/klCtynb5Zh6hByvInBQEIQAACEIAABCCQdQKrVq3KOgLqHxEBWe1pwpiGj5w6vqx8uSLX5dOI/EpAsUjZBDQSLkIgiQT4eTuJrYbPEIAABCAAAQhAICkEkLJJaSn8hEDCCPDzdsIaDHchAAEIQAACLgjkbt6Vu/mlwnnTS7mbviuni3zaZjxqBeOoDrXskzorfZB1jPVzU+4643zC0tXctY8bpy91kU13ZAvZX3X1lVn75Tu9fUeG5FNfSkmlEaRsKpuVSkEAAhCAAAQgAAEIQCAoAvn/mKmda+T8UymjqpoVHSvJZAXjOh2STWXl9GBEVjDWHNi4wFjB2NJI/rGr8982zkUWivfa72h2Hr9WTq3i137bgzNlWWTTnTuvPuf8O7bJPrEfvGXLyTc9IW/kPP+O7XdePY0teRwII2XrDz8sQAACcSEwYcKEnp6ewUFmlcSlRfADAlkjcPDgwe7u7qampqxVnPpCIM4EDB1bp5O5oo6t005l9tuuPHvftxZ0fGXWxs9dOGrkCHkj51sPLvj8/LN8LytNBpGyaWpN6gKBrBOQr48XXXTRHXfc0dvbm3UW1B8CEAidgPyOdvvtt8+cOXPcuHGhF06BEIgFgdxNL2rnjXK+IKfySXXJam+KA4xld1n93K7OwqfLtuWGz+cr65O74blCyqXP5pY+U3z/jLGvrHlrWW84jAHG3rLXk0t6X1tPbjy7ZaIMNp46aYy8d+6PPThwtHtgMOPDj3P5fD6X017rQV9r3s7Ozra2NnmtNSPpIQCBpBAI/8aiyEh/yNKlS3fv3j1x4sSaWInDNaUncZwJ0Jpxbp0U+3bgwIE5c+bcddddxv2nsbGxubk5xVVOU9VktcKkL1goX61nzJixZ88ey3Yxboz79u27fOb0zvumF5OZHn8lj0LzdU2HFqTjzbsq7ZuHGefXXKynzSkpm187S39vDDDOiYjVrmv7yurpdCmbX39JbllB0+bXzy0UVyzTKFGp2by2r6yeVxe0sq+sliD3PiVl8xvml1RtuB56Fn2ibF72lS27fv1m7fpjV2t2rtukvf+2eYCxXB32QrNz7eNamsevM10fpqT7Y/5eUXzv4svGwnu/9wcT33//8o9OGNtg9yc2OHT8s//22rs9h5/60kXmNDIsuX3LtpaWFrlod/9pbW1tb293TmNXruV1MdjR0SGvNeWqM7H6nomUrRMj2SEAAWsCUUlZ5U1/f//+/fvla+XAwAAtBAEIQCAcAjLHQQ5zWUjZcMhTiiIQppSVibKaWLv5JXlVOlb7p9X6T3ZStqzVDCmr61jNmPFiqGjtan1StqhjF+jC13ChVHOqksvVbEn6oo6V6bLm60W3Czg8Stnu/sEbV7+ya+9/N42zXfDpQP/g7P/v1H//i483lS4KhZQN425Ar2wYlCkDApESiMPP2yJlGWkcaRRQOASyTmCSfmSdAvUPi0D4UlbTcTcNq1klZY1eWVO9nXplh3Wr3isbnJQtnTHrXcqWzpj1X8oqbn2Hh0Sv2sWO7DdbJmJVyqxJWebKhnV3oRwIZIxAHIZpjR8/fsQI7nIZizyqC4HYEJD7D5NmY9MaOBIBAfN0WYfitemyxaHFwXlZdeUntRmPcsBqgHHBteBWfiqr+3h96qzdaaljg6MXW8sMMI5t0+AYBCDgA4GhoSEZY3zs2DEfbGECAhCAgGsComPl17SGBtupbq4tkTAkAnEYTFRnVSPpldWmhBY6Y2WYsbx/0VwLfXSxpg3Nc2W1f+vTZY1DRhdrF130ymqmipvx5Nsv13IV139S1kwTZbUP9cJlfqy2E0/ZkX9sofbh9Vu0XI9dpb8vSFntyrevHp4efJ22wWz+8WuUji23853rTFeqTTx2MVe2sgj3V7LWK4uUdR8bpIQABCAAAQhAAAIQSCeBaJd48IVpOFJWd9VYxMj0vt7rVqYqln0yzaGtmInqlFgBtpgT6+v10iK8LvtUTzBkTcoy9K6eaCEvBCBgSyAOA4xpHghAAAIQgAAEIACBtBJAyqa1ZakXBCImsGrVqog9oHgIQAACEIAABCAAgfQSQMqmt22pGQQgAAEIQAACEIAABCAAgZQSQMqmtGGpFgQgAAEIQAACEIAABCAAgfQSQMqmt22pGQQgAAEIQAACEIAABCAAgZQSQMqmtGGpFgQgAAEIQAACEICAawIrV650nZaEEIBALAggZWPRDDgBAQhAAAIQgAAEIBAhARbejxA+RUPAGwGkrDdu5IIABKoQ4OdtQgQCEIAABCAAAQhAIDgCSNng2GIZApkmwM/bmW5+Kg8BCEAAAhCAAAQCJoCUDRgw5iEAAQhAAAIQgAAEYk+AX2Bj30Q4CIFyArl8Pp/Laa9hsuns7Gxra5PXMAulLAhAIDsEuru7e3t7s1NfagoBCMSBwJQpUxobG+PgCT54IBD+92EPTjpnka/WM2bM2LNnj2UyqaC6vm/fvstnTu+8b3oxWeG69s9iGv0j8/XSfxofaUlMyeq6bmWqYLuiCMtynRKrupbaGf6XX9fLoFmSMV/0PQTe17pia/uWbS0tLWJabkfNzc2VZbS2tra3tzunqckzMdjR0SGvNeWqM7H6g0XK1omR7BCAgDUB+Xk7kl+4RcQuX758165dkyZNqqltjGd8TblIHE8CtGY82yX1Xsn9Z+bMmWvWrGlqakp9ZdNXQaSsrvWs1FdBoPklWe3sIGV9+KtCyvoAsaoJemWrIiIBBJJOIKrvBJdeeukpp5xy7733jho1qiaG9Ygfz3nDz6h/UfH4k3D4GT17G76rnkv0XMdIMkZVaE1/yxEmlsEgt9122/79+zdt2hShGxTtjUBUjy1v3lrmoldWx2LZhauA+dX7amentAjL3wW8PoJdxknWpCxzZV0GBskgAIEEEOjv79+9e/eqVatq1bEJqBsuQgACsScwYcKE1atX79ixo6enJ/bO4iAEIACBxBNAyia+CakABCBgEJDOkIkTJ8q3SZhAAAIQiITA6NGjJ0+efPDgwUhKp1AIQAACmSKAlM1Uc1NZCEAAAhCAAAQCJ3DgwAHpmB0aGgq8JAqAAAQgkGECSNkMNz5VhwAEIAABCEAgAAIDAwMiZbu6ulCzAdANyuTKlSuDMo1dCEAgGAJI2WC4YhUCEIAABCAAgWwTOHHiRF9fX7YZJKn2kay6nyRA+AqB+BFAysavTfAIAqkgwM/bqWhGKgEBCNRFQNRsXfnJDAEIQAAC9gSQskQHBCAQCAF+3g4EK0YhAAEIQAACEIAABHQCSFkCAQIQgAAEIAABCEAg6wT4BTbrEUD9E0gAKZvARsNlCEAAAhCAAAQgAAFfCcie5L7awxgEIBA4AaRs4IgpAALZJMDP29lsd2oNAQhAAAIQgAAEwiGAlA2HM6VAIHME+Hk7c01OhSEAAQhAAAIQgECIBJCyIcKmKAhAAAIQgAAEIAABCEAAAhDwgwBS1g+K2IAABCAAAb8JjNWPMcXDMK8umEszrlR+9H79sHNNfWocftfArb0G/XCbmnQQgAAEIAABCOgEkLIEAgQgAAEIxI6AiFjx6dChQ4f1Q95Xylc7p8tSOuhY+ehI8ZD3DqK3KqBR+lE1GQkgAAEIQAACEPCLAFLWL5LYgQAEIAABfwgYOtYwV6uarSpKVQKRsUYR6v3o0aP9qQNWIACBpBFYuXJl0lzGXwhknQBSNusRQP0hAAEIJIKA0T0bnLeiZgcHB5V90bTmw/KioXuNN0bfrHpjHCq75cXgqoNlCECgJgIsvF8TLhJDIA4EkLJxaAV8gEAKCfDzdgobNU5VsuynVQ6qj6p2zDrURklTkbXqUMrWnL7suiGAj+qHOaVxRQ0/Vv9UaRiQHKeAwhcIQAACEEgeAaRs8toMjyGQCAL8vJ2IZkqQk5VLOvnuvKhfNwOMDeFa1YEyWVs1PQkgAAEIQAACEHBPACnrnhUpIQABCEAgRgQcOmbVxNd6OmZjVE9cgQAEQiHAL7ChYKYQCPhJACnrJ01sQQACEIBA/QRk4WIxohZ/UodalFhpV/NRecX41LykU6VLlVpX6V73Pa71VxMLEIBArAisWrUqVv7gDAQgUJUAUrYqIhJAAAJeCPDzthdq5CkSMNSsMa7YTrXWr2aNvWcN9WvMj1UrP7mRuMb0V7sZsOYExrxZGhwCEIBA+AQmTJhwoP/Y4NCJ8IumxEAJHBw42j0w2NTUFGgpsTKOlI1Vc+AMBNJDgJ+309OWEdVE1Kyxr6xZr1YuZWxcqfxI7RprVwNjU9nKZMaaT8YKT0rQmrtty/5pXtKpcv0nyW4kKPt0SD8iwkyxEIBA5ghMmjRp9jmTbt34Zu/hY5mrfHorPDh0/PZ1P5o5beq4cePSW8vymuXy+Xwup72GWefOzs62tjZ5DbNQyoIABMIkEP6NRWond5UZM2bs2bPHQ03FYQ+5VBbPecPPmAhvzUOLPTdKcjO6l7UZiZ/ENWVra2t7e3tLS4t43tjY2NzcnLgqZNPhSB5b/qJ2fgia7xg9PT23LvjoS7842DRupK8+eH+SunbDvgh/CvfHin11grJ/oH9wzh+dete3np44caIq3e7+4/s9Sgx2dHTIq+tG9CGh+oNFyvqAEhMQgEAlgUi+EyBl3YRi+PrHc4mehbfnEsPP6LmOkWSMqlA3gR2fNL5/TYxP1dLtSSSPLX+Rupeyqtz+/v4DBw709fYdGbQdvaL91cv/7A6nT/zOpbtieXjzMOSq+dvWldZk3Lgc5utI2aCY0ysbFFnsQiA2BCL5ToCUddP+4as1zyV6Fk6eSww/o+c6RpIxqkLdBHZ80iBl49MWNXkSyWOrJg+rJq5VyiqDvb29ankCe7nqtyj1JoATLmU96+2q7W6XQEaSy1H5qe/3qAh7ZZkr6zk8yAgBCEAAAhCAAAQgkBICK1euTElNaqyGzOkYkUMR1Egt9slHjBiRhUmzDDCOfSTiIASSSSCSn7fplXUTLOF3PHouUfsJ3tMcZm+5PBdXT8Z68oZfzUi8dRPVsUrje49HrGqHM3Em4K1XVmp0/PhxWTZPXi1r53Cr8dbT6NGgdgOyxu+7Qed7nf+19vSkcwhF0bHjx49vaGiwTOP7PSrCXlmkbJzvSPgGgQQTkM14wt+PBynrJmLC1z+eS/QsnDyXGH5Gz3WMJGNUhboJ7Pik8f1rYnyqhicxJ+BZyjrf+pyEor0G8z2Xw/3HW1lV9GqIVfP86PEWkL7foyKUsgwn8BYD5IIABKoQCF/H0iQQgAAEIAABCEAAAtkhgJTNTltTUwhAAAIQgAAEIAABawL8AktkQCBxBBhgnLgmw2EIQMCWgO8DjGXnPVnasSpxz0ODws8odQm/UM8l1uOtQ6tNmTJFtiiwTODZVSNjd3e3m5gxl15/oVVDtCyB5xLraZF6Cq21gn6ldwgVhyJ8H7znV3Ww40wgkiUe/G0UBhhX8kzE2OmQb4++36MiHGCMlPX3HoI1CECgQCDpc2VFxP71VR/bubdncmOKto/XhIgvIeqPFUdXAiyie2Bw5rSpDz71alNTk18aT76IiIj99Lyz0xYz/rSDP1bsAyYo+ypU1mz/SWWoIGV9uZXEyghS1q45vM1E9T2Xw09p3spy/m3Om03fcwXxN4KUrZcq+8rWS5D8EIg9gUi+E/jYK7v8ojOnThy1esmZo0aqiRjF78raf83fm+u5bmWqYK+iiFqvD9suNTX8L7+ul9aiZJ0MUxF1Xfc53HsPDd229vX9/YMbdv3SRym76PyppphxU3cfY8kuJmuNsVoDr8J+JAHm9+KfRlQYobLplX3uo9D3r4nuiyZlPQQieWzV43BlXnplK5nQK1vJxPd7VIS9ssyV9fcegjUIQCANBPr7+1/6xcH7rzmjqGPTUCnqYBCYMLZh9Z+ft+PHXdL37hcWYsYvkrGyE0SoxKqCOAMBCEAg0QSQsoluPpyHAAQCIXDgwIGmcSMnjPF3aHEgrmLUG4HRDSdNbhx98OBBb9krc+3fv5+Y8QtmrOz4Hiqxqh3OQAACEEg0AaRsopsP5yEAAQhAwDsBkbK9B3uHhoa8myBnNgjIz1vSh0+oZKO1qSUEIJAYAkjZxDQVjkIAAhCAgL8EDh86LKsN/+53vzt27Ji/lrGWMgIDAwMiZbu6ulCzKWtZc3VWrlyZ4tpRNQikkgBSNpXNSqUgAAEIZIVAd/9g53v9dmf/4eo9rvkT+f6+/qzwynY9HaLFTaicOHGir68v2wjTXHv2lU1z61K3lBJAyqa0YakWBKImwM/bUbdA+ssXWbLw3u99cMXWti+/YHee9qnN8+/ZJSmdcZzIn0g/r2zXsGq0uA2VE4RKtiOJ2kMAAnEigJSNU2vgCwRSRICft1PUmPGqivSeqT7YRQ/855hRJ71+/7yOr8za+7XLOh9cUHm+/dBVUyeN+eQ3/ytedcCbsAhURguhEhZ7yoEABCAQOAGkbOCIKQACEIAABPwi8MCTPzu90A27843f9rz8i/dmrfqudMnKRfmoshS1mcrON7p6Bo765QN2kkLAMloIlaQ0X/h+puAX2AkTJsik7sHBKuNQwmdLifEhIOsddnd3NzU1xcelejxBytZDj7wQgAAEgiWQW75DFZBbtl1/3WY6n88te96h+NzSZy0/zS15umBzyVN22XOLtxbSXL8l2BrWYl162O7etPfVe+fqva8Lf79mkbyqnli5KB9ZTncsbKZyKM1SdjhO9IDJLd+uncvUqcWMbUPf8FwtLVAlbW5xIVpyMQgbu2jJeKj42NzpM7Vq1aqkV0r0yUUXXXTHHXfIgnZJrwv+B0FAfua4/fbbZ86cOW7cuCDsh28zl8/nczntNcyyOzs729ra5DXMQikLAhAIk4D8vB3+L9xyV5kxY8aePXs81FTuhEauffv2XT5zeud90012ip9q/x1OOfzey3UrUwXburnlO/Lr5sh/RZbk11+iXVkmb+YWvdLTLHs+/+g8S5dyNzybb7+s/KPc+0TK5jdcoZld8lR+w3zdmlw16lr0YPHW/MaF2ifXb8k/trDSjgUczZIVnHqvF4qSQcXSASvC1bJ9W1dslZHGrSc3Vn5q+ZFcXP/Ecx/4wAck/dhxYydPnqy7afa/hjiSmLn4E9NMMWOyY8vEn1jK3bhTj5PSgFl3SbFNVZxs0yNH98ocYzc8l3/0UtP1iuYzJy4EjNlIeRVEzerRosLmquFYrQgwu8CruF5ahCVMq1ZziBYPodK+ZVtLS4u40tjY2Nzc7BwZra2t7e3t7tPXEGckDZJA+N+Hg6iNdLgtXbp09+7dEydOLLPv+f4WhJ/+2kxx1fwFJfuKzZkz56677jLCw809raoPctPr6OiQ16opfUyg/mCRsj4ixRQEIDBMIJLvBGmSskUdq/RJQZb4K2VN8WohZTUBIWrWQpbo0qJE8bmRbfVI3IKnSNnK3yx0HTtb/71D/fChtY7224c7KTssNQuCsV4pa/7tI3f95qKatQ4wy99QkLI8SKIiEMljK6DK9vf379+/X3SL7CMVUBGYTSIBGYIuh9lzpKyXdqRX1gs18kAgUQQi+U6QGimbW27uZ9P6YwvdaTa9srkbpG9W+tbUkdP6Yx+9TF6NkMm3X24ohMpeWemeHU65cYEp0HIuOtmKzhULN2cffl9Xb23BDFK2TMpqOnbtbE09FgOmEAA2Ulbvm52nxqWrgMnpvbL662V6jOVyS5+RaJHX4ZAo9uGbrlypFbr4yYqwKUhWo0u2qGaRsom6fWfV2UgeW4HCFinLSONACafA+CT9qLMiEfbKMle2zrYjOwQgAAGfCZTqWNXPZpKEw9Nltbmy+uhi20MGGIssKVMm5Qa1UaNX5jcWTmOWrEomvbJq3qN0r4ks8bmqNZqb0ji69/DQr7osNvb85Tu9fUeGJEGNJhOcvKBjtXHFhR8+SuKkdK6sMS5dxYxz2GjNrYXNFdq54Qo1uVqNRZdXiRZ5Izq2GDML8hsXWIWNFi0Rho1dtGQwVBIc5bheH4Hx48ePGMFX/fogpjq3hEfSJ80ywDjVEUrlIBAdgUh+3s5gr2yht9amV9aYK6u62tR4zrJeWX3GrNbJVjxKhpjGqldWPJQ1ab+6ee/49zfIDJnDR4+PHT1SuS0S98uLpn1+/lmWIZ/WubLue2UVFtUrWzlXtrJXVktc0jGr6dji5Gq993bJcJesMi6C1hgwHIdeWbto8RYqzJWN7mESXsmRPLaCrt7Q0JCMMT527FjQBWE/cQREx8qPHQ0NDfV7HmGvLFK2/ubDAgQgYEEgku8EqZGy5qmPznNlA5WycZsrq+JMVqbd3z/49v5D1z6w+/v3FHqtpQuucYzt8zitUlaTlO7myjpL2cKg9PbLZNVrNRZd/+1D1gbTxam2TpiFlJVeWd1s6fRa0zph0c6VtYsWb6GClM3Ccy6S1QqzAJY6pp5AhFKWUQepjy4qCIHkETjvvPMWLlz4ne985/Dhw8nz3iePZQkftcOKrN8jq/i4t2qeIus+l5FyeBsetYJxYSla7Q1HDAnIXFkZYKzHSSFgInHSvHtTcakwY82nSDyiUAjUTCD8VfdrdpEMEIBAKQGkLBEBAQgEQmDlypWe7b7wwgvz589/6KGHTjvttOXLl2/btk2GSHm2ltyMJWpW31fW7lAr96hTW7+neEgnm3SvFUcXW+eWDjcZLCpTH9WpDxPV1y5Wbwo78cSFogwwPn3FVtmSZ/E/vXz02Al5o065KB/Fxctw/ZAVjIu/enhXs9o6YcUuWU0Yays/Pa2dxV2ItYtaqDylhhZLl2wxZrYOR4v1Tjzh4jCVZhktWQ6VyFqCgiEAAQgEQ4ABxsFwxSoEIOAHgXfffffxxx/fsGHDm2++ec011yxZsuSCCy5wWMQiTQOMTfzK9wI1hKr2xrTtZ8l1u4+8b+9ZPo603EP177pWKrbb1KdQlAwtFh3y6r1zP3Lq+LL4krWgpn9x21sPLrAcZpziAcbFGLDa68guNpyuO23GYxV4w3Gmmt9u0nUd10uLcL2vrF20eAsVBhj7cUfHBgQgkE4CDDBOZ7tSKwhAoE4CU6dOvfXWW3/wgx+88sor0kN7yy23fOhDH7rjjjveeOMNWfWnTuNkTxwBmSI7YUxDpY6VishF+UgSJK5SOBwQAbtoIVQCAp4CswwwTkEjUoWsEWCAcdZanPpCIJEEPvzhD995550//elPn35a2xdEhh9Pmzbt7rvvlt7aRNYHpyEAAQhAIGYEVq1aFTOPcAcCEKhCAClLiEAAAoEQCOLnbVkV+dxzz/3Hf/zH3/zmNzKTtqur6xP68fWvf12GIgdSDYxCAAIQgAAEIAABCMSSAFI2ls2CUxBIPoFAf96W6bIXXnjhN77xjXfeeUcKev31188666zZs2fLxNoTJ07EAV7u5pcK500v5W76rjrdOCar0aoFaaM6ZAkf43TwIXfdJnU6pbn28dy1j/tYEdlGRTYFlbmOlTZ/+U5v35EhSeBjcWGayt28qzJm3Dggm/GkI2AkVIzTTcWrprGLlqSHStWKkwACEIBAdgggZbPT1tQUAmETkE7UssPcVSvv608gW3vPnTt33bp1PT09su7xF77wBRG3YdfTvrz8f8zMr5HzT+WUVFXVrMgSSSYL0tZZBdmPx9uWPLImrebAxgXFdYy3ePMkd+135PSW1yGXLOl059XnnH/HNlnG6YO3bDn5pifkjTrPv2P7nVdPc9ha1ndngjCoBUwxZrIWMFrgPX6tnFrFr/12/XjtoiUdoVI/HyxAAAIQSAEBpGwKGpEqQCCmBGRlprKjTMrWmeBv//ZvX375ZVkF6pxzzjn55JNvvPHGf/3Xf5XVoWKKI/ZuGTq2qqe56506Y3VNco2cVe14SHDblWfv+9aCjq/M2vi5C0eNHCFv1ClrF39+/lkeDJLFMwG/Akb96qFErL+HZbQQKv5CxhoEIACBCAkgZSOET9EQgIAXAr29vU888YQIV1nfeMWKFdK1+/DDD8u82TVr1sybN89hqx4vhQWTJ3fTi7kb1fmCnKoQ1SWrvSkOMJbNQvVzu3YW95XNLdtWPJ/PLXu+0kGjP1bfVPbZgk19d1m1Tah5p9Bg6hesVeltaz258eyWiTLYeOqkMfJeTof+2IMDR7sHBpM79lgLCQmYQsy4DpjlhY2ITQEjkWMZMM8Vg0TbhdgUMIV9ZRMdMJXRku5QCfZvD+sQgAAEYkYAKRuzBsEdCEDAhoAs9fQv//Ivc+bM+cAHPiDadfr06a+++uqePXu++tWvymazJ510UgzJabMfi3Nlxb3iMOMXtfdrL9bPWbqI1dRsfm1hXLEaYCwiVru4bk5+3SVyaleKalbVNL9+npyVtc4/elkhQftl+XbtvdIn+fbL8+1X5DdcoV1Zoi0EXXbkN14pp7oo02W1LBsXVibLXb9Z++jbV0cLvKlx9Kxzp97676/1Hhpy8GRw6Pjt63500TmnJGLssXl+dXnArKk/YObaBMylpoC53BQwV5gC5qngAsbch68mV+cfv87f6HITLckKFX/5YE0RWLlyJSggAIFkEUDKJqu98BYC2SJw/Pjx73//+1/60pdk652Pf/zjsryTdMPKbNjt27f/5V/+5RlnnBFzHGreY0En6NNljcPolXWugtErW5Ysv35ucHUv6tgFlUUUdOxjEetY5dgjn/lEV/fhlls2GzNmK9803/TE7/sG1372guBw+WhZzZW1Dphir2yKA6aoY/0faewmWpIVKj5GHaYMAkEsvA9eCEAgUAI5masmw/PkNdBiyox3dna2tf3/7d0JcBz1nejxjLDstTy2LFkJJtZGIZuqV4DD29pgjkSlWA9jc2NusMGQPSAvqbhqd3HiLFuoJsfu4qRqXwp2K5Bd1geyCTHYxMTYDlkoPb/AFglZIkhSlYSNlDzMC5GsY2RbyPa8X3fPtHru7p6+/t3fyUSMRv/+H5//T2P9+t9Hj3wNslHaQgCBIAXkbwLXfxbIIcSHDh2SW8ju379fjiK+Rn9ceOGFdZde5VOlu7tblmpdjFQ+Cc2thoeHr+5dMbRlhaWewk+1/86WnH1d/L5ckFbKaWmJ/r5xwSd9VVZe51dl9cqLqrJc9illrsrmy+QLpuR4Ua0qLZXV3yq8b+2qcYyxsSSrtVhYldVKy//0JdnczmuLRmeOr3Dlp3z3Zjuoj0Rfki155L510+w7FsaicyAt7xeN2tb7teZz8vjMaHa6WolF85tlRa7iTyXv3bF7vyzyy09bFrS0t7frWNYZqdVuyc8kZi69eLklZiz1VB2jZf7MgNHfk8X8QsDkrxaW23qpEUtFEz17nbCygCmUNRbzC/s+KsdM6g7tGGM9YPQ28gGjLeBXChhrJbKAn79UmKuA0QLSeBSfMTv7fr5ac9gVMW3PWo1oqR0q/XsOdHZ2Si/S6XRHR0ftyOjq6urv77df3kGcURQBBBCInoB86A0MDMjXILtmJLCsygZpTlsIJEjAdR4rRr29vaocQtz4jFpPl61RmyQkJQcYN950eQ11L+STe+IG/XmjeYBx6EcaL9RPna32rJbH+qEXTJ12A8ZyfrV/HXMVMJYdH4We+Xflp5Kx14iW+IWKf/NOzQgggEBEBEhlIzIRdAMBBGYFfvSjH6lyCLHNabPejEdbXtPOj81f9kleG2fMljzkLFmtWOGyT1qxHdoZs3Yexumy5mWf5CxZ/dv8ZZ+0qvQzZkseRlqilZy9tWz+Zjyp2/ZUXI+11pC6dbc87XSPMnUFKgSM5QBjPwMmf1q1HjD5yz7pAWNdw89334uA0a5dbN63yXJrWQ9uxlMXmQIIlAg0sgcWTAQQCEWAA4xDYadRBBDwRSA6BxhXO/C4+H3tz3gLRNUDhvX8Mp9m2i1fbZPiA4YLtVmP5yzuUv3yxaOwdcCwnYNvXR7oaz+wInWAsd5tZwex2yvvNMacBmRZ/fUDxocAs32Asf3wsJaUUOEAY3d0am0V/Al3avnQWwSqCXCAMbGBAAJxE2D3dtxmlPEggAACCCCAAAJREuAA4yjNBn1BIEYCmUwmRqNhKAgggAACCCCAAALREiCVjdZ80BsEEEAAAQQQQAABBBBAAIG6AqSydYkogAACCCCAAAIIIIAAAgggEC0BUtlozQe9QQABBBBAAAEEEEAAAQQQqCtAKluXiAIIIIAAAggggAACMRfo6+uL+QgZHgKxEyCVjd2UMiAEEEAAAQQQQAABhwJceN8hGMURCF+AVDb8OaAHCMRSgN3bsZxWBoUAAggggAACCEREgFQ2IhNBNxCImwC7t+M2o4wHAQQQQAABBBCIkgCpbJRmg74ggAACCCCAAAIIhCHAHtgw1GkTgYYESGUb4mNjBBBAAAEEEEAAgRgIZDKZGIyCISCQKAFS2URNN4NFIDgBdm8HZ01LCCCAAAIIIIBA8gRIZZM354wYgUAE2L0dCDONIIAAAggggAACCRUglU3oxDNsBBBAAAEEEEAAAQQQQEBdAVJZdeeOniOAAAIIIIAAAggggAACCRUglU3oxDNsBBBAAAEEEEAAAQQQQEBdAVJZdeeOniOAAAIIIIAAAgh4I9DX1+dNRdSCAAJBCZDKBiVNOwgggAACCCCAAAJRFeDC+1GdGfqFQFUBUlmCAwEEfBFg97YvrFSKAAIIIIAAAgggoAuQyhIICCDgiwC7t31hpVIEEEAAAQQQQAABUlliAAEEEEAAAQQQ8FzgscceO1t/bNmyxaxcdvClyh7WvX4UMKzCcli5cqXnkUCFCCDgq0Aql8vJ56p89bWZksqHhoZ6enrka5CN0hYCCMReQD5Vuru7BwcHXYxUPgnNrYaHh6/uXTG0ZYWlnsJPtf/Olpx97eb9SlXl6y5rwun7s3UXVzX7nVfvF4/CwlgE1dD7Luaz/iZd9+7dsXv/smXLpGjLgpb29nZtJEX9rF+JNWYuvXi5JWYsvFXH7mEsVYtJpzHmNPDK6g8lwNzOms0JllDp33Ogs7NTyqfT6Y6OjtobdnV19ff32y9vsxsU81sg+L+H/R4R9SMQjIB86A0MDMjXYJozWjF+YTnAOEhz2kIgQQIcYJygyWaoCCCAAAIIIIBA4AKksoGT0yACyRDIZDLJGCijRAABBBBAAAEEEAhBgFQ2BHSaRAABBBBAAAEEEEAAAQQQaESAVLYRPbZFAAEEEEAAAQQQQAABBBAIQYBUNgR0mkQAAQQQQAABBBBAAAEEEGhEgFS2ET22RQABBBBAAAEEEIiDQF9fXxyGwRgQSJIAqWySZpuxIoAAAggggAACCFQS4ML7xAUCygmQyio3ZXQYATUE2L2txjzRSwQQQAABBBBAQE0BUlk1541eIxB5AXZvR36K6CACCCCAAAIIIKCwAKmswpNH1xFAAAEEEEAAAQQ8EWAPrCeMVIJAkAKkskFq0xYCCCCAAAIIIIBAFAUymUwUu0WfEECgugCpLNGBAAK+CCi9e3vRokWj2ZPTM6d9oaHSCAiMT717dGp68eLFXvWFmPFKMmr1GKHS1tYWtY7RHwQQQAABUlliAAEEfBFQeve2ZDiXnbd44643J46f9EWHSkMVmJ45tWn7j3uXL12wYIFXHZFUh5jxCjM69fgRKtEZHT1BAAEEVBdI5XK5VEr7GuRIhoaGenp65GuQjdIWAggEKRD8B4uMTj5Vuru7BwcHXYxUOmzdamxsbOPaP3nh5+NtC+a4qK36JkWteFqzWVnNJrxp35taag7fxyZGs9Or//is+x/e29raavShZUFLe3u7vCgJA/sTJBsePXr0L9acE7eY8WYevKkl+F8rI1Qe+MY+M1TS6XRHR0ftwOjq6urv7+/s7JRidsrbDzNK+ioQyj9bvo6IyhEIRkA+9AYGBuRrMM0ZrRi/sKSyQZrTFgIJEgjlbwIPU1ljqrLZ7Ojo6OTE5IkTJ2pNnts/1FPvcb+l62AKvlH3LWr/WLkZaO0WFy5cKMcDW+v1JJU1Y2ZkZER2hRw/dtxu112NUbdxv6XdviW7nMRJSajYSU1JZRWNmlD+2VLUim4jYBUglSUeEEAgbgKh/E3geSprzMrExMSxqWOksg3kTW4zLn9S2fKp1PKVVi25bWRV1lqtrNBmJ7N2f6vd8oSSyobSqF1J/8vJ2Qd1T7EmlfV/HnxpIZR/tnwZCZUiEKxAiKks58oGO9W0hgACCgq0tLSkmtxmGwqON2ldlsmd3zLf21HLwi8x4y1pFGpramry8PzqKIyIPlgF+vr6AEEAAbUEOMBYrfmitwgoIxDK7m2fVmUF/eTJkyeOnzh16lTlCXCb57pfA3S9QioDSEBv7cM2pZrSC9Nz5uTPiLa/YUkklG84MzNz7NgxiZy6v7TuG3U/l3U7VbWA+94Wn47uvgchbSl5rOyhaG5urts+q7J1iSiAAAJxEghxVZZUNk6BxFgQiJCA3Iwn+Pvx+JfK1pYN/o971y1qmazbjCL4DV33Nviuum7R9RhD2TCsRiP00WajK6SyNpAoggAC8REIMZXlAOP4hBEjQSBSAsHnsZEaPp1BAAEEEEAAAQQQ8FWAVNZXXipHAAEEEEAAAQQQUECAPbAKTBJdRKBYgFSWiEAAAQQQQAABBBBIukAmk0k6AeNHQDUBUlnVZoz+IqCIALu3FZkouokAAggggAACCCgpQCqr5LTRaQSiLxDK7m25OejY2Nj09HT0feghAgjEUmB8fFzuKtzW1hbL0TEoBBBAIFICpLKRmg46gwACDQnIn48rV67cvHnzxMREQxWxMQIIIOBcQPajbdq0qbe3l9vPOsdjCwQQQMCxADfjcUzGBgggYEcglPvKSsdkPWT9+vWHDx9ubW2100+zTCM3U3HUEIUDEGA2A0CmiXKB0dHR1atXP/DAA+bnTzqd7ujowEoJgbD+2VICh04iUEMgxJvxkMoSmQgg4ItAuH8TZLPZkZER+bNyamrKl+FRKQIIIFAmIOc4yMP6NqmsQmES7j9bCkHRVQRKBEhlCQkEEIibQBT+JpBUliON4xZYjAcBpQQW6w+lupzczsrVCrlgYXKnn5E3IBBiKsu5sg3MG5sigEC0BRYuXNjUxKdctCeJ3iEQXwH5/OGkWYWmlzxWocmiqwgYAhxgTCQggIAvAhHZvT0zMyPHGJ88edKXQVIpAgggUEVA8ljZm9bc3IwQAgggEG+BEFdlSWXjHVqMDgEEEEAAAQQQQAABBBDwSyDEVJZD7/yaVOpFAAEEEEAAAQQQUEWAA4xVmSn6iYApQCpLMCCAAAIIIIAAAggkXSCTySSdgPEjoJoAqaxqM0Z/EVBEgN3bikwU3UQAAQQQQAABBJQUIJVVctroNALRF2D3dvTniB4igAACCCCAAALqCpDKqjt39BwBBBBAAAEEEEAAAQQQSKgAqWxCJ55hI4AAAggggAACCCCAAALqCpDKqjt39BwBBBBAAAEEEEAAAQQQSKgA95VN6MQzbAT8FkiltI8Xv1upVv/Ro0cnJibCap12EUAgmQJLlixJp9PJHHsMRi1XK+SChTGYR4YQvECI95UllQ1+umkRgUQIhJXKShK7YcOGF198cfHixY6gpcOOylM4ygLMZpRnJ8Z9k8+f3t7erVu3trW1xXiYDA0BBBCwCpDKEg8IIBA3gbB2b1955ZVnnnnmgw8+OHfuXEemjSQ/rrcNfkMxCb5R1y267q3rFoPf0PUYQ9kwrEYd/S6HWFgOBrnvvvtGRkaeeuqpELtB0wgggECQAqSyQWrTFgIIxFYgm82+//3vf/311xctWuR0kK5zmFD+uKe3tefXtU/wGxI/Tn9VI15+enq6o6PjN7/5jdMDQyI+LrqHAAIIVBMIMZXlsk+EJQIIxEdAFkNaW1td5LHxIWAkCCAQqsC8efPa29vHx8dD7QWNuxHgRFk3amyDQKgCpLKh8tM4AggggAACCMROYHR0dGxsbGZmJnYji/OAMplMnIfH2BCIowCpbBxnlTEhEAEBdm9HYBLoAgIIhCMwNTUlqeyRI0fIZsOZAFpFAIFkCJDKJmOeGSUCgQuweztwchpEAIFoCZw+fXpycjJafaI3CCCAQIwESGVjNJkMBQEEEEAAAQSiJCDZbJS6Q18QQACBWAmQysZqOhkMAggggAACCCCAAAIIIJAEAVLZJMwyY0QAAQQQQAABBBBAAAEEYiVAKhur6WQwCCCAAAIIIIAAAi4E+vr6XGzFJgggEKIAqWyI+DSNAAIIIIAAAgggEAkBLrwfiWmgEwg4ESCVdaJFWQQQsC3A7m3bVBREAAEEEEAAAQQQcCxAKuuYjA0QQMCOALu37ShRBgEEEEAAAQQQQMCdAKmsOze2QgABBBDwTKCl7GGter7+KG+s/P1qJf+g+FG73/OKH54N0mFFzfrD4UYURwAB9wLsgXVvx5YIhCRAKhsSPM0igAACCBQLHCs85G3JbUt4SrLZ8uTWfKfkR5LGSlUnCg95bbxT8SFprLw/XXjIa+Mdd4+5+sPdtmyFAAIBC2QymYBbpDkEEGhQgFS2QUA2RwCBygLs3iYyXAtISlsxm3VRoZnHmttKSlstmzUKSxprFjZeN5LNuugzmyCAAAIIIICAHQFSWTtKlEEAAccC7N52TMYG9QSqrbvW267058YCrc2tjAVao3DFY4+NN40FWOsyrLkea75pLWP9qXEsMUcU25wRiiGAAAIIIGAIkMoSCQgggAACygsYWe5x/SEvahxC7HqodY89fld/SP1Gmmq8Nl6Yr0veMUrOFB7ymvNjXU8QGyKAAAIIJE2AVDZpM854EUAAgaQLGBeBsqlgLLrWLVySrNYob79k3UYpgAACCCCAQJIFSGWTPPuMHQEEEFBGwFhuNa9RbHxrPKwHHpuv7SeryhDQUQQQQAABBBCwCJDKEg4IIIAAAtESMC5fbFz8yf7DOLrYPMbY2LD8Ik/lF4IymzAKW9dgzYOK7XeDkgggoKhAX1+foj2n2wgkVoBUNrFTz8ARQACBaAmYN5etlseaK7HWJdm6YzCzWfO44hrXfDIvWWweV2xe86nGj6r1wTx1ttoteYwC1ms+yWmzdUdEAQQQ8EOAC+/7oUqdCPgqQCrrKy+VI5BcAXZvJ3funY/cvKOs9dayZjXWhdaKr0tWYmXDkmsUmzeVtXPtYvOmstZrFxudqfijkmIlF3kyvjVS1vLrPxlvmpd9suaxxpvOLdkCAQQQQACBpAikcrlcKqV9DXLEQ0NDPT098jXIRmkLAQRiLyCfKt3d3YODgy5GKp+ELrYyNnG9bfAbRrO3xhHFPKoJVMtpExI/ygVGV1dXf39/Z2en9DydTnd0dCg3BDqMAAII2BeQD72BgQH5an+TxksaCSyrso1LUgMCCCCAQEMC5auy5jvWM2Dtvy5ZhrX/bcm6q/1vzdVXFy+sq7IVXzeEy8YIIGBPgAOM7TlRCoEICZDKRmgy6AoCCCCAAAIIIIBAKAKZTCaUdmkUAQRcC5DKuqZjQwQQqCXA7m3iAwEEEEAAAQQQQMA/AVJZ/2ypGYFEC7B7O9HTz+ARQAABBBBAAAGfBUhlfQamegQQQAABBBBAAAEEEEAAAa8FSGW9FqU+BBBAAAEEEEAAAQQQQAABnwVIZX0GpnoEEEAAAQQQQAABBBBAAAGvBbivrNei1IcAArpA8DeslkY9v6/s2NjYxMRE3SkN/vaerls0pqbuiCoWCH7DRnpbY4xLliyRu336NMajR4/aiRlr68HDum6xkRlppFF3Edv4VjVCpUbl3Fe2cflQapCrFXLBwlDkaVR1gRDvK0sqq3rw0H8EIiqgeiorSexf3vDR770x1p6e4ymxyzTSSR9qNuFN+97UUnNQPjZxdGq6d/nSR77zSltbW0kfXKdbsqEksZ+64ty4xYw38+BNLdUDxq/6jVDZevAn5aFCKuvkQ4myCCAQZwFS2TjPLmNDIJkCoeze9nBVdsPKDy1tnfvQug/NnWOciFH4W1n7r/Xv5kber1RVvr6yJpy+P1t3cVWz33n1fvEoipZ8LU009L7Hv0MTx2bu2/bqSHZ654u/8DCVvenCpZaYsTN2D2OpWkw6jTGngVdWfygB5vZAg7qBZYbKUy8N1y1sFmBV1r4VJRFAIAYCIaaynCsbg/hhCAhEUUDpw7Sy2ewLPx//6s0fLOSxURSmT64FFrU0P/TnFxz6zyOy9u66kpINiRmvJCNVjx+hEqkB0hkEEEBAaQFSWaWnj84jgIAvAqOjo20L5iya7+2hxb50lUrdCcxrPqM9PW98fNzd5uVbjYyMEDNeYUaqHs9DJVKjozNWAaX3wDKVCCRTgFQ2mfPOqBFAAAEE3iOp7MT4xMzMDBYI1BaQ3Vuyhk+oxDtOMplMvAfI6BCInwCpbPzmlBEhEAkBdm9HYhroRE2B48eOy9WGf/e73508eRIqBGoITE1NSSp75MgRslniBAEEEIiOAKlsdOaCniAQKwF2b8dqOiM8mKPZ6aF3stWe2eP1V1xzp3PZyWyEh0jXPBOoES12QuX06dOTk5Oe9YaKEEAAAQQaE+BmPI35sTUCCFQRUPpmPMPDw1f3rhjassIyuEauVOzV1WWlO7YvMDtb1qsrFVerp7hXDV2puNpVfysHmaQlf/pPLz//k7flrNdqv4hyM5WV55257bOXtJWV6bp3747d+5ctWybbtixoaW9v10bi9lq4EjOXXrzcEjNcwdirwLMRYDZmrW601A6V/j0HOjs7pStyR+KOjo7aH/xcwVjRfxhD+WdLUSu6jYBVgCsYEw8IIIAAAgjYEpDVM2MN9qav/e/5c8949atXDHx51Rv/66qhR9aWP3/76A1LF8//s3/+D1tVUyh2AuXRQqjEbpIZEAIIJFeAA4yTO/eMHAEEEFBO4GvP/PQP793b87fP9/zt91779dj/+fk7qzL/Lt/Km/Kj8uEYN1P53mtHxqbeVW6wdLhBgYrRQqg0qMrmCCCAQHQESGWjMxf0BAEEECgVSG04ZLyVuvOg/vWA5flc6s7napCl1n+34k9T6/bl61z3nWqbp27fmy9z257ozIqssH3lqTdeefByffX1+t9vvUm+Giux8qb8qOLpjvmbqRyLcyo7Gyd6wKQ2HNSedxpPLWaqTvQd+z2c39Tt+WhJRSBsqkVLwkPFw+mOX1V9fX3xGxQjQiDeAqSy8Z5fRocAAgoLSH6S277ayExyO9YYI8ntuLzwvCK344rUHbWyWdeDz+1aa2SzuSeuj0JaYgxkJDu9aH7zh89aWD4ueVN+JAVcD1ndDVMbvleIk3zAaBO3fY3EjP7UAqZGNmt/4Knq+z7ywbkrHy162Dxtv2Y/SlaLliSHih/OcSmgKYYAADuASURBVKqTC+/HaTYZS0IESGUTMtEME4GgBdi93aB4UR67PZ/HNlhnyea5ndfWqFDPZrVFtkhls94KxKC21F2Sx14mAzEDxtGgco9f6ah83cJmtOSeuCH0bLZubymAAAIIIKC0AKms0tNH5xGIrgC7txuZG0seK+ts9fPYVPFhoqk78ocWyzHGqfXPyrNiZ8xFttS6Z1K355/WkrkoLbI14hnXbbU8dpuDPNY4Il1W8s3FfCNyzIDRXuvRoofNPu1ZfDi6xIxEi+FZiJm95uHoxvtks3GNN8aFAAIIRE2AVDZqM0J/EEAg6QIVjxc1UUrOlc09fkUNr1z/Vbn+q+VZLZvVEpJ138ntvC63K/+MclqyJD1v4vjML49UuLHnL96amDwxIwWSEz2WPDZ/gLF17CXnysoxxvn8887nJGZqh42Wjmphc4323HmNkc0aa/jyVaLFyGMLMbPWPBzd7IB5gHGIa7PVoiWBoZKcX4oGR8oe2AYB2RyB4AVIZYM3p0UEEECgloAcL2pcxUdOgDQv5zObJBSfK+s5paQlRRnRbXskLdFSl9uelrTE8+YcVZie33z/jedduPmA3BL2A/fsee/du+WF8bxw88H7b1wuBRxVqHRhWY+VbFaPk3zAWIdTcq6sJX5q7fsomvriVdlyq2qrsnq0SNho0RJi2FSLlgSGitJxHmTnM5lMkM3RFgIINC5AKtu4ITUggEAFAXZvNxIWZhKrv9CuXRzKQ86VLeSx+cwklG5YG73vunOHv7FWbiS7668+PndOk7wwnr95ZO1fX3tO6N0LuAOWbLbCXg/7nck9fpVxjLGs3st6bOFFflW2Wj3WVVnrHhA9j43E7o+K0ZLMULEfDJREAAEEFBIglVVosugqAioJNLJ7+4ILLrj++uu//e1vHz9+XKUxe9pXSza7xlE2az3v0UWPZm/Dc/teOVdWy2oKmYmL2vzYRFbbut6b7lzSMueMJnlhPBO1HmtV1bLZDcbabEPZbIMzZb17U0TyWGNE5dGS2FBpcIrZHAEEEIigAKlsBCeFLiGQdIHnn3/+2muvffTRR9///vdv2LDhwIEDMzMzCUQpymb1+8pWe8h1aOX6PcZTVtjMYuZln4yltooPOfvRetknY3lNMpP8i4jlsdI3uV/o0DvZ344cO3nqtLwwnhXvKJuQmKl9RLpNBG1hdv13zTjRz68uuuyTli1roZK/7JMsyVoPMC6ETeSW8cujJcmhYjMYKIYAAgioIpDK5XKplPY1yB4PDQ319PTI1yAbpS0EEAhSwJMPlrfffvvJJ5/cuXPnm2++efPNN69bt+6SSy5paqq6D04+Vbq7uwcHB12MVDpsbjU8PHx174qhLSss9RR+qv13tuTsazfvV6oqX3dZE07fn627uKrZ77x6v3gUFsYiqIben52Hrz3z06889YbcQlb+2Tr+7qmWeXOMn8nloOQ0WjmgtOLUy8m0chCyLN5afypv7ti9f9myZfJmy4KW9vZ2bSRF/XQQRxIzl1683BIzFt6qY/cwlqrFpNMYcxp4ZfWHEmBVZq1itLgLlf49Bzo7O2W06XS6o6OjdmR0dXX19/fbL+8gzijqp4An/2z52UHqRiCiAvKhNzAwIF+D7J/xC8uqbJDmtIUAAs4Eli5dunHjxpdffvmll16SFdp77rnn7LPP3rx582uvvRbwDjhn/aa0PwKyniZ57CsPXj70yNrhR69/Z+tN8sJ4ypvyIxbc/IFXstZq0UKoKDmddBoBBBCoJEAqS1wggIACAn/0R390//33v/766/v2afcFkcOPly9f/pWvfEVWaxXoPV30SGAkOy3rsR8+a2F5ffKm/EgKeNQU1SgvUC1aCBXlp9a3AfT19flWNxUjgIAvAqSyvrBSKQII+CEgB5Ocf/75//AP//Bf//VfcibtkSNHLtYfX//61+VQZD9apE4EEEAAgYQIcOH9hEw0w4yTAKlsnGaTsSAQIQFfd2/L6bIf//jHH3744bfeeksulfzqq6+ec845l112mZxYe/r06SgopD75Qv559wupu//deNrpmFyN1rggbVgPueCT+azRh9StTxnPWmVueTJ1y5MeDmRJep6c6PjLI5Pldf7irYnJEzNSwMPmgqwq9ckXy2PGTgfk1rLxCBgJFfNpZ+B1y1SLFtVDpe7AKYAAAggkR4BUNjlzzUgRCFpAFlFLHtZ93vK68QLNzc2XX3759u3bx8bG5LrHn/vc5yS5DXqc1dvL/Vtvbqs8/4c8pVTdbFbSEikmF6RtcAhyPx53t+SRa9JqHdi11rwgrbuepG75tjzdbVtjK7mNilzb6cLNB+SKTR+4Z897794tL4znhZsP3n/jctXvs6IFTCFmkhYwWuA9eYs8tYHf8q3Gg6datMQjVBr3oQYEEEAgBgKksjGYRIaAQBQFJFOVKzOVPEpS2cYLvPvuu88999ydd965ePFiWZX96le/KleHiiKHCn0y89i6nU3dVmsxVs9JbpZn3XpcFJBrFA9/Y61cjnjXX3187pwmeWE8f/PI2r++9hwXFbKJawGvAsbY62Eksd4+KkYLoeItcpxq4wDjOM0mY0mIAKlsQiaaYSIQKwE5ivjw4cOf+cxn5E4qcoDxBRdc8LOf/ezQoUNyw54at+qJDkHq7u+n7jKez8vT6JixJKu9KBxgnNpwSH8e1J6F+8qm7jxQeD6XuvO58kGZ67H6TWW/m69z/bMp7bkvtU57RofCRU9ktU1uq3NuZ6scbLx08Xx5Lc8a67HjU+8enZpW99hjLSQkYPIxYztgNuRvRGwJGImcigGzvxAkEjDPWgImf19ZpQOmPFriHSoufqHYxBSQf03QQAABtQRIZdWaL3qLgDICfuzellVcuQ3P5z//ebklz7333it5rHGfHrlhj9y2J4I02tmPhXNlpXuFw4y/r73edqn+XKUnsVo2m9uWP67YOMBYkljtze2rc9vXyFN7p5DNGiPN7bhCnuWjzj1+Vb5A/1W5fu21kZ/k+q/O9V+T23mN9k6lbDa36zp55jOZ2/dqm+y6vrz+1G1Paz/61o3hgrel5606f+nGf/3hxLGZGj2Znjm1afuPV553phLHHlvPry4NmK2NB8zlVQLmSkvAXG0JmGssAfOdCpHmUcBY1/CNk6tzT97qbXTZiRa1QsVbH2pDAAEEFBUglVV04ug2AlEX8Hb39q9+9asvf/nLcgOe6667TtZd5ZY8cmOev/mbv/nQhz4UZQjjvMd8nqCfLms+zFXZ2v03V2VLiuV2XO7fwOWyT3oeu7ZqHvtEyHms0bHHPnPxkaPHO+952jxjtvxFx927fz85ve2zl/jH5WHNxrmylQOmsCob44Ap5LHeH2lsJ1rUChUPo46qEEAAAXUFUrLKIVdeka9BjmFoaKinp0e+BtkobSGAQJACnnywyO125KLEO3fulLvv3HLLLevWrZNb79Q4hFg+Vbq7uwcHB12MVDpsbjU8PHx174qhLSss9RR+qv13tuTs6+L35YK0WjYoaYn+vnHBJ31VVl7nV2X1youqslz2KWWuyubL5Aum5HhRrSotldXfKrxv7apxjLGxJKu1WFiV1UrL//Ql2dzOa4tGZ46vcOWnfPdmO6iPRF+SLXnkvnXT7DsWxqJzIC3vF43a1vu15nPy+Mxo9dvJys1mZUWu4vaS9+7YvV/W9uWnLQta2tvbdSzrjDiII4mZSy9ebokZSz1Vx2iZPzNg9PdkMb8QMPmrheW2XmrEUtFEz14nrCxgCmWNxfzCvo/KMZO6QzvGWA8YvY18wGgL+JUCxlrJe4rPmNUCrPCwEzCz5YvPmLXWUzzqipi2Z61GtNQOlf49Bzo7O6Ur6XS6o6OjdmR0dXX19/fbL+8gzijqp4An/2z52UHqRiCiAvKhNzAwIF+D7J/xC8uqbJDmtIUAArYE5HLEjz322KpVq84991y50c4Xv/hFuS6x3HrnYx/7mBKnwtoapPn3vuV02RobSkJScoCxo1ZsFq57IZ/cEzfozxvNA4xDP9J4oX7qbLVntTzWJkgEi1nPr64VMJbzq/0bhauAsez4MH8LfLvyU8nYa0RL/ELFv3mnZgQQQCAiAqSyEZkIuoEAArMCksQ+++yzn/rUpySD3bZt25o1a+bMmaM0kPVmPNrymnZ+bP6yT/LaOGO25CFnyWrFCpd90ort0M6YtfMwTpc1L/skZ8nq3+Yv+6RVpZ8xW/Iw0hKt5OytZffk37ltT8X1WGsNqVt3y9NO9yhTV6BCwFgOMPYzYPKnVesBk7/skx4w1jX8fPe9CBjt2sXmfZsst5b14GY8dZEpgAACCCCgugAHGKs+g/QfgYgKhHKkVnQOMK524HHx+9qf8Zb5q3rAsJ5f5pNKu+WrbVJ8/GehttLjQp28XzwKWwcM2zn41uWBvvZ/HyJ1gLHebWcHsdsr7zTGnAZkWf2hBJjtA4zth4e1pIQKBxi7o1NrK7laoR8XLFQLgd4i4EKAA4xdoLEJAggggAACCCCAAALeCJDHeuNILQgEKMABxgFi0xQCSRLo6+tL0nAZKwIIIIAAAggggECgAqSygXLTGALJEWD3dnLmmpEigAACCCCAAALBC5DKBm9OiwgggAACCCCAAALREmAPbLTmg94gYEOAVNYGEkUQQAABBBBAAAEEYi2QyWRiPT4Gh0AMBUhlYzipDAmBKAiwezsKs0AfEEAAAQQQQACBuAqQysZ1ZhkXAiELsHs75AmgeQQQQAABBBBAINYCpLKxnl4GhwACCCCAAAIIIIAAAgjEUYBUNo6zypgQQAABBBBAAAEEEEAAgVgLkMrGenoZHAIIIIAAAggggAACCCAQRwFS2TjOKmNCAAEEEEAAAQQQcCLQ19fnpDhlEUAgfAFS2fDngB4ggAACCCCAAAIIhCvAhffD9ad1BFwIkMq6QGMTBBCoL8Du7fpGlEAAAQQQQAABBBBwK0Aq61aO7RBAoKYAu7cJEAQQQAABBBBAAAH/BEhl/bOlZgQQQAABBBBAAAE1BNgDq8Y80UsELAKksoQDAggggAACCCCAQNIFMplM0gkYPwKqCZDKqjZj9BcBRQTYva3IRNFNBBBAAAEEEEBASQFSWSWnjU4jEH0Bdm9Hf47oIQIIIIAAAgggoK4Aqay6c0fPEUAAAQQQQAABBBBAAIGECpDKJnTiGTYCCCCAAAII+CTw2GOPna0/tmzZYjYhp12kyh7WczEoYFiF5eBTMFAtAgj4J5DK5XLyuSpf/WujvOahoaGenh75GmSjtIUAAkEKBP/BIqOTT5Xu7u7BwUEXI5UOm1sNDw9f3btiaMsKSz2Fn2r/nS05+9rN+5Wqytdd1oTT92frLq5q9juv3i8ehYWxCKqh913MZ/1Nuu7du2P3/mXLlknRlgUt7e3t2kiK+lm/EmvMXHrxckvMWHirjt3DWKoWk05jzGngldUfSoC5nTWbEyyh0r/nQGdnp5RPp9MdHR21N+zq6urv77df3mY3KOa3QCj/bPk9KOpHIAAB+dAbGBiQrwG0ZTZh/MKyKhukOW0hgAACCCCAAAIIRFGgr68vit2iTwggUF2AVJboQAABBBBAAAEEEEi6ABfeT3oEMH4FBUhlFZw0uoyACgLs3lZhlugjAggggAACCCCgqgCprKozR78RiLgAu7cjPkF0DwEEEEAAAQQQUFqAVFbp6aPzCCCAAAIIIIAAAh4IsAfWA0SqQCBYAVLZYL1pDQEEEEAAAQQQQCB6AplMJnqdokcIIFBLgFSW+EAAAV8E2L3tCyuVIoAAAggggAACCOgCpLIEAgII+CLA7m1fWKkUAQQQQAABBBBAgFSWGEAAAQQQQAABBBBAAAEEEFBRgFVZFWeNPiOAAAIIIIAAAggggAACiRYglU309DN4BBBAAAEEEEAAAQQQQEBFAVJZFWeNPiOAAAIIIIAAAgh4KdDX1+dlddSFAAL+C5DK+m9MCwggoJrAokWLRrMnp2dOq9Zx+mtXYHzq3aNT04sXL7a7Qb1yxEw9IVV/boRKW1ubqgOg37YFuPC+bSoKIhAVAVLZqMwE/UAgZgJK796WDOey8xZv3PXmxPGTMZsXhiMC0zOnNm3/ce/ypQsWLPAKRFIdYsYrzOjU40eoRGd09AQBBBBQXSCVy+VSKe1rkCMZGhrq6emRr0E2SlsIIBB7AflU6e7uHhwcdDFS+SS0bjU2NrZx7Z+88PPxtgVzXNRWfZOiVjyt2aysZhPetO9NLTWH72MTo9np1X981v0P721tbTX60LKgpb29XV6UhIH9CZINjx49+hdrzolbzHgzD97UEvyvlREqD3xjnxkq6XS6o6OjdmB0dXX19/d3dnZKMTvl7YcZJRFAAIEICsiH3sDAgHwNsm9GAksqG6Q5bSGAgL8CHqayRkez2ezo6OjkxOSJEydqdd3tH+qp97jf0jVl8I26b1FLLt0MtHaLCxculOOBrfV6ksqaMTMyMiK7Qo4fO263667GqNu439Ju35JdTuKkJFTspKaksopGjRxgzDHGis4d3Q5XgFQ2XH9aRwCBmAh4nsoaLhMTE8emjpHKNpA3uc24/Elly6dSy1dateS2kVVZa7WyQpudzNr9vXLLE0oqG0qjdiX9LydnH9Q9xZpU1v958KWF4I9S9GUYVIpA4AIhprKcKxv4bNMgAskQiNO+7ZaWllST22wjGdOt9Chlcue3zPd2CLLwS8x4SxqF2pqamjw8vzoKI6IPCCCAgNICHGCs9PTReQSiKxDK7m2fVmVF+eTJkyeOnzh16lRlcbd5rvs1QNcrpNrKo8uwUai39rvalGpKL0zPmZM/I9r+hiWI5RvOzMwcO3ZMIqcut/tG3c9l3U5VLeC+t8Wno7vvQUhbSh4reyiam5vrts+qbF2iaBYI5Z+taFLQKwQcCYS4Kksq62imKIwAAnYFQvmbwL9Utvawg//j3nWLWibrNqMIfkPXvQ2+q65bdD3GUDYMq1G7nzvRKEcqG415cNyLUP7ZctxLNkAgegIhprIcYBy9cKBHCCCAAAIIIIAAAggggAACNQVIZQkQBBBAAAEEEEAAAQQQQAABxQRIZRWbMLqLAAIIIIAAAggg4LlAX1+f53VSIQII+CpAKusrL5UjgAACCCCAAAIIKCAQpwvvK8BNFxHwQoBU1gtF6kAAgTKBUHZvy81Bx8bGpqenmRAEEEAgFIHx8XG5q3BbW1sordMoAgggkCgBUtlETTeDRSA4gVB2b8ufjytXrty8efPExERwQ6UlBBBAQBeQ/WibNm3q7e3l9rNEBAIIIBCAADfjCQCZJhBAIDgBWQ9Zv3794cOHW1tbHbXayM1UHDVE4QAEmM0AkGmiXGB0dHT16tUPPPCA+fmTTqc7OjqwUkJA9sCGshNWCRw6iUANgRBvxkMqS2QigEAMBbLZ7MjIiPxZOTU1FcPhMSQEEIikgJzjIA9r10hlIzlRlTvFfWUVmiy6GikBUtlITQedQQABDwSisHtbUlmONPZgLqkCAQTcCizWH263ZrtABUhlA+WmsRgJhJjKcq5sjOKIoSAQJYFMJhN6dxYuXNjUxKdc6PNABxBIqIB8/nDSbELnnmEjgEAgAhxgHAgzjSCQPIGI7N6emZmRY4xPnjyZvBlgxAggEKaA5LGyN625uTnMTtC2E4GI/LPlpMuURSASAiGuypLKRiIC6AQC8RPgb4L4zSkjQgABBGIswD9bMZ5chuarQIipLIfe+TqzVI4AAggggAACCCCAAAIIIOC9AKms96bUiAACCCCAAAIIIKCWQF9fn1odprcIIEAqSwwggAACCCCAAAIIJF2Am8omPQIYv4ICpLIKThpdRkAFAXZvqzBL9BEBBBBAAAEEEFBVgFRW1Zmj3whEXIDd2xGfILqHAAIIIIAAAggoLUAqq/T00XkEEEAAAQQQQAABDwTYA+sBIlUgEKwAqWyw3rSGAAIIIIAAAgggED2BTCYTvU7RIwQQqCVAKkt8IICALwLs3vaFlUoRQAABBBBAAAEEdAFSWQIBAQR8EWD3ti+sVIoAAggggAACCCBAKksMIIAAAggggAACCCCAAAIIqCjAqqyKs0afEUAAAQQQQAABBBBAAIFEC6RyuVwqpX0NkmFoaKinp0e+BtkobSGAQJACwX+wWEd39OjRiYmJIMdLWwgggMCSJUvS6TQOigqE+8+Womh0GwER6OrqGhgYkK9Bahi/sKSyQZrTFgIJEgjrbwJJYjds2PDiiy8uXrzYEbd02FF5CkdZgNmM8uzEuG/y+dPb27t169a2trYYDzOuQ5OrFXLBwrhOLuPyVYBU1ldeKkcAgRAEwkplr7zyyjPPPPPBBx+cO3euo2E3kvy43jb4DcUk+EZdt+i6t65bDH5D12MMZcOwGnX0uxxiYTkY5L777hsZGXnqqadC7AZNI4AAAkEKhJjKcq5skBNNWwgkSKCvry/40Waz2cOHD8vFk53mscF3lRYRQCB+AosWLXrooYcOHTo0NjYWv9ExIgQQQCBqAqSyUZsR+oNATARCOUxLFkNaW1vlr8mYIDIMBBBQTWDevHnt7e3j4+OqdZz+IoAAAuoJkMqqN2f0GAEEEEAAAQSiLDA6OioLszMzM1HuJH0rEQhlDyyzgAACjQiQyjaix7YIIIAAAggggECpwNTUlKSyR44cIZtVKDjk5BSFektXEUBABEhlCQMEEPBFgN3bvrBSKQIIqCNw+vTpyclJdfpLTxFAAAHFBEhlFZswuouAKgLs3lZlpugnAgj4JyDZrH+VUzMCCCCQcAFS2YQHAMNHAAEEEEAAAQQQQAABBNQTIJVVb87oMQIIIIAAAggggAACCCCQcAFS2YQHAMNHAAEEEEAAAQQQQAABBNQTIJVVb87oMQIIIIAAAggggIC3An19fd5WSG0IIOC3AKms38LUjwACCCCAAAIIIBB1AS68H/UZon8IlAmQyhIUCCDgiwC7t31hpVIEEEAAAQQQQAABXYBUlkBAAAFfBNi97QtrMiptsTzmFx7m0M13yn8kZYw3/6DwqA1mFjNehKXbrD/Cap12EUAAAQQQUFSAVFbRiaPbCCCAQMwFjumP4/rDyFHNr8abJT+y/vSE/pB3aiSoxo+MknUL17Weqz/qFqMAAghEVoA9sJGdGjqGQDUBUlliAwEEEEAgDgJGrmvkvcajRoJq5rElhefNmxcHC8aAAALOBTKZjPON2AIBBMIUIJUNU5+2EYixALu3Yzy5IQ7NXKE1Elcjd7WmryV9M1dc7fRZCk9PTxslJae1Piq+aea95gtzbdZ4YT6MzSu+aadjlEEAAQQQQACBcgFSWaICAQR8EWD3ti+sSarUOGHWOPfVSFlLclfzR56rGKmppLXGw8hsra2UvG8mwO/qD2tJ8x3j8GPjW6MMByR7PnFUiAACCCCQKAFS2URNN4NFAAEElBGwnitbvu5afqJsxYE5up6TFLZzgLGZuNalLElr65anAAIIIIAAAgjYFyCVtW9FSQQQQACBkAVKVmKtV4QKuWc0jwACCCCAAALBCpDKButNawgggAAC/giUp7Xl13YyWy6/IpRR2P6Kqz+DoFYEEEAAAQQQsCtAKmtXinIIIIAAAqELWC/7VPE0WumheV9ZeW2krBUfZjZrHoRsFjbPjzWu/GQnxTVPf612Bqy1gHnebOiedAABBEyBvr4+NBBAQC0BUlm15oveIoAAAvEXMM6SrTZO601lyy9fbLxjvVtsDS+zWPmFjs1rPplXeDISWuuybcm31ks6lV//STY3C5T8dEZ/xH9eGSEC0RbgwvvRnh96h0AFAVJZwgIBBHwRYPe2L6zJqNS4drH1CsbGAqz9h7HQ6uJRcg8e+9+W3GjH0bfNxY9kTDKjRAABBBBAoFGBVC6XS6W0r43W5GT7oaGhnp4e+epkI8oigAACdQTkU6W7u3twcNCFlHwSutjK2MT1tsFvmJDeBg/rusWEzEgjw3T9ixnWhl1dXf39/Z2dndKBdDrd0dERVk9oFwEEEAhAQD70BgYG5GsAbZlNGAksq7JBmtMWAggggAACCCCAQBQFOMA4irNCnxCoKUAqS4AggAACCCCAAAIIJF0gk8kknYDxI6CaAKmsajNGfxFQRIDd24pMFN1EAAEEEEAAAQSUFCCVVXLa6DQC0Rdg93b054geIoAAAggggAAC6gqQyqo7d/QcAQQQQAABBBBAAAEEEEioAKlsQieeYSOAAAIIIIAAAggggAAC6gpwMx51546eIxBpgeDv8iUcnt+MZ2xsbGJioi606xuxBL+hjCX4Rl232Ehva8zakiVL5BYpFQu47qrNUPG2Ude9db1hIzPSSKN1fwe9LVAjQuw0xM147ChFsEwo/2xF0IEuIeBUIMSb8ZDKOp0syiOAgC2BUP4m8DCVlczkL2/46PfeGGtPz7E1YLuF3N+91m4L76nZhDfte1NLzRH52MTRqene5Usf+c4rbW1tJX1wkW4dPXr0f155XtxCxRt+b2qpHid+1W9EyNaDPymPEDu/hqSydpQiWEauVsgFCyM4L3Qp+gKkstGfI3qIAALOBFRPZTes/NDS1rkPrfvQ3DnGiRiFP5q1/1r/gG7k/UpV5esra8Lp+7N1F1c1+51X7xePIlUJRyvSyPvOYq9u6YljM/dte3UkO73zxV80nsrefNFZllCxDLPqkD0MoWqh6DS0nMZbWf2hxFWRcN1pd1DAjJCnXhp2sFmhKKmsCzQ2QQABdQVCTGU5V1bdsKHnCERaoK+vL9L9q9m5bDb7ws/Hv3rzBwt5rLpDoecVBBa1ND/05xcc+s8jsvbeIBCh0iBgNDf3MEKiOUB6hQACCMRDgFQ2HvPIKBCInIDSh2mNjo62LZizaL63hxZHbo6S3KF5zWe0p+eNj483iDAyMkKoNGgYzc29ipBojo5eIYAAAvEQIJWNxzwyCgQQQAABxwKSyk6MT8zMzDjekg2SISB7tWTpnghJxmy/R+k9sAmZI4aJQIkAqSwhgQACCCCQUIHjx47LFap/97vfnTx5MqEEDLumwNTUlKSyR44cIZtNQqRkMpkkDJMxIhAnAVLZOM0mY0EgQgLs3o7QZMS6K0ez00PvZKs9s8frr7jmTueyk9lYIyV9cA0GyenTpycnJ5OOyPgRQACB6AlwM57ozQk9QiAWAkpfwXh4ePjq3hVDW1ZYpqKRKxV7dZlZ6Y7tK83OlvXqSsXV6inuVUNXKq52+d/KvxKSn/zpP738/E/elrNeq/3SyF1VVp535rbPXtJWVqbr3r07du9ftmyZbNuyoKW9vV0bicOL4sr9n1Zd8hFLqHAFY6/izUZc2ZisRoJEIqR/z4HOzk7pityIuKOjw+ZnM1cwtgkVtWKh/LMVNQT6g4ALAa5g7AKNTRBAAAEEEi2w4aGX3tf6ByNbbxp6ZG21528fvWHp4vl/9s//kWipBA+eIEnw5DN0BBCIvwAHGMd/jhkhAgggECcBOWZYDid+4zdjLwy+/dkr/9uRsePybbUDiY27qnzvtSNjU+/GCYGx1BYgSIgQBBBAIAkCpLJJmGXGiAACqgqkNhwyup6686D+9YDl+VzqzudqDCy1/rsVf5paty9f57rvVNs8dfvefJnb9kTK7mvP/PQP793b87fPX/GlF+bPnXPVV16U1/KUN+VHFbuav6vKsXimsrMRskGPkA0HJVT0Zz5Uqk7xHfs9nNlUIU5Stz3tYbXuqiJI3LmxFQIIIKCcAKmsclNGhxFAICkCkqXktq828pPcjjXGsHM7Li88r8jtuCJ1R61s1rVUbtdaI5vNPXG9maW4rs2rDWWp7StPvfHKg5fL4cTDj17/juXQYnlTfmTnIk9edSYK9VgiRELFjJA1Ei1mnEhO23hXU9X3euTDshAnuSduCDebJUgan+7E1tDX15fYsTNwBBQVIJVVdOLoNgIIxFygKI8tZCnejjm389oaFerZrLYkG51sdiQ7vWh+84fPWljebXlTfiQFvCWKcm2pDd8r7OnI7/Jw1Nvc41c6Kl+3sBkn4WazBEndmaJANQEuvE9sIKCcAKmsclNGhxFQQ4Dd243MU8XVthoVpooPFk3dkT+0WI4xTq1/Vp4VtzWX2lLrnkndnn9aS+Z25Zdk9Swl/ANHGyGN2bapuySPvUwGZYZK7QEax6LLGr4ZKsYLM1S013qcpNbv057rtKdRpxEnWpCseyb/jhYte41nUcAU4iTcbDZmc81wEEAAAQSqCZDKEhsIIOCLALu3XbPWXm0rOVc29/gVNRrK9V+V679antWyWSNRye28Lrcr/6yUnBhrsyEfOCp9WJKeN3F85pdHKtzh8xdvTUyemJECrtkV2lDLY7dVzWNLzpWVI43z+ecdz0m01F2MzfVfoz13ak8jiTVW77Ug2XmdFjC3P6NHy1rjWRYw+TjRA+ap4FUJkuDNaREBBBAIS4BUNix52kUAAQQqC8hqm3EtHzl81Lyoj1m05FxZzxElObHWKSfKypKslsDc9rQkJ54356jC9Pzm+28878LNB+SGnx+4Z897794tL4znhZsP3n/jcingqEJFC0seK9ls9QgpOld2NnJq7vUomvTiVdlyJX0Nv8KqrDVO9IC5MXhhgiR489i0yB7Y2EwlA0mOAKlscuaakSKAgDICZhKrv9CuTBvKQ86VLeSx8iLkPNYQuO+6c4e/sXbgy6t2/dXH585pkhfG8zePrP3ra88JRSmURrVsdkPVbNZ+l3KPX2Vc6VrW7WX1Xn+xz1yVrVaPdVXWuu9D3/GhxUm4Oz4IEvsBQEmrQCaTAQQBBNQSIJVVa77oLQLKCLB7u8GpsmSzaxxls9azH130YfY2PLfvlXNl9bQkn9C6qM2PTWTZreu96c4lLXPOaJIXxjMh67FWz9qr937IV6zTet+mSC3gEySBxQANIYAAAmEJkMqGJU+7CMRcoJHd2x/96EdXr1790EMP/frXv445U83hFWWz+n1lqz3kBEi5io/xlHU2s5h52Sdjwa3iQ86EtF72yVhkk/wk/yJieaz0Te62MvRO9rcjx06eOi0vjGfSbsNjTKUnq/dyQrW5JKvV2X9NyWWftDeNINEv+yRLstYDjEviJNz1WDPCCZIkf3IydgQQSI5AKpfLpVLa1yDHPDQ01NPTI1+DbJS2EEAgSIFGPlgmJycPHTq0b9++/fv3v+9977tGf1x00UVnnHFG7SHIp0p3d/fg4KCLkUqHza2Gh4ev7l0xtGWFpZ7CT7X/zpacfe3m/UpV5esua8Lp+7N1F1c1+51X7xePwsJYBNXQ+7Pz8LVnfir3j5X77sg/W8ffPdUyb47xM7kclJxGK0eWVpx6OZlWDkKWZTrrT+XNHbv3L1u2TN5sWdDS3t6ujaSon/XjSEJu1SUfsYSKRbXqkD0MoWqh6DS0nMZbWf2hxFWVyfIqSCRC+vcc6OzslNGm0+mOjo76AaGX6Orq6u/vd7Ghzfop5pNAI/9s+dQlqkVACQH50BsYGJCvQfbW+IVlVTZIc9pCAAFbAgsXLrzxxhu3bt165MiRb37zm/Jpde+99y5duvSuu+7avXv3xMSErVooFDsBWWqTPPaVBy8femTt8KPXv7P1JnlhPOVN+VEy12ZjN88NDYggaYiPjRFAAAGlBEhllZouOotAwgRkGfaSSy75u7/7O1lofeWVVy644ALJbGUZjcOPExYI+eGOZKdlPfbDZy0sH768KT+SAsmUYdSmAEFCMCCAAALJESCVTc5cM1IE1Bb44Ac/+NnPfvbgwYNvvfWWLNL+6Ec/uvDCC5cvX/6FL3zhBz/4walTp9QeHr1HAAEEEAhVoK+vL9T2aRwBBBwLkMo6JmMDBBAIV6DG4cdybu3p06fD7R6t+yewJD1Pzon95ZHJ8iZ+8dbE5IkZKeBf69SshABBosQ0RbOTXHg/mvNCrxCoIUAqS3gggIAvAp/4xCfkHNeSh/UPBXndYIEvfelLH/vYx/7+7//+9ddf//3vf799+/ZPf/rTsmbry3gcVpr65Av5590vpO7+d+Nppw65Wahxv9CwHnLtYvNZow+pW58ynrXK3PJk6pYnPRyI3HFHru104eYDcj2eD9yz571375YXxvPCzQfvv3G5crfkSX3yxfJQsSOWuismcSIRYj7tDLxumfgFSd0hUwABBBBIrABXME7s1DNwBOIgMDMz8/3vf3/nzp1yueMVK1bIObT/+I//+MYbb7gYm7dXMJYURfqQ+7de/WrH+v/1VDa39dJ83ypdkVjyE63M9ssqXCTZyRWMjVvLyk1W9LYcXKlYbrKibVi4H4/2+gnt1rLl9aRuyyexuW/dWH6l4tQt3zanIPfkLXovKl1r1+77RfMp1/WR8yHlZjy3fO3wD/5+tfEzWYurkcdG9grGs3FSCJNCnPyPGhfHrhUnsxNe/6LEcuumQpzUL5zvj17QVZzcZJnFlBGVRpwYEWLs9ch9+9aiYuY3FeOn+uWmPQkSrmBc9IvHNwgggEAVAa5gTGgggAACDgTkKOLDhw9/5jOfkUtAyQ1s5XJQP/vZz+T+PTfffHNTEwebOJC0FrXmJ7WrMPPYasVyT94sT5f9qLeZpKxyW51zO1vlYOOli+fLa3nWyGPHp949OjXNscf1XO3+3Ks4seaxdtu2XY4gsU1FwVkBDjAmGhBQToC/+ZSbMjqMQHIF5AZir7322uc///mzzz5brvwkeezLL7/80ksvbdy4UW7Vo5BL6u7vp+4yns/L0+i5sdSmvSgcYJzacEh/HtSedx7M//TOA6n887nUnc+Vj9pYktXqWf9deRZeP5taL899qXXaUyGral1tS89bdf7Sjf/6w4ljMzWGMz1zatP2H68870zljj3WZlDiJB8qtuNkQ3mcSMBUjBNtSbYQJ89a4mRfbOIkCUESg9/l6AxBdoxGpzP0BAEE7AhwgLEdJcoggEDIAr/61a926Y+pqanb9cdHPvIR6yHBRv+Ghoa6u7vlzj0uuuvHAcYl3cht1Y4aleRE3s9tM440ThmpbG7bKv317AHGksRq72+XA2j145P1FCW343LJY41qczuu0Cswvis6QLTkAGNJYrXy/VdrxeR/eiqb23mtpXv5Az7NquR0Wa3MrustFRdauu1p7UffutE4UbbiAcb5PlkOH/XwAGOz20ez03c99NKLb/y/tgVVr/Y0mp2+7L+f9a+fvkiympLpkMNHd+zeLztE5P2WBS3t7e36fFglS7ao8K2E3KpLPjK0ZUXhZ5bNqx5TbZk2/UD0koceJ5Yj0vX5dxgna8x9HxIz1mODraFScoBxIU6uMQKqLE6MY4LNzurdchAnFQ4wno034+jiJ28tCmTrNw4PMPYkSDjAuP4vQLxKyK+/7DCN15gYDQJBCHCAcRDKtIEAAsoJHDly5Otf//pFF10kd5d9++235aayb775plzn6fzzz3eacoQydjlXNre112jayE9m84DCqmztjpmrsiXF9PzEr0chP1lb3kDKyGOfkPNjw39IdvqdL6z8v9+8YeDLq6o9hx9Z+/Tnesrz2PB7b+mBFidyWnXFOCmsysY4TvJnyRrnVHv9iE2QeA1DfQgggEAcBDjAOA6zyBgQiJnA2NjYY489tmrVqnPPPffVV1/94he/KNclfvjhh+V6xSqeCmtdZDNnSlZl9ecq41ltBmVVNrd9jfbcoT0DmOgaeazZupwra167uPZFjAPo8EL91Nlqz4gnsVYfY69HyZWu5TphzuJED5UA2J3Hye6KvfI1jzVbjE2QBDCzNIEAAggoJEAqq9Bk0VUEkiIgSeyzzz77qU99SjLYbdu2rVmzZs6cOXEdvPV02RpjlONFzUNG/aOoe0Wf3BM36M8b9eOKtYf5wr9eUbOW4lpOq64VJ5bTqv1zcxUn1gOM813z9cpP/g2fmhFAAAEEIiJAKhuRiaAbCCAwK/DDH/7w6aefvummm+bPnx8Pl9KzH7XMJH/ZJy0brLQqq58lK6fI5i/7pBWzvdqWe1y7DY952Sf9LFn5Nn/ZJ62qnfr5kMUPIz/RSs7eWnZP/p3b9hiHFtd4pG7dLc94zFdYo6gQJ5YDjP2ME/NsaomT/GWf9DixnlCdV/EiTrR78Jh3bLLcWvZbYcnTLgIIIICAigJc9knFWaPPCCBQWSA6l32avTxO4b6yhR4XLpvj5D6xen6ZTyotI7dehqfSXVsrblJ82Z7ZXrl/f7Zzej8buX9stWsm+RLwUbjskz4wa0hUm0en7xdPSv4urjVCyNl9ZYu6bQzBffwUN1101a1619ByeI0up2HEZZ+ciqleXm7Gw/14VJ9E+h+KAJd9CoWdRhFAAAEEEEAAAQQQ0ATIY4kDBJQT4ABj5aaMDiOAAAIIIIAAAggggAACSRcglU16BDB+BBBAAAEEEEAAAQQQQEA5AVJZ5aaMDiOAAAIIIIAAAgh4LMABxh6DUh0C/guQyvpvTAsIIIAAAggggAAC0RbIZDLR7iC9QwCBUgFSWWICAQQQQAABBBBAAAEEEEBAMQFSWcUmjO4igAACCCCAAAIIIIAAAgiQyhIDCCCAAAIIIIAAAggggAACigmQyio2YXQXAQQQQAABBBBAAAEEEECAVJYYQAABBBBAAAEEEEAAAQQQUEyAVFaxCaO7CCCAAAIIIIAAAp4L9PX1eV4nFSKAgK8CpLK+8lI5AggggAACCCCAgAIC3FdWgUmiiwgUC5DKEhEIIIAAAggggAACCCCAAAKKCZDKKjZhdBcBBBBAAAEEEEAAAQQQQIBUlhhAAAEEEEAAAQQQSLoABxgnPQIYv4ICpLIKThpdRgABBBBAAAEEEPBUIJPJeFoflSGAgO8CpLK+E9MAAggggAACCCCAAAIIIICAtwKkst56UhsCCCCAAAIIIIAAAggggIDvAqSyvhPTAAIIIIAAAggkSuCxxx47W39s2bLFHLicipkqe1jPz6SAYRWWwyc+8YlERSmDRSAGAqlcLiefq/I1yMEMDQ319PTI1yAbpS0EEIi9gHyqdHd3Dw4OuhipfBKaWw0PD1/du2JoywpLPYWfav+dLTn72s37larK113WhNP3Z+surmr2O6/eLx6FhbEIqqH3Xcxn/U267t27Y/f+ZcuWSdGWBS3t7e3aSIr6Wb8SCblVl3zEEioW1apD9jCEqoWi09ByGm9l9YcSVw4nq/50FpeQCOnfc6Czs1PeTqfTHR0dNmvo6urq7+93saHN+imGAAIIREpAPvQGBgbka5C9MhJYVmWDNKctBBBAAAEEEEAAAQQQQAABDwRIZT1ApAoEEEAAAQQQQAABBBBAAIEgBUhlg9SmLQQQQAABBBBAAAEEEEAAAQ8ESGU9QKQKBBBAAAEEEEAAAQQQQACBIAVIZYPUpi0EEEAAAQQQQAABBBBAAAEPBEhlPUCkCgQQQAABBBBAAAEEEEAAgSAFSGWD1KYtBBBAAAEEEEAAAQQQQAABDwRIZT1ApAoEEEAAAQQQQAABBBBAAIEgBUhlg9SmLQQQQAABBBBAAAEEEEAAAQ8ESGU9QKQKBBBAAAEEEEAAAQQQQACBIAVIZYPUpi0EEEAAAQQQQAABBBBAAAEPBEhlPUCkCgQQQAABBBBAAAEEEEAAgSAFSGWD1KYtBBBQQ2DRokWj2ZPTM6fV6C69dC4wPvXu0anpxYsXO9+0aAtCpUHAyG5uREhbW1tke0jHEEAAAQRIZYkBBBBAoFRAMpzLzlu8cdebE8dPohM/gemZU5u2/7h3+dIFCxY0ODpJdQiVBg0juLmHERLB0dElBBBAIDYCqVwul0ppX4Mc0tDQUE9Pj3wNslHaQgCB2AvIp0p3d/fg4KCLkconoXWrsbGxjWv/5IWfj7ctmOOituqbFLXiac1mZTWb8KZ9b2qpOXwfmxjNTq/+47Puf3hva2ur0YeWBS3t7e3yoiQM7EzQ0aNH77n83LiFijf83tQS/G+TESEPfGOfGSHpdLqjo8NOPEiZrq6u/v7+zs5Oee1oQ5v1UwwBBBCIlIB86A0MDMjXIHtlJLCkskGa0xYCCPgr4GEqa3Q0m82Ojo5OTkyeOHGiVtfd/sWeeo/7LV1TBt+o+xa15NLNQGu3uHDhQjkw2FpvI6msUc/U1NTIyIjsATl+7LjjHrsao27jfkvHnUzSBhIeJRHiKCMllU1SsDBWBBDQ9t+RyhIHCCCAQKMCnqeyRocmJiaOTR0jlW0gb3KbcfmTypZPpZa4tGrJrYtVWaM2Y0NZoc1OZh3HsVueUFLZUBp1TOr1BnLSgf0zq0llveanPgQQiLRAiKks58pGOjLoHAIIREGgpaUl1eQ224jCAOhDTQGZ3Pkt8z1BkvVeQsUTyUhV0tTU1Php1ZEaEZ1BAAEE4iHAAcbxmEdGgQACmoBPq7JS88mTJ08cP3Hq1KnK0G7zXPdrgK5XSGUACeitfdimVFN6YXrOnPwZ0fY3LIkEc8OZmZljx45JwNj/nXTfqPu5tN+70pLue1t8Orr7HgS7peSxsoeiubnZfrOsytq3oiQCCMRAIMRVWVLZGMQPQ0AAgbyAf6lsbeLg/7h33aKWybrNKILf0HVvg++q6xZdjzGUDcNqVK3POFJZteaL3iKAQIMCIaayHGDc4NyxOQIIIIAAAggggAACCCCAQNACpLJBi9MeAggggAACCCCAAAIIIIBAgwKksg0CsjkCCCCAAAIIIIAAAggggEDQAqSyQYvTHgIIIIAAAggggAACCCCAQIMCpLINArI5AghESEBuDjo2NjY9PR2hPtEVBBBIksD4+LjcXritrS1Jg2asCCCAQDgCpLLhuNMqAgj4ISB/Pq5cuXLz5s0TExN+1E+dCCCAQA0B2Y+2adOm3t5e7kNLnCCAAAIBCHAzngCQaQIBBIITkPWQ9evXHz58uLW11VGrjdxMxVFDFA5AgNkMAJkmygVGR0dXr179wAMPmJ8/6XS6o6MDKwQQQCDGAiHejIdUNsZxxdAQSK5ANpsdGRmRPyunpqaSq8DIEUAgWAE5x0Ee1jZJZYOdAVpDAIEQBEhlQ0CnSQQQiL2ApLIcaRz7WWaACERZYLH+iHIP6RsCCCDQoECIqSznyjY4d2yOAALRFVi4cGFTE59y0Z0geoZAvAXk84eTZuM9xYwOAQTCFeAA43D9aR0BBPwVmJmZkWOMT5486W8z1I4AAggUC0geK3vTmpubgUEAAQTiLRDiqiypbLxDi9EhgAACCCCAAAIIIIAAAn4JhJjKcuidX5NKvQgggAACCCCAAAIIIIAAAj4JhJPKyvX95HIscvs1n0ZFtQgggAACCCCAAAIIIIAAAr4KjI+Py30QlyxZ4msr1SoPJ5Vta2u77LLLNm7cyMVFQ5l1GkUAAQQQQAABBBBAAAEEGhGQhclNmzb19vbKjccaqcf1tuGcKyvdlfT97rvvfuGFFyStdd17NkQAAQQQQAABBBBAAAEEEAheQA6zXb169b/8y78En9ClUnoaq/1ffxX84KXFbDY7MjISStM0igACCCCAAAIIIIAAAggg4E6gtbU1rFtnRyKVdafGVggggAACCCCAAAIIIIAAAskUMFLZcM6VTaY4o0YAAQQQQAABBBBAAAEEEPBEgFTWE0YqQQABBBBAAAEEEEAAAQQQCE6AVDY4a1pCAAEEEEAAAQQQQAABBBDwRIBU1hNGKkEAAQQQQAABBBBAAAEEEAhOgFQ2OGtaQgABBBBAAAEEEEAAAQQQ8ESAVNYTRipBAAEEEEAAAQQQQAABBBAIToBUNjhrWkIAAQQQQAABBBBAAAEEEPBEgFTWE0YqQQABBBBAAAEEEEAAAQQQCE6AVDY4a1pCAAEEEEAAAQQQQAABBBDwRIBU1hNGKkEAAQQQQAABBBBAAAEEEAhOgFQ2OGtaQgABBBBAAAEEEEAAAQQQ8ESAVNYTRipBAAEEEEAAAQQQQAABBBAIToBUNjhrWkIAAQQQQAABBBBAAAEEEPBEgFTWE0YqQQABBBBAAAEEEEAAAQQQCE6AVDY4a1pCAAEEEEAAAQQQQAABBBDwRIBU1hNGKkEAAQQQQAABBBBAAAEEEAhOgFQ2OGtaQgABBBBAAAEEEEAAAQQQ8ESAVNYTRipBAAEEEEAAAQQQQAABBBAIToBUNjhrWkIAAQQQQAABBBBAAAEEEPBEgFTWE0YqQQABBBBAAAEEEEAAAQQQCE6AVDY4a1pCAAEEEEAAAQQQQAABBBDwRIBU1hNGKkEAAQQQQAABBBBAAAEEEAhOgFQ2OGtaQgABBBBAAAEEEEAAAQQQ8ESAVNYTRipBAAEEEEAAAQQQQAABBBAIUCCXywXYGk0hgAACCCCAAAIIIIAAAggg0JCApLH/H5NYkdvleLYiAAAAAElFTkSuQmCC)

**Figure 1‑1 Target of this document**

![グラフィカル ユーザー インターフェイス, アプリケーション, PowerPoint

自動的に生成された説明](data:image/png;base64,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plTKX+jbphRc5uPFOKueFWcev16WGMg1PsZlPpmv3+BFT+zXOTG7hUrZZxTTKHYGbjdmsrvt2KmwnjJV96DNxkwubFRDZWMmtdSrPWiLRpfAgKlnfjkWAQQQQAABBLwTIJninS01I4BATASKdr6QUZkv81G7YBQ98jun5Dag1U9Bba9MUdumGBvQ5ndOGdl9NrPlmtIW1VmxfuDyXdnnzlT+1shypYa6WKPCQ5YbqPNhHq4ImBc0GbvtqLDRg6FSzOT2Lc7GjL5zip2HZcxkN6DVq7IVM3rY5KJomcSPjZi5UY8ZI3JkcUr+6cKtke0MnDIIIIAAAggggEBQAqlMJpNK6f8Nqge0iwAC9Qis2attf0NbP19bOqueasof6/iHw3nnnffOd75zxYoVV1111fjx4+33rKura+7cuZ2dnfYPMUpKb+V1d3f3VfPmdN03x1SD/r7+0P+ff53/s9P3y1WVq7ukiVrfH6m7sKqRP7n1fuEosoD5h+l1Xe87mMnqh8gGK5t3PDd9+nQp2jChobm5uSgMqldRUkIi55ILZ5six46AixFlFZm1Rlqt4VdSfyBhVhBjDmavyiESMB07d7e2tkq5xsbGlpaWyge0tbV1dHTYL+9+jz2rcdt+be0+bclMbUNuy2zPWgqiYtk0PeH7pgehTpsIIIBAQgXk1IOVKQmde4aNgKcC+/btu+aaax566KGzzjpr9erVu3fvHh62vGmLpz2hcgQQQACBhAiQSUnIRDNMBBBAICQCJFNCMhF0A4EwCqTTaWfdmjJlyq233rp3794f//jHskpF/oEriwg+9rGPfec73zl16pSzOjkKAQQQQAABBBBAAAEEEAiJAMmUkEwE3UAgjAL1f8s3bdq0O+6443vf+94rr7wiq1Ruu+22s88+e926da+//jpXF4ZxyukTAggggAACCCCAAAII2BAgmWIDiSIIIFC3wHve85677rrrRz/60TPP6NthykVAs2fPvueee958882666YCBBBAAAEEtPq/AAARAQQQQAAB+wIkU+xbURIBBOoVkI2azj333L/927/9xS9+ITuqHDhw4MLs4/7773/77bfrrZ3jEUAAAQQSLNDe3p7g0TN0BBBAAAG/BUim+C1OewhESMC7b/lGjRr1gQ984Ctf+cpbb70l//x97bXXzjnnnAULFmzbto1NVSIUIXQVAQQQ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)

Figure 1‑2 Target of this document

## References

|  |  |  |
| --- | --- | --- |
| **No.** | **Title (Document Name)** | **Version** |
|  | Software Architecture Design Specification for IMP Driver | *0.16E* |
|  | Component Architecture Design Specification for IMP Driver | *0.13E* |
|  | IMP Driver User’s Manual | *0.04E* |
|  | R-Car V3x IMP Driver Product Information | *V3M: 2.00E*  *V3H: 2.00E*  *V3H\_2: 2.00E* |
|  | Operating System Abstraction Layer API (OSAL API) User’s Manual | *3.11E* |
|  | xOS3-IMPIMRPAP\_CommonInfo.xlsx | *1.00M* |
|  | Operating System Abstraction Layer (OSAL) API Application Note | *3.12E* |
|  | IMP Framework User’s Manual | *0.20E* |

## Abbreviation

Refer to the “Abbreviation definition sheet” in [6]

## Terminology

Refer to the “Terminology definition sheet” in [6]

# Software Unit Design

The following shows the function detail of IMP Driver.

This design does not use the C standard library. However, in order to use the predefined identifier, it is necessary to include “stddef.h” and “stdint.h”.

The description of traceability ID is given to each unit.

## Functions of API Layer

Table 2‑1: Function List

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **No.** | **Function Name** | **Access** | **ASIL** | **Source File Name** |
|  | R\_IMPDRV\_Init | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_Quit | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_AttrInit | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_AttrSetCoreMemInit | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_Start | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_Stop | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_AttrSetCoreMap | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_AttrSetCl | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_AttrSetIrqMask | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_SetIrqGroup | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_AttrSetClBrkAddr | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_Execute | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_ResumeExecution | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_SetPMPolicy | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_GetPMPolicy | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_GetPMState | Public | ASIL D | r\_impdrv\_api.c |
|  | R\_IMPDRV\_GetVersion | Public | ASIL D | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_RegGetHwInfo](#_R_IMPDRV_RegGetHwInfo) | Public | ASIL D | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_RegRead32](#_R_IMPDRV_RegRead32) | Public | ASIL D | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_RegWrite32](#_R_IMPDRV_RegWrite32) | Public | ASIL D | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_RegRequired](#_R_IMPDRV_RegRequired) | Public | ASIL D | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_SetMemProtect](#_R_IMPDRV_SetMemProtect) | Public | ASIL D | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_BusIfCheck](#_R_IMPDRV_BusIfCheck) | Public | ASIL D | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_ConfRegCheck](#_R_IMPDRV_ConfRegCheck) | Public | ASIL D | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_ModuleStopCheck](#_R_IMPDRV_ModuleStopCheck) | Public | ASIL D | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_AttrSetDsp](#_R_IMPDRV_AttrSetDsp) | Public | - | r\_impdrv\_api.c |
|  | [R\_IMPDRV\_AttrSetGosubCond](#_R_IMPDRV_AttrSetGosubCond) | Public | ASIL D | r\_impdrv\_api.c |
|  | impdrv\_api\_chk\_init\_data | Private | ASIL D | r\_impdrv\_api.c |
|  | impdrv\_api\_chk\_core\_info | Private | ASIL D | r\_impdrv\_api.c |
|  | impdrv\_api\_chk\_instance\_num | Private | ASIL D | r\_impdrv\_api.c |
|  | impdrv\_api\_cnv\_error\_code | Private | ASIL D | r\_impdrv\_api.c |
|  | impdrv\_api\_cnv\_ctrl\_handle | Private | ASIL D | r\_impdrv\_api.c |
|  | [impdrv\_api\_chk\_bus\_if\_check](#_i_mpdrv_api_chk_bus_if_check) | Private | ASIL D | r\_impdrv\_api.c |
|  | [impdrv\_api\_chk\_conf\_reg\_check](#_impdrv_api_chk_conf_reg_check) | Private | ASIL D | r\_impdrv\_api.c |

### Public function

#### R\_IMPDRV\_Init

Table 2‑2: R\_IMPDRV\_Init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0001  R\_IMPDRV\_Init  [Covers: AD\_PD\_CAS0105, AD\_PD\_CAS1001, AD\_PD\_CAS2001, AD\_PD\_CAS2002, AD\_PD\_CAS3001, AD\_PD\_CAS2238] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_Init (  st\_impdrv\_initdata\_t \*const p\_initdata,  impdrv\_ctrl\_handle\_t \*const p\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-Out)** | st\_impdrv\_initdata\_t \*const p\_initdata | | Initialization data for IMP Driver  The lifetime of this parameter is until this function returns.  Refer st\_impdrv\_initdata\_t for the expiration of the members of the structure. | |
| **Range** | Not NULL |
| **Parameters (Out)** | impdrv\_ctrl\_handle\_t \*const p\_handle | | Control handle for IMP Driver  The lifetime of this parameter is the period from the R\_IMPDRV\_Init is executed until R\_IMPDRV\_Quit is executed. | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.1 R\_IMPDRV\_Init” in [3]. | | | |
| **Preconditions** | Can be executed in the “Uninitialized State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_Quit

Table 2‑3 R\_IMPDRV\_Quit

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0002  R\_IMPDRV\_Quit  [Covers: AD\_PD\_CAS1004, AD\_PD\_CAS2067, AD\_PD\_CAS2068, AD\_PD\_CAS3001] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_Quit (  impdrv\_ctrl\_handle\_t handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.2 R\_IMPDRV\_Quit” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State” or “Uninitialized State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_AttrInit

Table 2‑4 R\_IMPDRV\_AttrInit

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0003  R\_IMPDRV\_AttrInit  [Covers: AD\_PD\_CAS1007, AD\_PD\_CAS2115, AD\_PD\_CAS2116, AD\_PD\_CAS3001] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_AttrInit (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information  The lifetime of this parameter is until this function returns. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | const impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver  The lifetime of this parameter is the period from the R\_IMPDRV\_Init is executed until R\_IMPDRV\_Quit is executed. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.3 R\_IMPDRV\_AttrInit” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_AttrSetCoreMemInit

Table 2‑5 R\_IMPDRV\_AttrSetCoreMemInit

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0004  R\_IMPDRV\_AttrSetCoreMemInit  [Covers: AD\_PD\_CAS1005, AD\_PD\_CAS1009, AD\_PD\_CAS2139, AD\_PD\_CAS2365] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_AttrSetCoreMemInit (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const e\_impdrv\_param\_t enable  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| const e\_impdrv\_param\_t enable | | Core memory initialization selection | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.4 R\_IMPDRV\_AttrSetCoreMemInit” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_Start

Table 2‑6 R\_IMPDRV\_Start

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0005  R\_IMPDRV\_Start  [Covers: AD\_PD\_CAS1005, AD\_PD\_CAS2231, AD\_PD\_CAS2232] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_Start (  impdrv\_ctrl\_handle\_t handle ,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.5 R\_IMPDRV\_Start” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_Stop

Table 2‑7 R\_IMPDRV\_Stop

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0006  R\_IMPDRV\_Stop  [Covers: AD\_PD\_CAS1006, AD\_PD\_CAS2266, AD\_PD\_CAS2267] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_Stop (  impdrv\_ctrl\_handle\_t handle ,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.6 R\_IMPDRV\_Stop” in [3]. | | | |
| **Preconditions** | Can be executed in the “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_AttrSetCoreMap

Table 2‑8 R\_IMPDRV\_AttrSetCoreMap

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0007  R\_IMPDRV\_AttrSetCoreMap  [Covers: AD\_PD\_CAS1008,AD\_PD\_CAS1009, AD\_PD\_CAS2156, AD\_PD\_CAS2370] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_AttrSetCoreMap (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const st\_impdrv\_core\_info\_t core\_map [IMPDRV\_COREMAP\_MAXID]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| const st\_impdrv\_core\_info\_t core\_map | | Sync core map array | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “ 5.2.1.7 R\_IMPDRV\_AttrSetCoreMap” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State ” or “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_AttrSetCl

Table 2‑9 R\_IMPDRV\_AttrSetCl

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0008  R\_IMPDRV\_AttrSetCl  [Covers: AD\_PD\_CAS1009, AD\_PD\_CAS2175, AD\_PD\_CAS2376] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_AttrSetCl (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const uintptr\_t claddr\_phys  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| const uintptr\_t claddr\_phys | | Physical memory address of CL data | |
| **Range** | 128byte alignments |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.8 R\_IMPDRV\_AttrSetCl” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State ” or “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

[impdrv\_impsctl\_execute](file:///C:\\Users\\a5149970\\AppData\\Local\\Microsoft\\Windows\\INetCache\\Content.MSO\\CC66D94F.xlsx" \l "'D_対象CoreControl(一覧)'!E244" \t "_parent)

#### R\_IMPDRV\_AttrSetIrqMask

Table 2‑10 R\_IMPDRV\_AttrSetIrqMask

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0009  R\_IMPDRV\_AttrSetIrqMask  [Covers: AD\_PD\_CAS1008, AD\_PD\_CAS1009, AD\_PD\_CAS2192, AD\_PD\_CAS2381] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_AttrSetIrqMask (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const bool irq\_mask[IMPDRV\_IRQMASK\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| const bool irq\_mask[IMPDRV\_IRQMASK\_MAX] | | Array for IRQ mask setting | |
| **Range** | true or false |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.10 R\_IMPDRV\_AttrSetIrqMask” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State ” or “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_SetIrqGroup

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0011  R\_IMPDRV\_SetIrqGroup  [Covers: AD\_PD\_CAS1009, AD\_PD\_CAS2209, AD\_PD\_CAS2386] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_SetIrqGroup (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_irq\_group\_t \*const p\_irq\_param  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_irq\_group\_t \*const p\_irq\_param | | Interrupt group to which this Control handle | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.11 R\_IMPDRV\_SetIrqGroup” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State ” or “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

Table 2‑11: R\_IMPDRV\_SetIrqGroup

#### R\_IMPDRV\_AttrSetClBrkAddr

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0036  R\_IMPDRV\_AttrSetClBrkAddr  [Covers: AD\_PD\_CAS2537, AD\_PD\_CAS2538] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_ AttrSetClBrkAddr (  impdrv\_ctrl\_handle\_t handle ,  const st\_impdrv\_core\_info\_t \* const p\_core\_info,  const uintptr\_t cl\_brk\_addr  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| uintptr\_t cl\_brk\_addr | | CL break point physical address | |
| **Range** | 4byte alignments |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | N/A  Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.12 R\_IMPDRV\_AttrSetClBreak” in [3]. | | | |
| **Preconditions** | Can be executed in the “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** |  | | | |

Table 2‑12 R\_IMPDRV\_AttrSetClBrkAddr

#### R\_IMPDRV\_Execute

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0012  R\_IMPDRV\_Execute  [Covers: AD\_PD\_CAS1010, AD\_PD\_CAS2292, AD\_PD\_CAS2293] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_Execute (  impdrv\_ctrl\_handle\_t handle ,  const st\_impdrv\_core\_info\_t \* const p\_core\_info  const p\_impdrv\_cbfunc\_t callback\_func,  void \*const p\_callback\_args  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| const p\_impdrv\_cbfunc\_t callback\_func | | Callback function to IMP Framework | |
| **Range** | Not NULL |
| void  \*const p\_callback\_args | | Argument of callback function | |
| **Range** | None |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_ATTRIBUTE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.12 R\_IMPDRV\_Execute” in [3]. | | | |
| **Preconditions** | Can be executed in the “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

Table 2‑13: R\_IMPDRV\_Execute

#### R\_IMPDRV\_ResumeExecution

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0013  R\_IMPDRV\_ResumeExecution  [Covers: AD\_PD\_CAS1014, AD\_PD\_CAS2393, AD\_PD\_CAS2394] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_ResumeExecution (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.13 R\_IMPDRV\_ResumeExecution” in [3]. | | | |
| **Preconditions** | Can be executed in the “Int State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

Table 2‑14: R\_IMPDRV\_ResumeExecution

#### R\_IMPDRV\_SetPMPolicy

Table 2‑15 : R\_IMPDRV\_SetPMPolicy

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0018  R\_IMPDRV\_SetPMPolicy  [Covers: AD\_PD\_CAS1015, AD\_PD\_CAS3001, AD\_PD\_CAS2419, AD\_PD\_CAS2420] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_SetPMPolicy (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const e\_impdrv\_pm\_policy\_t policy  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| const e\_impdrv\_pm\_policy\_t policy | | Power management policy | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.2.1 R\_IMPDRV\_SetPMPolicy” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State ”, “Ready State”, “ Active State” and “Int State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_GetPMPolicy

Table 2‑16: R\_IMPDRV\_GetPMPolicy

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0019  R\_IMPDRV\_GetPMPolicy  [Covers: AD\_PD\_CAS3001, AD\_PD\_CAS1016, AD\_PD\_CAS2451, AD\_PD\_CAS2452] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_GetPMPolicy (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  e\_impdrv\_pm\_policy\_t \*const policy  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (Out)** | e\_impdrv\_pm\_policy\_t \*const policy | | Power management policy | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.2.2 R\_IMPDRV\_GetPMPolicy” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State ”, “Ready State”, “ Active State” and “Int State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | policy is pointer of output parameter, so the use of this pointer variable is acceptable. | | | |

#### R\_IMPDRV\_GetPMState

Table 2‑17: R\_IMPDRV\_GetPMState

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0038  R\_IMPDRV\_GetPMState  [Covers: AD\_PD\_CAS1032, AD\_PD\_CAS2097, AD\_PD\_CAS2098] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_GetPMState(  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  e\_impdrv\_pm\_state\_t \*const p\_pmstate  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | e\_impdrv\_pm\_state\_t \*const p\_pmstate | | Power management state | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.2.3 R\_IMPDRV\_GetPMState” in [3]. | | | |
| **Preconditions** | Can be executed in the “Initialized State”, “Ready State”, “Active State” and “Int State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | Power management state is pointer of output parameter, so the use of this pointer variable is acceptable. | | | |

#### R\_IMPDRV\_GetVersion

Table 2‑18: R\_IMPDRV\_GetVersion

|  |  |  |  |
| --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0020  R\_IMPDRV\_GetVersion  [Covers: AD\_PD\_CAS1013, AD\_PD\_CAS2392, AD\_PD\_CAS2480] | | |
| **ASIL Level** | ASIL D | **Status** | New |
| **Syntax** | const st\_impdrv\_version\_t\* R\_IMPDRV\_GetVersion (  void  ); | | |
| **Sync/Async** | Synchronous | | |
| **Reentrancy** | Reentrant | | |
| **Interrupt State** | Can be called from OSAL Callback. | | |
| **Parameters (In)** | N/A | | N/A |
| **Parameters (In-Out)** | N/A | | N/A |
| **Parameters (Out)** | N/A | | N/A |
| **Return Value** | st\_impdrv\_version\_t | | IMP driver version information, classified by major, minor, and patch versions.  Refer to 5.1.2.1.6 |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.18 R\_IMPDRV\_GetVersion” in [3]. | | |
| **Preconditions** | Can be executed in the “Uninitialized State”, “Initialized State ”, “Ready State”, “ Active State” and “Int State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | |
| **Remarks** | N/A | | |

#### R\_IMPDRV\_RegGetHwInfo

Table 2‑19: R\_IMPDRV\_RegGetHwInfo

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0026  R\_IMPDRV\_RegGetHwInfo  [Covers: AD\_PD\_CAS3001, AD\_PD\_CAS1018, AD\_PD\_CAS2104, AD\_PD\_CAS2105] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_RegGetHwInfo (  impdrv\_ctrl\_handle\_t handle,  const char \*const p\_device\_id,  [st\_impdrv\_reg\_info\_t](#_st_impdrv_reg_info_t) \*const p\_reg\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const char \*const p\_device\_id | | Pointer to Target OSAL device ID. | |
| **Range** | Not NULL |
| impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | [st\_impdrv\_reg\_info\_t](#_st_impdrv_reg_info_t) \*const p\_reg\_info | | Pointer to Hardware register area specification information. | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2 R\_IMPDRV\_RegGetHwInfo ” in [3]. | | | |
| **Preconditions** | Can be executed in the “Uninitialized state ”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_RegRead32

Table 2‑20: R\_IMPDRV\_RegRead32

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0027  R\_IMPDRV\_RegRead32  [Covers: AD\_PD\_CAS3001, AD\_PD\_CAS1019, AD\_PD\_CAS2111, AD\_PD\_CAS2112] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_RegRead32 (  impdrv\_ctrl\_handle\_t handle,  const char \*const p\_device\_id,  const uintptr\_t offset,  uint32\_t \*const p\_data  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const char \*const p\_device\_id | | Pointer to Target OSAL device ID. | |
| **Range** | Not NULL |
| const uintptr\_t offset | | Sets the offset address from Register top. | |
| **Range** | The offset  address should be specified as 4-byte alignment. |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver. | |
| **Range** | Not NULL |
| **Parameters (Out)** | uint32\_t \*const p\_data | | Pointer to the read data to hardware registers. | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2 R\_IMPDRV\_RegRead32” in [3]. | | | |
| **Preconditions** | Can be executed in the “Uninitialized state ”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | p\_data is pointer of output parameter, so the use of this pointer variable is acceptable. | | | |

#### R\_IMPDRV\_RegWrite32

Table 2‑21: R\_IMPDRV\_RegWrite32

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0028  R\_IMPDRV\_RegWrite32  [Covers: AD\_PD\_CAS3001, AD\_PD\_CAS1020, AD\_PD\_CAS2122, AD\_PD\_CAS2123] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_RegWrite32 (  impdrv\_ctrl\_handle\_t handle,  const char \*const p\_device\_id,  const uintptr\_t offset,  const uint32\_t data  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const char \*const p\_device\_id | | Pointer to Target OSAL device ID. | |
| **Range** | Not NULL |
| const uintptr\_t offset | | Sets the offset address from Register top. | |
| **Range** | The offset  address should be specified as 4-byte alignment. |
| Uint32\_t data | | Data written to hardware registers. | |
| **Range** | None |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2 R\_IMPDRV\_RegWrite32” in [3]. | | | |
| **Preconditions** | Can be executed in the “Uninitialized state ”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_RegRequired

Table 2‑22: R\_IMPDRV\_RegRequired

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0029  R\_IMPDRV\_RegRequired  [Covers: AD\_PD\_CAS3001, AD\_PD\_CAS1021, AD\_PD\_CAS2124, AD\_PD\_CAS2125] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_RegRequired (  impdrv\_ctrl\_handle\_t handle,  const char \*const p\_device\_id,  const [e\_impdrv\_reg\_req\_state\_t](#_e_impdrv_reg_req_state_t) new\_state  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const char \*const p\_device\_id | | Pointer to Target OSAL device ID. | |
| **Range** | Not NULL |
| const  [e\_impdrv\_reg\_req\_state\_t](#_e_impdrv_reg_req_state_t)  new\_state | | Required state to the Register read/write function. | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t  handle | | Control handle for IMP Driver. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2 R\_IMPDRV\_RegRequired” in [3]. | | | |
| **Preconditions** | Can be executed in the “Uninitialized State”, “Initialized State ”, “Ready State”, “ Active State” and “Int State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_SetMemProtect

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0030  R\_IMPDRV\_SetMemProtect  [Covers: AD\_PD\_CAS3001, AD\_PD\_CAS1017, AD\_PD\_CAS2100, AD\_PD\_CAS2101] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_SetMemProtect (  impdrv\_ctrl\_handle\_t handle,  const [e\_impdrv\_protect\_mode\_t](#_e_impdrv_protect_mode_t) protect\_mode  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Permitted | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const  [e\_impdrv\_protect\_mode\_t](#_e_impdrv_protect_mode_t)  protect\_mode | | Memory protection setting. | | |
| **Range** | Within the range of ENUM type. | |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t  handle | | Control handle for IMP Driver. | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2 R\_IMPDRV\_SetMemProtect” in [3]. | | | | |
| **Preconditions** | Can be executed in the “Uninitialized State”, “Initialized State ”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | | |
| **Remarks** | N/A | | | | |

Table 2‑23: R\_IMPDRV\_SetMemProtect

#### R\_IMPDRV\_BusIfCheck

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0031  R\_IMPDRV\_BusIfCheck  [Covers: AD\_PD\_CAS3001, AD\_PD\_CAS1025, AD\_PD\_CAS1026, AD\_PD\_CAS1027, AD\_PD\_CAS2301, AD\_PD\_CAS2302, AD\_PD\_CAS1030] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_BusIfCheck (  impdrv\_ctrl\_handle\_t handle,  const [st\_impdrv\_core\_info\_t](#_API_Layer_2) \*const p\_core\_info,  const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t) \*const p\_chk\_resource  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const [st\_impdrv\_core\_info\_t](#_API_Layer_2) \*const p\_core\_info | | Pointer to the Core information data. | |
| **Range** | Not NULL |
| const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t)  \*const \_chk\_resource | | Pointer to the OSAL resource for bus interface check. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Pointer to handle of the IMP Driver control | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2 R\_IMPDRV\_BusIfCheck” in [3]. | | | |
| **Preconditions** | Can be executed in the “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

Table 2‑24: R\_IMPDRV\_BusIfCheck

#### R\_IMPDRV\_ConfRegCheck

Table 2‑25: R\_IMPDRV\_ConfRegCheck

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0032  R\_IMPDRV\_ConfRegCheck  [Covers: AD\_PD\_CAS3001, AD\_PD\_CAS1028, AD\_PD\_CAS2303, AD\_PD\_CAS2304] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_BusIfCheck (  impdrv\_ctrl\_handle\_t handle,  const [st\_impdrv\_chk\_param\_t](#_st_impdrv_chkparam_t(T.B.D.)) \*const p\_chk\_param,  const uint32\_t param\_num,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const [st\_impdrv\_chk\_param\_t](#_st_impdrv_chkparam_t(T.B.D.)) \*const p\_chk\_param | | Pointer to Array of check parameters. | |
| **Range** | Not NULL |
| const uint32\_t param\_num | | Number of check parameters. | |
| **Range** | Not 0 |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Pointer to the Core information data. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Pointer to handle of the IMP Driver control | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2 R\_IMPDRV\_ConfRegCheck” in [3]. | | | |
| **Preconditions** | Can be executed in the “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_ModuleStopCheck

Table 2‑26: R\_IMPDRV\_ModuleStopCheck

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0033  R\_IMPDRV\_ModuleStopCheck  [Covers: AD\_PD\_CAS3001, AD\_PD\_CAS1029, AD\_PD\_CAS2305, AD\_PD\_CAS2306] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_ModuleStopCheck (  impdrv\_ctrl\_handle\_t handle,  const st\_impdrv\_chk\_param\_t \*const p\_chk\_param,  const uint32\_t param\_num,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In-Out)** | const st\_impdrv\_chk\_param\_t \*const p\_chk\_param | | Pointer to Array of check parameters. | |
| **Range** | Not NULL |
| const uint32\_t param\_num | | Number of check parameters. | |
| **Range** | Not 0 |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Pointer to the Core information data. | |
| **Range** | Not NULL |
| **Parameters (In)** | impdrv\_ctrl\_handle\_t handle | | Pointer to handle of the IMP Driver control | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2 R\_IMPDRV\_ModuleStopCheck” in [3]. | | | |
| **Preconditions** | Can be executed in the “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_AttrSetDsp

Table 2‑27: R\_IMPDRV\_AttrSetDsp

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0037  R\_IMPDRV\_AttrSetDsp  [Covers: AD\_PD\_CAS1009, AD\_PD\_CAS2239, AD\_PD\_CAS2240] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_AttrSetDsp(  impdrv\_ctrl\_handle\_t handle,  const [st\_impdrv\_core\_info\_t](#_st_impdrv_core_info_t) \*const p\_core\_info,  const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_app,  const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_fw,  const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_data,  const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_dtcm  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const [st\_impdrv\_core\_info\_t](#_st_impdrv_core_info_t) \*const p\_core\_info | | Pointer to the Core information data. | |
| **Range** | Not NULL |
| const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_app, | | Pointer to the application which run on the DSP. | |
| **Range** | Not NULL |
| const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_fw, | | Pointer to the DSP FW which run on the DSP. | |
| **Range** | Not NULL |
| const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_data, | | Pointer to the data which is used by application on the DSP. | |
| **Range** | Not NULL |
| const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_dtcm | | Pointer to the internal data which is used by application on the DSP. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Pointer to handle of the IMP Driver control | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.9 R\_IMPDRV\_AttrSetDsp” in [3]. | | | |
| **Preconditions** | Can be executed in the “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

#### R\_IMPDRV\_AttrSetGosubCond

Table 2‑28: R\_IMPDRV\_AttrSetGosubCond

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0039  R\_IMPDRV\_AttrSetGosubCond  [Covers: AD\_PD\_CAS1031, AD\_PD\_CAS2241, AD\_PD\_CAS2242] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t R\_IMPDRV\_AttrSetGosubCond(  impdrv\_ctrl\_handle\_t handle,  const [st\_impdrv\_core\_info\_t](#_st_impdrv_core_info_t) \*const p\_core\_info,  const e\_impdrv\_gosub\_cond\_t condition  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const [st\_impdrv\_core\_info\_t](#_st_impdrv_core_info_t) \*const p\_core\_info | | Pointer to the Core information data. | |
| **Range** | Not NULL |
| const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_app, | | Pointer to the application which run on the DSP. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | impdrv\_ctrl\_handle\_t handle | | Pointer to handle of the IMP Driver control | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  For the usage, refer to the “5.2.1.XX R\_IMPDRV\_AttrSetGosubCond” in [3]. | | | |
| **Preconditions** | Can be executed in the “Ready State”.  For details, refer to the “3.1 Finite-State machine” in [3]. | | | |
| **Remarks** | N/A | | | |

### Private function

#### impdrv\_api\_chk\_init\_data

Table 2‑27: impdrv\_api\_chk\_init\_data

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0021  impdrv\_api\_chk\_init\_data  [Covers: AD\_PD\_CAS3001] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_api\_chk\_init\_data (  const st\_impdrv\_initdata\_t \*const p\_initdata  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_initdata\_t  \*const p\_initdata | | Initialization data for IMP Driver  The lifetime of this parameter is until this function returns.  Refer st\_impdrv\_initdata\_t for the expiration of the members of the structure. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_api\_chk\_core\_info

Table 2‑28: impdrv\_api\_chk\_core\_info

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0022  impdrv\_api\_chk\_core\_info  [Covers: AD\_PD\_CAS3001] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_api\_chk\_core\_info(  const st\_impdrv\_core\_info\_t core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t  core\_info | | Core information for Specific core. | |
| **Range** | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_api\_chk\_instance\_num

Table 2‑29: impdrv\_api\_chk\_instance\_num

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0023  impdrv\_api\_chk\_instance\_num  [Covers: AD\_PD\_CAS3001] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_api\_chk\_instance\_num(  const e\_impdrv\_instance\_t instance\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_api\_cnv\_error\_code

Table 2‑30: impdrv\_api\_cnv\_error\_code

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0024  impdrv\_api\_cnv\_error\_code  [Covers: AD\_PD\_CAS3001] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_api\_cnv\_error\_code(  const e\_impdrv\_errorcode\_t ercd  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t ercd | | Error code | |
| **Range** | None |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | Error code translated for public interface,  All values defined in the enumeration. | |
| **Description** | Convert IMPDRV\_EC\_NG\_PARAM and IMPDRV\_EC\_NG\_ARGNULL returned from other subcomponents to IMPDRV\_EC\_NG\_SYSTEMERROR.  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_api\_cnv\_ctrl\_handle

Table 2‑31: impdrv\_api\_cnv\_ctrl\_handle

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0025  impdrv\_api\_cnv\_ctrl\_handle  [Covers: AD\_PD\_CAS2001, AD\_PD\_CAS2067, AD\_PD\_CAS2115] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_api\_cnv\_ctrl\_handle(  impdrv\_ctrl\_handle\_t handle,  st\_impdrv\_ctl\_t \*\*const p\_impdrv\_ctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | impdrv\_ctrl\_handle\_t handle | | Control handle for IMP Driver | |
| **Range** | None |
| **Parameters (In-Out)** | st\_impdrv\_ctl\_t \*\*const p\_impdrv\_ctl | | General control handle | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | Error code translated for public interface,  All values defined in the enumeration. | |
| **Description** | Cast the published structure to an internal structure.  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_api\_chk\_bus\_if\_check

Table 2‑32: impdrv\_api\_chk\_bus\_if\_check

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0034  impdrv\_api\_chk\_bus\_if\_check  [Covers: AD\_PD\_CAS2301] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_api\_chk\_bus\_if\_check(  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t) \*const p\_chk\_resource  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info, | | Pointer to the Specified core information. | |
| **Range** | Not NULL |
| const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t) \*const p\_chk\_resource | | Pointer to the OSAL resource for bus interface check. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | Error code translated for public interface,  All values defined in the enumeration. | |
| **Description** | Check the internal bus check resource data for IMP Driver.  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_api\_chk\_conf\_reg\_check

Table 2‑33: impdrv\_api\_chk\_conf\_reg\_check

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_01\_0035  impdrv\_api\_chk\_conf\_reg\_check  [Covers: AD\_PD\_CAS2303] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_api\_chk\_conf\_reg\_check(  const [st\_impdrv\_chk\_param\_t](#_st_impdrv_chkparam_t(T.B.D.)) \*const p\_chk\_param,  const uint32\_t param\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const [st\_impdrv\_chk\_param\_t](#_st_impdrv_chkparam_t(T.B.D.)) \*const p\_chk\_param | | Pointer to Array of check parameters. | |
| **Range** | Not NULL |
| const uint32\_t param\_num | | Number of check parameters. | |
| **Range** | Not 0. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Convert the Input handle to Control structure pointer.  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

### User define function

#### impdrv\_udefctl\_udef\_crc

Table 2‑: impdrv\_udefctl\_udef\_crc

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0071***  impdrv\_udefctl\_udef\_crc  ***[Covers: AD\_PD\_CAS1005, AD\_PD\_CAS1010A, D\_PD\_CAS2600, AD\_PD\_CAS2603]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | uint32\_t impdrv\_udefctl\_udef\_crc(  uint32\_t st,  uint32\_t sz  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | N/A | | | |
| **Parameters (In)** | uint32\_t st | | Start Address. | |
| **Range** | N/A |
| uint32\_t sz | | Size of Memory (Long Word). | |
| **Range** | N/A |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | uint32\_t | | CRC value. | |
| **Description** | For the usage, refer to the “5.6.1 impdrv\_udefctl\_udef\_crc” in [8]. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_udefctl\_set\_ecm

Table 2‑196: impdrv\_udefctl\_set\_ecm

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0072***  impdrv\_udefctl\_set\_ecm  ***[Covers: AD\_PD\_CAS1005, AD\_PD\_CAS1035, AD\_PD\_CAS1010, AD\_PD\_CAS2601, AD\_PD\_CAS2602, AD\_PD\_CAS2604]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | void impdrv\_udefctl\_set\_ecm(  int32\_t core\_num,  bool flag  ); | | | |
| **Sync/Async** | Asynchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | N/A | | | |
| **Parameters (In)** | int32\_t core\_num | | Specify VDSP core number. | |
| **Range** | 0 to 3. (only V4H)  0 to 1. (only V4M) |
| bool flag | | Specify control of ECM. | |
| **Range** | true or false. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | N/A | | N/A | |
| **Description** | For the usage, refer to the “5.6.2 impdrv\_udefctl\_set\_ecm” in [8]. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

## Functions of General Control

Table 2‑34: Function List

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **No.** | **Function Name** | **Access** | **ASIL** | **Source File Name** |
|  | impdrv\_genctl\_init | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_quit | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_start | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_stop | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_set\_cl\_brk\_addr | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_execute | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_resume\_exe | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_pm\_set\_policy | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_pm\_get\_policy | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_pm\_get\_state | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_attr\_init | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_set\_core\_mem\_init | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_set\_core\_map | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_set\_cl | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_set\_irq\_mask | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_set\_irq\_group | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_int\_handler | Public | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_reg\_set\_mem\_protect](#_impdrv_genctl_reg_set_mem_protect) | Public | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_reg\_get\_hw\_info](#_impdrv_genctl_reg_get_hw_info) | Public | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_reg\_read32](#_impdrv_genctl_reg_read32) | Public | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_reg\_write32](#_impdrv_genctl_reg_write32) | Public | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_reg\_required](#_impdrv_genctl_reg_required) | Public | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_check\_intclear | Public | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_bus\_if\_check](#_impdrv_genctl_bus_if_check) | Public | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_conf\_reg\_check](#_impdrv_genctl_conf_reg_check) | Public | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_set\_dsp](#_impdrv_genctl_set_dsp) | Public | - | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_dsp\_int\_handler](#_impdrv_genctl_dsp_int_handler) | Public | - | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_set\_gosub\_cond](#_impdrv_genctl_set_gosub_cond) | Public | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_chk\_core\_info](#_impdrv_genctl_chk_core_info) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_prologue](#_impdrv_genctl_prologue) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_epilogue](#_impdrv_genctl_epilogue) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_chk\_state\_init](#_impdrv_genctl_chk_state_init) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_chk\_state\_uninit](#_impdrv_genctl_chk_state_uninit) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_set\_state\_uninit](#_impdrv_genctl_set_state_uninit) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_core\_init](#_impdrv_genctl_core_init) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_init\_get\_func](#_impdrv_genctl_init_get_func) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_init\_chk\_state](#_impdrv_genctl_init_chk_state) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | i[mpdrv\_genctl\_init\_set\_state](#_impdrv_genctl_init_set_state) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | [impdrv\_genctl\_init\_attr\_init](#_impdrv_genctl_init_attr_init) | Private | ASIL D | r\_impdrv\_genctl.c |
|  | impdrv\_genctl\_get\_worksize | Private | ASIL D | r\_impdrv\_genctl.c |

### Public function

#### impdrv\_genctl\_init

Table 2‑35: impdrv\_genctl\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0001  impdrv\_genctl\_init  [Covers: AD\_PD\_CAS1001, AD\_PD\_CAS2003, AD\_PD\_CAS2004, AD\_PD\_CAS2005, AD\_PD\_CAS2006, AD\_PD\_CAS2007, AD\_PD\_CAS2008, AD\_PD\_CAS2009, AD\_PD\_CAS2010, AD\_PD\_CAS2011, AD\_PD\_CAS2012, AD\_PD\_CAS2117, AD\_PD\_CAS2118, AD\_PD\_CAS2119, AD\_PD\_CAS2120, AD\_PD\_CAS2121, AD\_PD\_CAS3002, AD\_PD\_CAS2227] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_init(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  st\_impdrv\_initdata\_t \*const p\_data,  const impdrv\_ctrl\_handle\_t osal\_cb\_args  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const impdrv\_ctrl\_handle\_t  osal\_cb\_args | | OSAL callback argument  The lifetime of this parameter is the period from the impdrv\_genctl\_init is executed until impdrv\_genctl\_quit is executed. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle  The lifetime of this parameter is the period from the impdrv\_genctl\_init is executed until impdrv\_genctl\_quit is executed. | |
| **Range** | Not NULL |
| st\_impdrv\_initdata\_t \*const p\_data | | Initialization data  The lifetime of this parameter is until impdrv\_genctl\_init returns.  Refer st\_impdrv\_initdata\_t for the expiration of the members of the structure. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_INSTANCE | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_quit

Table 2‑36: impdrv\_genctl\_quit

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0002  impdrv\_genctl\_quit  [Covers: AD\_PD\_CAS1004, AD\_PD\_CAS2069, AD\_PD\_CAS2070, AD\_PD\_CAS2071, AD\_PD\_CAS2072, AD\_PD\_CAS2073, AD\_PD\_CAS2074, AD\_PD\_CAS2075, AD\_PD\_CAS2076, AD\_PD\_CAS2077, AD\_PD\_CAS3002, AD\_PD\_CAS2557] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_quit(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | N/A | | N/A | | |
| **Range** | N/A | |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * Add arguments for call impdrv\_genctl\_chk\_state\_init * Add processing of call impdrv\_\*\*\*ctl\_quit for init state cores | | | | |
| **Preconditions** | N/A. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_genctl\_start

Table 2‑37: impdrv\_genctl\_start

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0003  impdrv\_genctl\_start  [Covers: AD\_PD\_CAS1005, AD\_PD\_CAS2233, AD\_PD\_CAS2234, AD\_PD\_CAS2235, AD\_PD\_CAS2236, AD\_PD\_CAS2237, AD\_PD\_CAS2243, AD\_PD\_CAS2244, AD\_PD\_CAS2245, AD\_PD\_CAS2253] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_start(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | IMP Driver initialization is complete.  And the core is not execute. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_genctl\_stop

Table 2‑38: impdrv\_genctl\_stop

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0004  impdrv\_genctl\_stop  [Covers: AD\_PD\_CAS1006, AD\_PD\_CAS2268, AD\_PD\_CAS2269, AD\_PD\_CAS2270, AD\_PD\_CAS2271, AD\_PD\_CAS2272, AD\_PD\_CAS2254] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_stop(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t  \*const p\_core\_info | | Core information | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | IMP Driver start is complete.  And the core is not execute. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_genctl\_set\_cl\_brk\_addr

Table 2‑39 impdrv\_genctl\_set\_cl\_brk\_addr

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0040  impdrv\_genctl\_set\_cl\_brk\_addr  [Covers: AD\_PD\_CAS2539, AD\_PD\_CAS2540, AD\_PD\_CAS2541, AD\_PD\_CAS2542, AD\_PD\_CAS2543, AD\_PD\_CAS2255, AD\_PD\_CAS2256, AD\_PD\_CAS2260, AD\_PD\_CAS2261, AD\_PD\_CAS2262] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_set\_cl\_brk\_addr (  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \* const p\_core\_info,  uint32\_t cl\_brk\_addr  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core | |
| **Range** | Not NULL |
| uintptr\_t Cl\_brk\_addr | | CL break point physical address | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl, | | General control handle | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | |  | |
| **Preconditions** |  | |  | |
| **Remarks** |  | | | |

#### impdrv\_genctl\_execute

Table 2‑40: impdrv\_genctl\_execute

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0005  impdrv\_genctl\_execute  [Covers: AD\_PD\_CAS1010, AD\_PD\_CAS2294, AD\_PD\_CAS2295, AD\_PD\_CAS2298, AD\_PD\_CAS2299, AD\_PD\_CAS2300] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_execute(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  const p\_impdrv\_cbfunc\_t callback\_func,  void \*const p\_callback\_args  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | |
| **Range** | Not NULL |
| const p\_impdrv\_cbfunc\_t callback\_func | | Callback function | |
| **Range** | Not NULL |
| void  \*const p\_callback\_args | | Callback argument | |
| **Range** | None. |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | IMP Driver start is complete.  CL has been set. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_resume\_exe

Table 2‑41: impdrv\_genctl\_resume\_exe

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0006  impdrv\_genctl\_resume\_exe  [Covers: AD\_PD\_CAS1014, AD\_PD\_CAS2395, AD\_PD\_CAS2396, AD\_PD\_CAS2397, AD\_PD\_CAS2398, AD\_PD\_CAS2399] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_resume\_exe(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t  const \*p\_core\_info | | Core information | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_DSP\_HALT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | INT interrupt is coming after CL is running. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_genctl\_pm\_set\_policy

Table 2‑42: impdrv\_genctl\_pm\_set\_policy

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0007  impdrv\_genctl\_pm\_set\_policy  [Covers: AD\_PD\_CAS1015, AD\_PD\_CAS2421, AD\_PD\_CAS2422, AD\_PD\_CAS2423, AD\_PD\_CAS2424, AD\_PD\_CAS2425] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_pm\_set\_policy(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl ,  const st\_impdrv\_core\_info\_t \*const p\_core\_info ,  const e\_impdrv\_pm\_policy\_t policy  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | |
| **Range** | Not NULL |
| const e\_impdrv\_pm\_policy\_t policy | | Policy you want to set | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | IMP Driver initialization is complete. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_pm\_get\_policy

Table 2‑43: impdrv\_genctl\_pm\_get\_policy

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0008  impdrv\_genctl\_pm\_get\_policy  [Covers: AD\_PD\_CAS1016, AD\_PD\_CAS2453, AD\_PD\_CAS2454, AD\_PD\_CAS2455, AD\_PD\_CAS2456, AD\_PD\_CAS2457] | | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_pm\_get\_policy(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  e\_impdrv\_pm\_policy\_t \*const p\_policy  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t  \*const p\_impdrv\_ctl | | General control handle | | | |
| **Range** | | Not NULL | |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | | | |
| **Range** | | | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | | | |
| **Parameters (Out)** | e\_impdrv\_pm\_policy\_t \*const p\_policy | | Current PM Policy | | | |
| **Range** | Not NULL | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| **Preconditions** | IMP Driver initialization is complete. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_genctl\_pm\_get\_state

Table 2‑44: impdrv\_genctl\_pm\_get\_state

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0015  impdrv\_genctl\_pm\_get\_state  [Covers: AD\_PD\_CAS1032, AD\_PD\_CAS2539, AD\_PD\_CAS2540, AD\_PD\_CAS2541, AD\_PD\_CAS2542, AD\_PD\_CAS2275] | | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_pm\_get\_state(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  e\_impdrv\_pm\_state\_t \*const p\_pmstate  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t  \*const p\_impdrv\_ctl | | General control handle | | | |
| **Range** | | Not NULL | |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | | | |
| **Range** | | | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | | | |
| **Parameters (Out)** | e\_impdrv\_pm\_state\_t \*const p\_pmstate | | Current PM State | | | |
| **Range** | Not NULL | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PMSYSTEMERROR | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| **Preconditions** | IMP Driver initialization is complete. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_genctl\_attr\_init

Table 2‑45: impdrv\_genctl\_attr\_init

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0009  impdrv\_genctl\_attr\_init  [Covers: AD\_PD\_CAS1007, AD\_PD\_CAS3002] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_attr\_init(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t  \*const p\_core\_info | | Core information  The lifetime of this parameter is until this function returns. | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle  The lifetime of this parameter is the period from the impdrv\_genctl\_init is executed until impdrv\_genctl\_quit is executed. | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_genctl\_set\_core\_mem\_init

Table 2‑46: impdrv\_genctl\_set\_core\_mem\_init

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0010  impdrv\_genctl\_set\_core\_mem\_init  [Covers: AD\_PD\_CAS1005, AD\_PD\_CAS2140, AD\_PD\_CAS2366, AD\_PD\_CAS2367, AD\_PD\_CAS2368, AD\_PD\_CAS2369] | | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_set\_core\_mem\_init(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl ,  const st\_impdrv\_core\_info\_t \*const p\_core\_info ,  const e\_impdrv\_param\_t enable  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | | | |
| **Range** | | Not NULL | |
| const e\_impdrv\_param\_t enable | | Whether to initialize memory | | | |
| **Range** | Within the range of ENUM type. | | |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | | | |
| **Range** | | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_genctl\_set\_core\_map

Table 2‑47: impdrv\_genctl\_set\_core\_map

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0011  impdrv\_genctl\_set\_core\_map  [Covers: AD\_PD\_CAS1008, AD\_PD\_CAS2157, AD\_PD\_CAS2371, AD\_PD\_CAS2372, AD\_PD\_CAS2373, AD\_PD\_CAS2374, AD\_PD\_CAS2375] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_set\_core\_map(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl ,  const st\_impdrv\_core\_info\_t \*const p\_core\_info ,  const st\_impdrv\_core\_info\_t core\_map [IMPDRV\_COREMAP\_MAXID]  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | | |
| **Range** | Not NULL | |
| const st\_impdrv\_core\_info\_t core\_map  [IMPDRV\_COREMAP\_MAXID] | | Setting Core map | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | IMP Driver start is complete.  And the core is not execute. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_genctl\_set\_cl

Table 2‑48: impdrv\_genctl\_set\_cl

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0012  impdrv\_genctl\_set\_cl  [Covers: AD\_PD\_CAS2176, AD\_PD\_CAS2377, AD\_PD\_CAS2378, AD\_PD\_CAS2380, AD\_PD\_CAS2379] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_set\_cl(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl ,  const st\_impdrv\_core\_info\_t \*const p\_core\_info ,  const uint32\_t claddr\_phys  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | |
| **Range** | Not NULL |
| const uint32\_t claddr\_phys | | Setting CL address | |
| **Range** | 4byte alignments |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | - | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | IMP Driver start is complete.  And the core is not execute. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_set\_irq\_mask

Table 2‑49: impdrv\_genctl\_set\_irq\_mask

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0013  impdrv\_genctl\_set\_irq\_mask  [Covers: AD\_PD\_CAS1008, AD\_PD\_CAS2193, AD\_PD\_CAS2382, AD\_PD\_CAS2383, AD\_PD\_CAS2384, AD\_PD\_CAS2385] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_set\_irq\_mask(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl ,  const st\_impdrv\_core\_info\_t \*const p\_core\_info ,  const bool irq\_mask[IMPDRV\_IRQMASK\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | |
| **Range** | Not NULL |
| const bool irq\_mask[IMPDRV\_IRQMASK\_MAX] | | Setting IRQ mask | |
| **Range** | true or false |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | IMP Driver start is complete.  And the core is not execute. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_set\_irq\_group

Table 2‑50: impdrv\_genctl\_set\_irq\_group

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0014  impdrv\_genctl\_set\_irq\_group  [Covers: AD\_PD\_CAS1009, AD\_PD\_CAS2210, AD\_PD\_CAS2387, AD\_PD\_CAS2388, AD\_PD\_CAS2389, AD\_PD\_CAS2390, AD\_PD\_CAS2391] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_set\_irq\_group(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl ,  const st\_impdrv\_irq\_group\_t \*const p\_irq\_param  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_irq\_group\_t \*const p\_irq\_param | | Setting irq group | |
| **Range** | Not NULL |
| const st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | IMP Driver start is complete.  And the core is not execute. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_int\_handler

Table 2‑51: impdrv\_genctl\_int\_handler

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0016  impdrv\_genctl\_int\_handler  [Covers: AD\_PD\_CAS1011, AD\_PD\_CAS2338, AD\_PD\_CAS2339, AD\_PD\_CAS2340, AD\_PD\_CAS2341] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | void impdrv\_genctl\_int\_handler(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const uint64\_t irq\_channel ,  const e\_impdrv\_errorcode\_t ercd  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can be called from OSAL interrupt. | | | |
| **Parameters (In)** | const uint64\_t irq\_channel | | IRQ channel associated with OSAL interrupt manager. | |
| **Range** | None. |
| Const e\_impdrv\_errorcode\_t ercd | | IMPDRV error code | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | N/A | | N/A | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | IMP Driver execute is complete. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_reg\_set\_mem\_protect

Table 2‑52: impdrv\_genctl\_reg\_set\_mem\_protect

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0024  impdrv\_genctl\_reg\_set\_mem\_protect  [Covers: AD\_PD\_CAS1017, AD\_PD\_CAS2100, AD\_PD\_CAS2200, AD\_PD\_CAS2201, AD\_PD\_CAS2205 AD\_PD\_CAS2206] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_reg\_set\_mem\_protect(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const [e\_impdrv\_protect\_mode\_t](#_e_impdrv_protect_mode_t) protect\_mode  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| const [e\_impdrv\_protect\_mode\_t](#_e_impdrv_protect_mode_t) protect\_mode | | Memory protection setting. | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * Add arguments for call impdrv\_genctl\_chk\_state\_init | | | |
| **Preconditions** | The core is not start. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_reg\_get\_hw\_info

Table 2‑53: impdrv\_genctl\_reg\_get\_hw\_info

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0025  impdrv\_genctl\_reg\_get\_hw\_info  [Covers: AD\_PD\_CAS1018, AD\_PD\_CAS2104, AD\_PD\_CAS2207, AD\_PD\_CAS2208, AD\_PD\_CAS2211, AD\_PD\_CAS2212] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_reg\_get\_hw\_info(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const char \*const p\_device\_id,  [st\_impdrv\_reg\_info\_t](#_st_impdrv_reg_info_t) \*const p\_reg\_info  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | | |
| **Range** | Not NULL | |
| const char \*const p\_device\_id | | Pointer to Target OSAL device ID. | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | [st\_impdrv\_reg\_info\_t](#_st_impdrv_reg_info_t) \*const p\_reg\_info | | Pointer to Hardware register area specification information. | | |
| **Range** | | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | The core is uninitialized. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_genctl\_reg\_read32

Table 2‑54: impdrv\_genctl\_reg\_read32

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0026  impdrv\_genctl\_reg\_read32  [Covers: AD\_PD\_CAS1019, AD\_PD\_CAS2111, AD\_PD\_CAS2213, AD\_PD\_CAS2214, AD\_PD\_CAS2215, AD\_PD\_CAS2218] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_reg\_read32(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const char \*const p\_device\_id,  const uintptr\_t offset,  uint32\_t \*const p\_data  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | | |
| **Range** | Not NULL | |
| const char \*const p\_device\_id | | Pointer to the Target OSAL device ID. | | |
| **Range** | Not NULL | |
| const uintptr\_t offset | | Sets the offset address from Register top. | | |
| **Range** | The offset  address should be specified as 4-byte alignment. | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | uint32\_t \*const p\_data | | Pointer to the read data to hardware registers. | | |
| **Range** | | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | The core is uninitialized. | | | | |
| **Remarks** | p\_data is pointer of output parameter, so the use of this pointer variable is acceptable. | | | | |

#### impdrv\_genctl\_reg\_write32

Table 2‑55: impdrv\_genctl\_reg\_write32

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0027  impdrv\_genctl\_reg\_write32  [Covers: AD\_PD\_CAS1020, AD\_PD\_CAS2122, AD\_PD\_CAS2219, AD\_PD\_CAS2220, AD\_PD\_CAS2221, AD\_PD\_CAS2222] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_reg\_write32(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const char \*const p\_device\_id,  const uintptr\_t offset,  const uint32\_t data  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| const char \*const p\_device\_id | | Pointer to the Target OSAL device ID. | |
| **Range** | Not NULL |
| const uintptr\_t offset | | Sets the offset address from Register top. | |
| **Range** | The offset  address should be specified as 4-byte alignment. |
| const uint32\_t data | | Data written to hardware registers. | |
| **Range** | None |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | The core is uninitialized. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_reg\_required

Table 2‑56: impdrv\_genctl\_reg\_required

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0028  impdrv\_genctl\_reg\_required  [Covers: AD\_PD\_CAS1021, AD\_PD\_CAS2124, AD\_PD\_CAS2223, AD\_PD\_CAS2224, AD\_PD\_CAS2225, AD\_PD\_CAS2226] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_reg\_required(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const char \*const p\_device\_id,  const [e\_impdrv\_reg\_req\_state\_t](#_e_impdrv_reg_req_state_t) new\_state  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| const char \*const p\_device\_id | | Pointer to the Target OSAL device ID. | |
| **Range** | Not NULL |
| const [e\_impdrv\_reg\_req\_state\_t](#_e_impdrv_reg_req_state_t) new\_state | | Required state to the Register read/write function. | |
| **Range** | Within the range of ENUM type |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | The core is uninitialized. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_check\_intclear

Table 2‑57: impdrv\_genctl\_check\_intclear

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0029  impdrv\_genctl\_check\_intclear  [Covers: AD\_PD\_CAS2360] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_check\_intclear(  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Specified core information. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_bus\_if\_check

Table 2‑58: impdrv\_genctl\_bus\_if\_check

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0034  impdrv\_genctl\_bus\_if\_check  [Covers: AD\_PD\_CAS2301, AD\_PD\_CAS2307, AD\_PD\_CAS2308, AD\_PD\_CAS2309, AD\_PD\_CAS2400, AD\_PD\_CAS2401, AD\_PD\_CAS2402, AD\_PD\_CAS2403, AD\_PD\_CAS2404, AD\_PD\_CAS2416] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_bus\_if\_check(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t) \*const p\_chk\_resource  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info, | | Pointer to the Core information data. | |
| **Range** | Not NULL |
| const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t) \*const p\_chk\_resource | | Pointer to the OSAL resource for bus interface check. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_conf\_reg\_check

Table 2‑59: impdrv\_genctl\_conf\_reg\_check

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0035  impdrv\_genctl\_conf\_reg\_check  [Covers: AD\_PD\_CAS2303, AD\_PD\_CAS2304, AD\_PD\_CAS2305, AD\_PD\_CAS2306, AD\_PD\_CAS2405, AD\_PD\_CAS2406, AD\_PD\_CAS2407, AD\_PD\_CAS2412, AD\_PD\_CAS2414, AD\_PD\_CAS2415] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_conf\_reg\_check(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const st\_impdrv\_chk\_param\_t \*const p\_chk\_param,  const uint32\_t param\_num,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl, | | General control handle | |
| **Range** | Not NULL |
| const [st\_impdrv\_chk\_param\_t](#_st_impdrv_chkparam_t(T.B.D.)) \*const p\_chk\_param | | Pointer to Array of check parameters. | |
| **Range** | Not NULL |
| const uint32\_t param\_num, | | Number of check parameters | |
| **Range** | Not NULL |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Pointer to the Core information data. | |
|  | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | The core is ready. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_set\_dsp

able 2‑62: impdrv\_genctl\_set\_dsp

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD0X\_XX\_XXXX  impdrv\_genctl\_set\_dsp  [Covers: AD\_PD\_CAS1009, AD\_PD\_CAS2276, AD\_PD\_CAS2277, AD\_PD\_CAS2278, AD\_PD\_CAS2279, AD\_PD\_CAS2579] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_set\_dsp(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_app,  const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_fw,  const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_data,  const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_dtcm  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info, | | Specified core information. | |
| **Range** | Not NULL |
| const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_app, | | Information of DSP data | |
| **Range** | Not NULL |
| const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_fw, | | Information of DSP data | |
| **Range** | Not NULL |
| const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_data | | Information of DSP data | |
| **Range** | Not NULL |
| const [st\_impdrv\_dsp\_data\_t](#_st_impdrv_dsp_data_t) \*const p\_dsp\_dtcm | | Information of DSP data | |
| **Range** | Not NULL |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | The core is ready. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_dsp\_int\_handler

Table 2‑62 impdrv\_genctl\_dsp\_int\_handler

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0017  impdrv\_genctl\_dsp\_int\_handler  [Covers: AD\_PD\_CAS1011, AD\_PD\_CAS2338, AD\_PD\_CAS2339, AD\_PD\_CAS2340, AD\_PD\_CAS2341, AD\_PD\_CAS2280, AD\_PD\_CAS2287, AD\_PD\_CAS2288] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | void impdrv\_genctl\_int\_handler(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const uint64\_t irq\_channel ,  const e\_impdrv\_errorcode\_t ercd,  const st\_impdrv\_core\_info\_t const core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can be called from OSAL interrupt. | | | |
| **Parameters (In)** | const uint64\_t irq\_channel | | IRQ channel associated with OSAL interrupt manager. | |
| **Range** | None. |
| Const e\_impdrv\_errorcode\_t ercd | | IMPDRV error code | |
| **Range** | Within the range of ENUM type. |
| const st\_impdrv\_core\_info\_t const core\_info | | Core information data | |
| **Range** |  |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | N/A | | N/A | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | IMP Driver execute is complete. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_set\_gosub\_cond

Table 2‑63: impdrv\_genctl\_set\_gosub\_cond

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0042  impdrv\_genctl\_set\_gosub\_cond  [Covers: AD\_PD\_CAS1031, AD\_PD\_CAS2263, AD\_PD\_CAS2264, AD\_PD\_CAS2265, AD\_PD\_CAS2273, AD\_PD\_CAS2274] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_set\_gosub\_cond(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const e\_impdrv\_gosub\_cond\_t condition  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Pointer to the Core information data. | |
| **Range** | Not NULL |
| const e\_impdrv\_gosub\_cond\_t condition | | Conditional GOSUB instruction attribute. | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl, | | General control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | The core is ready. | | | |
| **Remarks** | N/A | | | |

### Private function

#### impdrv\_genctl\_chk\_core\_info

Table 2‑60: impdrv\_genctl\_chk\_core\_info

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0021  impdrv\_genctl\_chk\_core\_info  [Covers: AD\_PD\_CAS3002] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_chk\_core\_info(  const st\_impdrv\_core\_info\_t core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t core\_info | | Core information for Specific core. | |
| **Range** | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_prologue

Table 2‑61: impdrv\_genctl\_prologue

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0022  impdrv\_genctl\_prologue  [Covers: AD\_PD\_CAS3002] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_prologue(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information for Specific core. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_epilogue

Table 2‑62: impdrv\_genctl\_epilogue

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0023  impdrv\_genctl\_epilogue  [Covers: AD\_PD\_CAS3002] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_epilogue(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const e\_impdrv\_errorcode\_t ercd  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| const e\_impdrv\_errorcode\_t  ercd | | Error code | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | Calling impdrv\_genctl\_prologue in advance. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_chk\_state\_init

Table 2‑63: impdrv\_genctl\_chk\_state\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0030  impdrv\_genctl\_chk\_state\_init  [Covers: AD\_PD\_CAS3002] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_chk\_state\_init (  const st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_corectl\_func\_t \*p\_funcs[IMPDRV\_INNER\_FIXED\_VALUE],  st\_impdrv\_core\_info\_t init\_core\_info[IMPDRV\_INNER\_FIXED\_VALUE],  uint32\_t \*const p\_init\_core\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | const st\_impdrv\_corectl\_func\_t \*p\_funcs[IMPDRV\_INNER\_FIXED\_VALUE] | | Array of specified control function | |
| st\_impdrv\_core\_info\_t init\_core\_info[IMPDRV\_INNER\_FIXED\_VALUE | | Array of the core of the Init state | |
| uint32\_t \*const p\_init\_core\_num | | Pointer to number of cores in Init state | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  [Update Information]   * Add Parameters (p\_funcs, init\_core\_info, p\_init\_core\_num) * Remove local variable (p\_funcs) * Replace local variable p\_funcs with Parameters p\_funcs * Update processing of Input parameter confirmation process for added Parameters * If impdrv\_\*\*\*ctl\_check\_state(INIT) return IMPDRV\_EC\_OK, store core information in Parameters init\_core\_info | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_chk\_state\_uninit

Table 2‑64: impdrv\_genctl\_chk\_state\_uninit

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0031  impdrv\_genctl\_chk\_state\_uninit  [Covers: AD\_PD\_CAS2072, AD\_PD\_CAS3002] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_chk\_state\_uninit (  const st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_set\_state\_uninit

Table 2‑65: impdrv\_genctl\_set\_state\_uninit

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0032  impdrv\_genctl\_set\_state\_uninit  [Covers: AD\_PD\_CAS2074, AD\_PD\_CAS3002] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_set\_state\_uninit (  const st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | const st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_core\_init

Table 2‑66: impdrv\_genctl\_core\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0033  impdrv\_genctl\_core\_init  [Covers: AD\_PD\_CAS2008, AD\_PD\_CAS2009, AD\_PD\_CAS2010, AD\_PD\_CAS2227, AD\_PD\_CAS2229, AD\_PD\_CAS3002] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_core\_init(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const st\_impdrv\_core\_info\_t core\_info[IMPDRV\_INNER\_FIXED\_VALUE],  const st\_impdrv\_corectl\_func\_t \*const p\_funcs[IMPDRV\_INNER\_FIXED\_VALUE]  const uint32\_t use\_core\_num,  const bool is\_dmac\_mb\_init  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t core\_info  [IMPDRV\_INNER\_FIXED\_VALUE] | | Core information | |
| **Range** | Not NULL |
| st\_impdrv\_corectl\_func\_t \*const p\_funcs  [IMPDRV\_INNER\_FIXED\_VALUE] | | Core function information | |
| **Range** | Not NULL |
| const uint32\_t use\_core\_num | | Use Core num | |
| **Range** | One or more. IMPDRV\_INNER\_FIXED\_VALUE or less. |
| Const bool is\_dmac\_mb\_init | | DMAC multi-bank initialization | |
| **Range** | true or false |
| **Parameters (In-Out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_init\_get\_func

Table 2‑67: impdrv\_genctl\_init\_get\_func

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0036  impdrv\_genctl\_init\_get\_func  [Covers: AD\_PD\_CAS2005] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_init\_get\_func (  const st\_impdrv\_initdata\_t \*const p\_data,  const uint32\_t use\_core\_num,  st\_impdrv\_core\_info\_t \*const p\_core\_array,  const st\_impdrv\_corectl\_func\_t \*\*const p\_func\_array  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_initdata\_t \*const p\_data | | Initialization data for IMP Driver. | |
| **Range** | Not NULL |
| const uint32\_t use\_core\_num | | Number of core information | |
| **Range** | Not 0.  Value less than IMPDRV\_INNER\_FIXED\_VALUE. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_core\_info\_t \*const p\_core\_array | | Array of specified core information | |
| **Range** | Not NULL |
| const st\_impdrv\_corectl\_func\_t \*\*const p\_func\_array | | Array of specified control function | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_init\_chk\_state

Table 2‑68: impdrv\_genctl\_init\_chk\_state

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0037  impdrv\_genctl\_init\_chk\_state  [Covers: AD\_PD\_CAS2006] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_init\_chk\_state (  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const uint32\_t use\_core\_num,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const st\_impdrv\_corectl\_func\_t \*\*const p\_funcs  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle. | |
| **Range** | Not NULL |
| const uint32\_t use\_core\_num | | Number of core information | |
| **Range** | Not 0.  Value less than IMPDRV\_INNER\_FIXED\_VALUE. |
| Const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Array of specified core information | |
| **Range** | Not NULL |
| const st\_impdrv\_corectl\_func\_t \*\*const p\_funcs | | Array of specified control function | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_init\_set\_state

Table 2‑69: impdrv\_genctl\_init\_set\_state

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0038  impdrv\_genctl\_init\_set\_state  [Covers: AD\_PD\_CAS2010] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_init\_set\_state (  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const uint32\_t use\_core\_num,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const st\_impdrv\_corectl\_func\_t \*\*const p\_funcs  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const uint32\_t use\_core\_num | | Number of core information | |
| **Range** | Not 0.  Value less than IMPDRV\_INNER\_FIXED\_VALUE. |
| Const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Array of specified core information | |
| **Range** | Not NULL |
| const st\_impdrv\_corectl\_func\_t \*\*const p\_funcs | | Array of specified control function | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle. | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_init\_attr\_init

Table 2‑70: impdrv\_genctl\_init\_attr\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0039  impdrv\_genctl\_init\_attr\_init  [Covers: AD\_PD\_CAS2227] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_genctl\_init\_attr\_init(  st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl,  const uint32\_t use\_core\_num,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const st\_impdrv\_corectl\_func\_t \*\*const p\_funcs  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const uint32\_t use\_core\_num | | Number of core information | |
| **Range** | Not 0.  Value less than IMPDRV\_INNER\_FIXED\_VALUE. |
| Const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Array of specified core information | |
| **Range** | Not NULL |
| const st\_impdrv\_corectl\_func\_t \*\*const p\_funcs | | Array of specified control function | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | General control handle. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_genctl\_get\_worksize

Table 2‑70: impdrv\_genctl\_get\_worksize

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_02\_0043  impdrv\_genctl\_get\_worksize  [Covers: AD\_PD\_CAS2289] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_genctl\_get\_worksize(  uint32\_t work\_type,  uint32\_t \*p\_work\_size  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | uint32\_t work\_type | | type of work size | |
| **Range** | Not 0. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_ctl\_t \*const p\_impdrv\_ctl | | size of work area | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

## Functions of Common Control

Table 2‑71: Function List

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **No.** | **Function Name** | **Access** | **ASIL** | **Source File Name** |
|  | impdrv\_cmnctl\_init | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_quit | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_judge\_int | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_mutex\_create | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_mutex\_destroy | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_mutex\_lock | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_mutex\_unlock | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_set\_irq\_group | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_get\_corectl\_func | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_get\_syncc\_val | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_fatal\_cb](#_impdrv_cmnctl_fatal_cb_1) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_chk\_instance\_num](#_impdrv_cmnctl_chk_instance_num) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_get\_io\_imptop](#_impdrv_cmnctl_get_io_imptop) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_get\_io\_dta](#_impdrv_cmnctl_get_io_dta) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_reg\_init](#_impdrv_cmnctl_reg_init) | Public | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_quit](#_impdrv_cmnctl_reg_quit_1) | Public | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_set\_mem\_protect](#_impdrv_cmnctl_reg_set_mem_protect) | Public | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_mem\_init](#_impdrv_cmnctl_reg_mem_init_1) | Public | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_get\_hw\_info](#_impdrv_cmnctl_reg_get_hw_info) | Public | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_read32](#_impdrv_cmnctl_reg_read32_1) | Public | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_write32](#_impdrv_cmnctl_reg_write32_1) | Public | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_required](#_impdrv_cmnctl_reg_required) | Public | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_save\_irq\_mask](#_impdrv_cmnctl_save_irq_mask) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_force\_irq\_mask](#_impdrv_cmnctl_force_irq_mask) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_restore\_irq\_mask](#_impdrv_cmnctl_restore_irq_mask) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_conf\_reg\_check](#_impdrv_cmnctl_conf_reg_check) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_reg\_chk\_mem\_protect](#_impdrv_cmnctl_reg_chk_mem_protect) | Public | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_get\_io\_dsp](#_impdrv_cmnctl_get_io_dsp) | Public | - | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_get\_init\_param](#_impdrv_cmnctl_get_init_param) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_get\_dsp\_func](#_impdrv_cmnctl_get_dsp_func) | Public | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_chk\_core\_info | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_cnv\_int\_core\_bit | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_cnv\_int\_bit\_core](#_impdrv_cmnctl_cnv_int_bit_core) | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_execute\_no\_group](#_impdrv_cmnctl_execute_no_group_1) | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_execute\_group](#_impdrv_cmnctl_execute_group_1) | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_chk\_init\_data](#_impdrv_cmnctl_chk_init_data) | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_chk\_group\_data](#_impdrv_cmnctl_chk_group_data) | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_get\_group](#_impdrv_cmnctl_get_group) | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_calc\_checksum | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_set\_checksum | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | impdrv\_cmnctl\_test\_checksum | Private | ASIL D | r\_impdrv\_cmnctl.c |
|  | [impdrv\_cmnctl\_reg\_hwrsc\_open](#_impdrv_cmnctl_reg_hwrsc_open) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_hwrsc\_close](#_impdrv_cmnctl_reg_hwrsc_close) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_pow\_on\_hwrsc](#_impdrv_cmnctl_reg_pow_on_hwrsc_1) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_pow\_off\_hwrsc](#_impdrv_cmnctl_reg_pow_off_hwrsc) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_find\_resource](#_impdrv_cmnctl_reg_find_resource) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_chk\_rsc\_name](#_impdrv_cmnctl_reg_chk_rsc_name) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_mb\_initialize](#_impdrv_cmnctl_reg_mb_initialize) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | impdrv\_cmnctl\_reg\_set\_checksum | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | impdrv\_cmnctl\_reg\_test\_checksum | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_spm\_preset](#_impdrv_cmnctl_reg_spm_preset) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_spm\_initialize](#_impimpdrv_cmnctl_reg_spm_initialize) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_spm\_ena\_access](#_impdrv_cmnctl_reg_spm_ena_access) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_spm\_wait\_init](#_impdrv_cmnctl_reg_spm_wait_init) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |
|  | [impdrv\_cmnctl\_reg\_spm\_chk\_init](#_impdrv_cmnctl_reg_spm_chk_init) | Private | ASIL D | r\_impdrv\_cmnctl\_reg.c |

### Public function

#### impdrv\_cmnctl\_init

Table 2‑72: impdrv\_cmnctl\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0001  impdrv\_cmnctl\_init  [Covers: AD\_PD\_CAS1001, AD\_PD\_CAS1002, AD\_PD\_CAS2021, AD\_PD\_CAS2022, AD\_PD\_CAS2023, AD\_PD\_CAS2024, AD\_PD\_CAS2025, AD\_PD\_CAS2026, AD\_PD\_CAS2027, AD\_PD\_CAS2028, AD\_PD\_CAS2079, AD\_PD\_CAS2080, AD\_PD\_CAS3003, AD\_PD\_CAS2046] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_init(  st\_impdrv\_commonctl\_t \*const p\_commonctl,  const [st\_impdrv\_cmn\_init\_data\_t](#_st_impdrv_cmn_init_data_t) \*const p\_cmn\_init\_data,  bool \*const p\_is\_dmac\_mb\_init  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const [st\_impdrv\_cmn\_init\_data\_t](#_st_impdrv_cmn_init_data_t) \*const p\_cmn\_init\_data | | Common control initialization data. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_commonctl\_t \*const p\_commonctl, | | Common Control handle. | |
| **Range** | Not NULL |
| bool \*const p\_is\_dmac\_mb\_init | | DMAC multi-bank initialization | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_INSTANCE  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | Must be in “Uninitialized State”. | | | |
| **Remarks** | p\_is\_dmac\_mb\_init is pointer of output parameter, so the use of this pointer variable is acceptable. | | | |

#### impdrv\_cmnctl\_quit

Table 2‑73: impdrv\_cmnctl\_quit

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0003  impdrv\_cmnctl\_quit  [Covers: AD\_PD\_CAS1004, AD\_PD\_CAS2083, AD\_PD\_CAS2084, AD\_PD\_CAS2086, AD\_PD\_CAS2087, AD\_PD\_CAS2088, AD\_PD\_CAS2089, AD\_PD\_CAS3003, AD\_PD\_CAS2085, AD\_PD\_CAS2047] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_quit(  st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_commonctl\_t \*const p\_commonctl | | The Common Control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | IMP Driver initialization is complete. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_judge\_int

Table 2‑74: impdrv\_cmnctl\_judge\_int

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0004  impdrv\_cmnctl\_judge\_int  [Covers: AD\_PD\_CAS1011, AD\_PD\_CAS2342, AD\_PD\_CAS2343, AD\_PD\_CAS2344, AD\_PD\_CAS2345, AD\_PD\_CAS2346, AD\_PD\_CAS2347] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_judge\_int(  const st\_impdrv\_commonctl\_t \*const p\_commonctl ,  const uint64\_t irq\_channel,  st\_impdrv\_core\_info\_t core\_info[IMPDRV\_INTSTS\_BITNUM] ,  uint32\_t \*const p\_use\_core\_num,  bool is\_fb\_callback  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can be called from OSAL interrupt. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t \*const p\_commonctl | | The Common Control handle | |
| **Range** | Not NULL |
| const uint64\_t irq\_channel | | IRQ channel associated with OSAL interrupt manager. | |
| **Range** | None |
| bool is\_fb\_callback | | Whether to callback | |
| **Range** | true or false |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_core\_info\_t core\_info[IMPDRV\_INTSTS\_BITNUM] | | Core lists information | |
| **Range** | Not NULL |
| uint32\_t \*const p\_use\_core\_num | | Number of using core. | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | p\_use\_core\_num is pointer of output parameter, so the use of this pointer variable is acceptable. | | | |

#### impdrv\_cmnctl\_mutex\_create

Table 2‑75: impdrv\_cmnctl\_mutex\_create

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0005  impdrv\_cmnctl\_mutex\_create  [Covers: AD\_PD\_CAS1001, AD\_PD\_CAS2013, AD\_PD\_CAS2014, AD\_PD\_CAS2015, AD\_PD\_CAS2060, AD\_PD\_CAS3003] | | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_mutex\_create(  const st\_impdrv\_commonctl\_t \*const p\_commonctl,  const osal\_mutex\_id\_t mutex\_id  const osal\_milli\_sec\_t time\_period  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const osal\_mutex\_id\_t  mutex\_id | | To set value of mutex id. | | | |
| **Range** | - | | |
| const osal\_milli\_sec\_t  time\_period | | Time period. | | | |
| **Range** | | 0 or more | |
| **Parameters (In-out)** | N/A | | N/A | | | |
| **Range** | | | N/A |
| **Parameters (Out)** | const st\_impdrv\_commonctl\_t \*const p\_commonctl | | The Common Control handle  The lifetime of this parameter is the period from the impdrv\_cmnctl\_mutex\_create is executed until impdrv\_cmnctl\_mutex\_destroy is executed. | | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_cmnctl\_mutex\_destroy

Table 2‑76: impdrv\_cmnctl\_mutex\_destroy

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0006  impdrv\_cmnctl\_mutex\_destroy  [Covers: AD\_PD\_CAS1004, AD\_PD\_CAS2061, AD\_PD\_CAS2093, AD\_PD\_CAS2094, AD\_PD\_CAS2095, AD\_PD\_CAS3003] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_mutex\_destroy(  const st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t \*const p\_commonctl, | | The Common Control handle  The lifetime of this parameter is the period from the impdrv\_cmnctl\_mutex\_create is executed until impdrv\_cmnctl\_mutex\_destroy is executed. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_mutex\_lock

Table 2‑77: impdrv\_cmnctl\_mutex\_lock

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0007  impdrv\_cmnctl\_mutex\_lock  [Covers: AD\_PD\_CAS2016, AD\_PD\_CAS2017, AD\_PD\_CAS2018, AD\_PD\_CAS3003] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_mutex\_lock(  st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_commonctl\_t \*const p\_commonctl | | The Common Control handle  The lifetime of this parameter is the period from the impdrv\_cmnctl\_mutex\_create is executed until impdrv\_cmnctl\_mutex\_destroy is executed. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Range** | N/A |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_mutex\_unlock

Table 2‑78: impdrv\_cmnctl\_mutex\_unlock

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0008  impdrv\_cmnctl\_mutex\_unlock  [Covers: AD\_PD\_CAS2029, AD\_PD\_CAS2030, AD\_PD\_CAS2031, AD\_PD\_CAS3003] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_mutex\_unlock(  st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | st\_impdrv\_commonctl\_t \*const p\_commonctl | | The Common Control handle  The lifetime of this parameter is the period from the impdrv\_cmnctl\_mutex\_create is executed until impdrv\_cmnctl\_mutex\_destroy is executed. | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Range** | | N/A |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_cmnctl\_set\_irq\_group

Table 2‑79: impdrv\_cmnctl\_set\_irq\_group

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0009  impdrv\_cmnctl\_set\_irq\_group  [Covers: AD\_PD\_CAS2078, AD\_PD\_CAS2216, AD\_PD\_CAS2217, AD\_PD\_CAS2357, AD\_PD\_CAS2358, AD\_PD\_CAS2359] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_set\_irq\_group(  const st\_impdrv\_commonctl\_t \*const p\_commonctl ,  const st\_impdrv\_irq\_group\_t \*const p\_irq\_param  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t \*const p\_commonctl | | The Common Control handle | | |
| **Range** | | Not NULL |
| const st\_impdrv\_irq\_group\_t \*const p\_irq\_param | | Setting IRQ group | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Range** | N/A | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ATTRIBUTE | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_cmnctl\_get\_corectl\_func

Table 2‑80: impdrv\_cmnctl\_get\_corectl\_func

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0010  impdrv\_cmnctl\_get\_corectl\_func  [Covers: AD\_PD\_CAS1001, AD\_PD\_CAS1004, AD\_PD\_CAS1003, AD\_PD\_CAS1007, AD\_PD\_CAS2019, AD\_PD\_CAS2020, AD\_PD\_CAS3003, AD\_PD\_CAS1005, AD\_PD\_CAS1006, AD\_PD\_CAS1008, AD\_PD\_CAS1009, AD\_PD\_CAS1010, AD\_PD\_CAS1011, AD\_PD\_CAS1014, AD\_PD\_CAS1015] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | const st\_impdrv\_corectl\_func\_t \* impdrv\_cmnctl\_get\_corectl\_func(  const e\_impdrv\_core\_type\_t core\_type  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_core\_type\_t core\_type | | Specified core type.  The lifetime of this parameter is until this function returns. | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | st\_impdrv\_corectl\_func\_t\* | | Address of Core control function table.  NULL If the argument is out of range | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_get\_syncc\_val

Table 2‑81: impdrv\_cmnctl\_get\_syncc\_val

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0011  impdrv\_cmnctl\_get\_syncc\_val  [Covers: AD\_PD\_CAS1008, AD\_PD\_CAS2081, AD\_PD\_CAS2161, AD\_PD\_CAS2162] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_get\_syncc\_val(  uint8\_t syncc\_val[IMPDRV\_COREMAP\_MAXID],  const st\_impdrv\_commonctl\_t \*const p\_commonctl,  const st\_impdrv\_core\_info\_t core\_map[IMPDRV\_COREMAP\_MAXID]); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t core\_map[IMPDRV\_COREMAP\_MAXID] | | Setting Core map | |
| **Range** | Not NULL |
| const st\_impdrv\_commonctl\_t \*const p\_commonctl | | Common Control handle | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | uint8\_t syncc\_val[IMPDRV\_COREMAP\_MAXID] | | Core sync value | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_ATTRIBUTE | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | syncc\_val is pointer of output parameter, so the use of this pointer variable is acceptable. | | | |

#### impdrv\_cmnctl\_fatal\_cb

Table 2‑82: impdrv\_cmnctl\_fatal\_cb

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0016  impdrv\_cmnctl\_fatal\_cb  [Covers: AD\_PD\_CAS2349, AD\_PD\_CAS2350] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_fatal\_cb(  const st\_impdrv\_commonctl\_t \*const p\_commonctl,  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const e\_impdrv\_fatalcode\_t fatal\_code,  const e\_impdrv\_errorcode\_t error\_code  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t \*const p\_commonctl | | The Common Control handle | |
| **Range** | Not NULL |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core lists information. | |
| **Range** | Not NULL |
| const e\_impdrv\_fatalcode\_t fatal\_code | | Fatal callback result code. | |
| **Range** | None |
| const e\_impdrv\_errorcode\_t error\_code | | IMP Driver error code. | |
| **Range** | None |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | [e\_impdrv\_errorcode\_t](#_API_Layer) | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Fatal callback to the framework.  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_chk\_instance\_num

Table 2‑83: impdrv\_cmnctl\_chk\_instance\_num

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0013  impdrv\_cmnctl\_chk\_instance\_num  [Covers: AD\_PD\_CAS3003] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_chk\_instance\_num(  const e\_impdrv\_instance\_t instance\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_get\_io\_imptop

Table 2‑84: impdrv\_cmnctl\_get\_io\_imptop

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0020  impdrv\_cmnctl\_get\_io\_imptop  [Covers: AD\_PD\_CAS2129, AD\_PD\_CAS2291, AD\_PD\_CAS2296] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_get\_io\_imptop (  st\_impdrv\_device\_handle\_t \*const p\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_device\_handle\_t  \*const p\_handle | | Device handle of ‘imp\_top’ resource. | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_get\_io\_dta

Table 2‑85: impdrv\_cmnctl\_get\_io\_dta

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0021  impdrv\_cmnctl\_get\_io\_dta  [Covers: AD\_PD\_CAS1019] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_get\_io\_dta (  st\_impdrv\_device\_handle\_t \*const p\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_device\_handle\_t  \*const p\_handle | | Device handle of ‘imp\_dta’ resource. | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_reg\_init

Table 2‑86: impdrv\_cmnctl\_reg\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0025  impdrv\_cmnctl\_reg\_init  [Covers: AD\_PD\_CAS1022, AD\_PD\_CAS2228, AD\_PD\_CAS2126, AD\_PD\_CAS2127, AD\_PD\_CAS2128, AD\_PD\_CAS2027, AD\_PD\_CAS2028, AD\_PD\_CAS2029, AD\_PD\_CAS2133, AD\_PD\_CAS2134, AD\_PD\_CAS2135] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_init (  st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_commonctl\_t  \*const p\_commonctl | | The Common Control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_reg\_quit

Table 2‑87: impdrv\_cmnctl\_reg\_quit

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0026  impdrv\_cmnctl\_reg\_quit  [Covers: AD\_PD\_CAS1004, AD\_PD\_CAS2230, AD\_PD\_CAS2145, AD\_PD\_CAS2146, AD\_PD\_CAS2147, AD\_PD\_CAS2148, AD\_PD\_CAS2152, AD\_PD\_CAS2153, AD\_PD\_CAS2154] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_quit (  st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_commonctl\_t  \*const p\_commonctl | | The Common Control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_reg\_set\_mem\_protect

Table 2‑93: impdrv\_cmnctl\_reg\_set\_mem\_protect

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0039  impdrv\_cmnctl\_reg\_set\_mem\_protect  [Covers: AD\_PD\_CAS2201, AD\_PD\_CAS2155, AD\_PD\_CAS2158, AD\_PD\_CAS2159] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_set\_mem\_protect (  st\_impdrv\_commonctl\_t \*const p\_commonctl,  const [***e\_impdrv\_protect\_mode\_t***](#_e_impdrv_protect_mode_t)  protect\_mode  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const [***e\_impdrv\_protect\_mode\_t***](#_e_impdrv_protect_mode_t)  protect\_mode | | Memory protection setting. | | |
| **Range** | | Within the range of ENUM type. |
| **Parameters (In-out)** | st\_impdrv\_commonctl\_t  \*const p\_commonctl | | The Common Control handle | | |
| **Range** | Not NULL | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | ECC: V3M and V3H are not supported. | | | | |

#### impdrv\_cmnctl\_reg\_mem\_init

Table 2‑89: impdrv\_cmnctl\_reg\_mem\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0027  impdrv\_cmnctl\_reg\_mem\_init  [Covers: AD\_PD\_CAS1023, AD\_PD\_CAS2082, AD\_PD\_CAS2136, AD\_PD\_CAS2137, AD\_PD\_CAS2138, AD\_PD\_CAS2141, AD\_PD\_CAS2142, AD\_PD\_CAS2143, AD\_PD\_CAS2144] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_mem\_init (  st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_commonctl\_t  \*const p\_commonctl | | The Common Control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_reg\_get\_hw\_info

Table 2‑90: impdrv\_cmnctl\_reg\_get\_hw\_info

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0028  impdrv\_cmnctl\_reg\_get\_hw\_info  [Covers: AD\_PD\_CAS1018, AD\_PD\_CAS2208, AD\_PD\_CAS2160, AD\_PD\_CAS2163, AD\_PD\_CAS2164] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_get\_hw\_info (  st\_impdrv\_commonctl\_t \*const p\_commonctl,  const char \*const p\_device\_id, [***st\_impdrv\_reg\_info\_t***](#_API_Layer) \*const info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Permitted | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_commonctl\_t  \*const p\_commonctl | | The Common Control handle | |
| **Range** | Not NULL |
| const char \*const p\_device\_id, | | Pointer to Target OSAL device ID. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | [***st\_impdrv\_reg\_info\_t***](#_API_Layer) \*const info | | Pointer to Hardware register area specification information. | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_reg\_read32

Table 2‑91: impdrv\_cmnctl\_reg\_read32

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0029  impdrv\_cmnctl\_reg\_read32  [Covers: AD\_PD\_CAS1019, AD\_PD\_CAS2214, AD\_PD\_CAS2165, AD\_PD\_CAS2166, AD\_PD\_CAS2167, AD\_PD\_CAS2171, AD\_PD\_CAS2172] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_read32(  const st\_impdrv\_commonctl\_t \*const p\_commonctl,  const char \*const p\_device\_id,  const uintptr\_t offset,  uint32\_t \*const p\_data  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t  \*const p\_commonctl | | Common control handle | | |
| **Range** | Not NULL | |
| const char \*const  p\_device\_id, | | Pointer to Target OSAL device ID. | | |
| **Range** | Not NULL | |
| const uintptr\_t offset | | Sets the offset address from Register top. | | |
| **Range** | The offset  address should be specified as 4-byte alignment. | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | uint32\_t \*const p\_data | | Pointer to the read data to hardware registers. | | |
| **Range** | | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_cmnctl\_reg\_write32

Table 2‑92: impdrv\_cmnctl\_reg\_write32

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0030  impdrv\_cmnctl\_reg\_read32  [Covers: AD\_PD\_CAS1020, AD\_PD\_CAS2220, AD\_PD\_CAS2173, AD\_PD\_CAS2174, AD\_PD\_CAS2177, AD\_PD\_CAS2178, AD\_PD\_CAS2179] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_write32(  const st\_impdrv\_commonctl\_t \*const p\_impdrv\_ctl,  const char \*const p\_device\_id,  const uintptr\_t offset,  const uint32\_t data  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t  \*const p\_impdrv\_ctl | | Common control handle | |
| **Range** | Not NULL |
| const char \*const  p\_device\_id, | | Pointer to Target OSAL device ID. | |
| **Range** | Not NULL |
| const uintptr\_t offset | | Sets the offset address from Register top. | |
| **Range** | The offset  address should be specified as 4-byte alignment. |
| const uint32\_t data | | Data written to hardware registers. | |
| **Range** | None |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_reg\_required

Table 2‑98: impdrv\_cmnctl\_reg\_required

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0031  impdrv\_cmnctl\_reg\_required  [Covers: AD\_PD\_CAS1021, AD\_PD\_CAS2224, AD\_PD\_CAS2180, AD\_PD\_CAS2181, AD\_PD\_CAS2182, AD\_PD\_CAS2183, AD\_PD\_CAS2184] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_required(  const st\_impdrv\_commonctl\_t \*const p\_impdrv\_ctl,  const char \*const p\_device\_id,  const [e\_impdrv\_reg\_req\_state\_t](#_e_impdrv_reg_req_state_t) new\_state  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t  \*const p\_impdrv\_ctl | | Common control handle | |
| **Range** | Not NULL |
| const char \*const  p\_device\_id, | | Pointer to Target OSAL device ID. | |
| **Range** | Not NULL |
| const [e\_impdrv\_reg\_req\_state\_t](#_e_impdrv_reg_req_state_t) new\_state | | Required state to the Register read/write function. | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_save\_irq\_mask

Table 2‑94: impdrv\_cmnctl\_save\_irq\_mask

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0040  impdrv\_cmnctl\_save\_irq\_mask  [Covers: AD\_PD\_CAS2308, AD\_PD\_CAS2513, AD\_PD\_CAS2481] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_save\_irq\_mask (  st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_commonctl\_t  \*const p\_commonctl | | Common control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | This function is save the current IRQ mask settings .  To do so, do the following.  ・Check the Instance number value.  ・Read the IRQ mask register value.  ・Save the IRQ mask register value.  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_force\_irq\_mask

Table 2‑95: impdrv\_cmnctl\_force\_irq\_mask

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0041  impdrv\_cmnctl\_force\_irq\_mask  [Covers: AD\_PD\_CAS2309, AD\_PD\_CAS2482, AD\_PD\_CAS2483] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_force\_irq\_mask (  const st\_impdrv\_commonctl\_t \*const p\_commonctl  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t  \*const p\_commonctl | | Common control handle | |
| **Range** | Not NULL |
| const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | This function is force setting the IRQ mask with no group.  To do so, do the following.  ・Check the Instance number value.  ・Write the IRQ mask register  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_restore\_irq\_mask

Table 2‑96: impdrv\_cmnctl\_restore\_irq\_mask

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0049  impdrv\_cmnctl\_restore\_irq\_mask  [Covers: AD\_PD\_CAS2402, AD\_PD\_CAS2484, AD\_PD\_CAS2485] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_restore\_irq\_mask (  const st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | const st\_impdrv\_commonctl\_t  \*const p\_commonctl | | Common control handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | This function is restore the IRQ mask settings form save data.  To do so, do the following.  ・Check the Instance number value.  ・Restore of IRQ mask register.  ・Save the IRQ mask register value.  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### pdrv\_cmnctl\_conf\_reg\_check

Table 2‑97: impdrv\_cmnctl\_conf\_reg\_check

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0042  impdrv\_cmnctl\_conf\_reg\_check  [Covers: AD\_PD\_CAS2412, AD\_PD\_CAS2486, AD\_PD\_CAS2487] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_conf\_reg\_check(  const st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t  \*const p\_commonctl | | Common control handle | |
| **Range** | Not NULL |
| **Parameters(In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | This function is configuration register check in Common control .  To do so, do the following.  ・Read the configuration register  ・Check the configuration register  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_reg\_chk\_mem\_protect

Table 2‑98: impdrv\_cmnctl\_reg\_chk\_mem\_protect

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0043  impdrv\_cmnctl\_reg\_chk\_mem\_protect  [Covers: AD\_PD\_CAS2412, AD\_PD\_CAS2533, AD\_PD\_CAS2534, AD\_PD\_CAS2535] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_chk\_mem\_protect(  const st\_impdrv\_commonctl\_t \*const p\_commonctl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t  \*const p\_commonctl | | Common control handle | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | This function is check the Memory protection mode.  To do so, do the following.  ・Check the Memory protection setting  Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_get\_io\_dsp

Not Use (Out of scope)

#### impdrv\_cmnctl\_get\_init\_param

Table 2‑101: impdrv\_cmnctl\_get\_init\_param

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0056  impdrv\_cmnctl\_get\_init\_param  [Covers: AD\_PD\_CAS1034, AD\_PD\_CAS2297, AD\_PD\_CAS2310] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_get\_init\_param(  const st\_impdrv\_commonctl\_t \*const p\_commonctl,  e\_osal\_interrupt\_priority\_t \*const p\_irq\_priority,  [impdrv\_ctrl\_handle\_t](#_impdrv_ctrl_handle_t)  \*const p\_osal\_cb\_args  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t  \*const p\_commonctl | | Common control handle | | |
| **Range** | Not NULL | |
| **Parameters(In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | e\_osal\_interrupt\_priority\_t \*const p\_irq\_priority | | The value of interrupt priority | | |
| **Range** | | Within the range of ENUM type |
| [impdrv\_ctrl\_handle\_t](#_impdrv_ctrl_handle_t)  \*const p\_osal\_cb\_args | | Interrupt handler function's argument. | | |
| **Range** | | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_cmnctl\_get\_dsp\_func

Table 2‑98: impdrv\_cmnctl\_get\_dsp\_func

|  |  |  |  |
| --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0045  impdrv\_cmnctl\_get\_dsp\_func  [Covers: AD\_PD\_CAS2324, AD\_PD\_CAS2325, AD\_PD\_CAS2327, AD\_PD\_CAS2328, AD\_PD\_CAS2348, AD\_PD\_CAS2362, AD\_PD\_CAS2290] | | |
| **ASIL Level** | ASIL D | **Status** | New |
| **Syntax** | p\_impdrv\_dspctl\_dsp\_start\_t impdrv\_cmnctl\_get\_dsp\_func(  void  ); | | |
| **Sync/Async** | Synchronous | | |
| **Reentrancy** | Reentrant | | |
| **Interrupt State** | . | | |
| **Parameters (In)** | N/A | | N/A |
| **Parameters(In-out)** | N/A | | N/A |
| **Parameters (Out)** | N/A | | N/A |
| **Return Value** | p\_impdrv\_dspctl\_dsp\_start\_t | | Function pointer of the Control start of DSP core pre-preparation. |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | |
| **Preconditions** | N/A | | |
| **Remarks** | N/A | | |

### Private function

#### impdrv\_cmnctl\_chk\_core\_info

Table 2‑99: impdrv\_cmnctl\_chk\_core\_info

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0012  impdrv\_cmnctl\_chk\_core\_info  [Covers: AD\_PD\_CAS3003] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_chk\_core\_info(  const st\_impdrv\_core\_info\_t core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t core\_info | | Core information for Specific core. | |
| **Range** | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_cnv\_int\_core\_bit

Table 2‑100: impdrv\_cmnctl\_cnv\_int\_core\_bit

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0014  impdrv\_cmnctl\_cnv\_int\_core\_bit  [Covers: AD\_PD\_CAS2021] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_cnv\_int\_core\_bit(  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const uint32\_t use\_core\_num,  const st\_impdrv\_inten\_tbl\_t \*const p\_s\_inten\_cnv\_table,  const uint32\_t cnv\_table\_num,  uint32\_t \*const p\_val  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Array of core information. | |
| **Range** | Not NULL |
| const uint32\_t use\_core\_num | | Maximum number of cores | |
| **Range** | One or more.  IMPDRV\_INNER\_FIXED\_VALUE or less. |
| Const st\_impdrv\_inten\_tbl\_t \*const p\_s\_inten\_cnv\_table | | Array of convert information | |
| **Range** | Not NULL |
| const uint32\_t cnv\_table\_num | | Number of elements in array p\_s\_inten\_cnv\_table[] | |
| **Range** | One or more. IMPDRV\_INNER\_FIXED\_VALUE or less. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Range** | N/A |
| **Parameters (Out)** | uint32\_t \*const p\_val | | Address of area to output value. | |
| **Return Value** | [e\_impdrv\_errorcode\_t](#_API_Layer) | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | p\_val is pointer of output parameter, so the use of this pointer variable is acceptable. | | | |

#### impdrv\_cmnctl\_cnv\_int\_bit\_core

Table 2‑101: impdrv\_cmnctl\_cnv\_int\_bit\_core

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0017  impdrv\_cmnctl\_cnv\_int\_bit\_core  [Covers: AD\_PD\_CAS2331] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_cnv\_int\_bit\_core(  const st\_impdrv\_inten\_tbl\_t \*const p\_s\_inten\_cnv\_table,  const uint32\_t cnv\_table\_num,  const uint32\_t stat,  st\_impdrv\_core\_info\_t core\_info[IMPDRV\_INTSTS\_BITNUM],  uint32\_t \*const p\_use\_core\_num  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_inten\_tbl\_t \*const p\_s\_inten\_cnv\_table | | Array of convert information | | |
| **Range** | Not NULL | |
| const uint32\_t cnv\_table\_num | | Number of elements in array p\_s\_inten\_cnv\_table[] | | |
| **Range** | Maximum number of cores for the Interrupt group. | |
| Const uint32\_t stat | | Register value. | | |
| **Range** | None | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | [st\_impdrv\_core\_info\_t](#_API_Layer_2)  core\_info[IMPDRV\_INTSTS\_BITNUM] | | Array of core information. | | |
| **Range** | | Not NULL |
| uint32\_t  \*const p\_use\_core\_num | | Number of using core. | | |
| **Range** | | Not NULL |
| **Return Value** | [e\_impdrv\_errorcode\_t](#_API_Layer) | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | p\_use\_core\_num is pointer of output parameter, so the use of this pointer variable is acceptable. | | | | |

#### impdrv\_cmnctl\_execute\_no\_group

Table 2‑102: impdrv\_cmnctl\_execute\_no\_group

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0018  impdrv\_cmnctl\_execute\_no\_group  [Covers: AD\_PD\_CAS2357, AD\_PD\_CAS2358, AD\_PD\_CAS2359] | | | |
| **ASIL Level** | ASIL D | **ASIL Level** | ASIL D | |
| **Syntax** | IMPDRV\_STATIC  [e\_impdrv\_errorcode\_t](#_API_Layer) impdrv\_cmnctl\_execute\_no\_group (  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const st\_impdrv\_group\_tbl\_t \*const p\_inten\_group\_table,  const e\_impdrv\_instance\_t instance\_num,  const uint32\_t write\_val  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Range** | Not NULL |
| const st\_impdrv\_group\_tbl\_t \*const p\_inten\_group\_table | | Interrupt group register. | |
| **Range** | Not NULL |
| const e\_impdrv\_instance\_t instance\_num | | Instance number. | |
| **Range** | Within the range of ENUM type. |
| Const uint32\_t write\_val | | Interrupt register value. | |
| **Range** | None |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | [e\_impdrv\_errorcode\_t](#_API_Layer) | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | Can be executed in the “Ready State”. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_execute\_group

Table 2‑103: impdrv\_cmnctl\_execute\_group

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0019  impdrv\_cmnctl\_execute\_group  [Covers: AD\_PD\_CAS2357, AD\_PD\_CAS2358, AD\_PD\_CAS2359] | | | |
| **ASIL Level** | ASIL D | **ASIL Level** | ASIL D | |
| **Syntax** | IMPDRV\_STATIC  [e\_impdrv\_errorcode\_t](#_API_Layer) impdrv\_cmnctl\_execute\_group (  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const st\_impdrv\_group\_tbl\_t \*const p\_inten\_group\_table,  const e\_impdrv\_instance\_t instance\_num,  const uint32\_t group\_reg\_write\_val,  const e\_impdrv\_irq\_group\_t irq\_group;  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Range** | Not NULL |
| const st\_impdrv\_group\_tbl\_t \*const p\_inten\_group\_table | | Array of interrupt group register. | |
| **Range** | Not NULL |
| const e\_impdrv\_instance\_t instance\_num | | Instance number. | |
| **Range** | Within the range of ENUM type. |
| Const uint32\_t group\_reg\_write\_val | | Value to set to interrupt register. | |
| **Range** | None |
| const e\_impdrv\_irq\_group\_t  irq\_group | | Interrupt group number. | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | [e\_impdrv\_errorcode\_t](#_API_Layer) | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | Can be executed in the “Ready State”. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_cmnctl\_chk\_init\_data

Table 2‑104: impdrv\_cmnctl\_chk\_init\_data

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0022  impdrv\_cmnctl\_chk\_init\_data  [Covers: AD\_PD\_CAS3003] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | [Other than R-Car V4H2]  IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_chk\_init\_data(  const st\_impdrv\_commonctl\_t \*const p\_commonctl,  const [st\_impdrv\_cmn\_init\_data\_t](#_st_impdrv_cmn_init_data_t) \*const p\_cmn\_init\_data,  const bool \*const p\_is\_dmac\_mb\_init,  uint32\_t \*const p\_use\_core\_info  );  [R-Car V4H2]  IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_chk\_init\_data(  const st\_impdrv\_commonctl\_t \*const p\_commonctl,  const [st\_impdrv\_cmn\_init\_data\_t](#_st_impdrv_cmn_init_data_t) \*const p\_cmn\_init\_data,  const bool \*const p\_is\_dmac\_mb\_init,  uint32\_t \*const p\_use\_core\_info,  uint32\_t \*const p\_use\_dsp\_core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t \*const p\_commonctl, | | Common Control handle. | |
| **Range** | Not NULL |
| const [st\_impdrv\_cmn\_init\_data\_t](#_st_impdrv_cmn_init_data_t) \*const p\_cmn\_init\_data | | Common control initialization data. | |
| **Range** | Not NULL |
| const bool \*const p\_is\_dmac\_mb\_init | | MAC multi-bank initialization | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | uint32\_t \*const p\_use\_core\_info | | Use core information | |
| **Range** | Not NULL |
| uint32\_t \*const p\_use\_dsp\_core\_info | | [Use R-Car V4h2 Only]  Use DSP core information. | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_INSTANCE  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None | | | |
| **Remarks** | p\_use\_core\_info is pointer of output parameter, so the use of this pointer variable is acceptable. | | | |

#### impdrv\_cmnctl\_chk\_group\_data

Table 2‑105: impdrv\_cmnctl\_chk\_group\_data

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0023  impdrv\_cmnctl\_chk\_group\_data  [Covers: AD\_PD\_CAS3003] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_chk\_group\_data(  const st\_impdrv\_commonctl\_t \*const p\_commonctl,  const st\_impdrv\_irq\_group\_t, \*const p\_irq\_param  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_commonctl\_t \*const p\_commonctl, | | Common Control handle. | |
| **Range** | Not NULL |
| const st\_impdrv\_irq\_group\_t, \*const p\_irq\_param | | Setting IRQ group. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_get\_group

Table 2‑106: impdrv\_cmnctl\_get\_group

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0024  impdrv\_cmnctl\_get\_group  [Covers: AD\_PD\_CAS3003, AD\_PD\_CAS2085, AD\_PD\_CAS2343] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_get\_group(  e\_impdrv\_irq\_group\_t \*const p\_irq\_group,  const e\_impdrv\_instance\_t instance\_num  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Interrupt register value. | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | | |
| **Range** | | Within the range of ENUM type. |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | None | | | | |
| **Remarks** | None | | | | |

#### impdrv\_cmnctl\_calc\_checksum

Table 2‑107: impdrv\_cmnctl\_calc\_checksum

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0044  impdrv\_cmnctl\_calc\_checksum  [Covers: AD\_PD\_CAS2522, AD\_PD\_CAS2523, AD\_PD\_CAS2524] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_calc\_checksum(  const void\* \*const p\_data,  const size\_t size,  uint32\_t \*const p\_checksum  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const void\*  \*const p\_data | | Start address | |
| **Range** | Not NULL |
| const size\_t  size | | Data size | |
| **Range** | N/A |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | uint32\_t  \*const p\_checksum | | Checksum value | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None | | | |
| **Remarks** | p\_checksum is pointer of output parameter, so the use of this pointer variable is acceptable. | | | |

#### impdrv\_cmnctl\_set\_checksum

Table 2‑108: impdrv\_cmnctl\_set\_checksum

|  |  |  |  |
| --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0047  impdrv\_cmnctl\_set\_checksum  [Covers: AD\_PD\_CAS2522, AD\_PD\_CAS2524] | | |
| **ASIL Level** | ASIL D | **Status** | New |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_set\_checksum(  void  ); | | |
| **Sync/Async** | Synchronous | | |
| **Reentrancy** | Non-Reentrant | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | |
| **Parameters (In)** | N/A | | N/A |
| **Parameters (In-out)** | N/A | | N/A |
| **Parameters (Out)** | N/A | | N/A |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL |
| **Description** | Refer to “3 Activity Diagrams”. | | |
| **Preconditions** | None | | |
| **Remarks** | None | | |

#### impdrv\_cmnctl\_test\_checksum

Table 2‑109: impdrv\_cmnctl\_test\_checksum

|  |  |  |  |
| --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0048  impdrv\_cmnctl\_test\_checksum  [Covers: AD\_PD\_CAS2523] | | |
| **ASIL Level** | ASIL D | **Status** | New |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_test\_checksum(  void  ); | | |
| **Sync/Async** | Synchronous | | |
| **Reentrancy** | Non-Reentrant | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | |
| **Parameters (In)** | N/A | | N/A |
| **Parameters (In-out)** | N/A | | N/A |
| **Parameters (Out)** | N/A | | N/A |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR |
| **Description** | Refer to “3 Activity Diagrams”. | | |
| **Preconditions** | None | | |
| **Remarks** | None | | |

#### impdrv\_cmnctl\_reg\_hwrsc\_open

Table 2‑110: impdrv\_cmnctl\_reg\_hwrsc\_open

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0032  impdrv\_cmnctl\_reg\_hwrsc\_open  [Covers: AD\_PD\_CAS2129] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_hwrsc\_open(  const e\_impdrv\_instance\_t instance\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_reg\_hwrsc\_close

Table 2‑111: impdrv\_cmnctl\_reg\_hwrsc\_close

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0033  impdrv\_cmnctl\_reg\_hwrsc\_close  [Covers: AD\_PD\_CAS2148] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_hwrsc\_close (  const e\_impdrv\_instance\_t instance\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams” | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_reg\_pow\_on\_hwrsc

Table 2‑112: impdrv\_cmnctl\_reg\_pow\_on\_hwrsc

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0034  impdrv\_cmnctl\_reg\_pow\_on\_hwrsc  [Covers: AD\_PD\_CAS2129] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_pow\_on\_hwrsc(  const e\_impdrv\_instance\_t instance\_num,  const uint32\_t index  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| Const uint32\_t index | | Index number to Management table | |
| **Range** | Value less than IMPDRV\_HWRSC\_TABLE\_NUM |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_reg\_pow\_off\_hwrsc

Table 2‑113: impdrv\_cmnctl\_reg\_pow\_off\_hwrsc

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0035  impdrv\_cmnctl\_reg\_pow\_off\_hwrsc  [Covers: AD\_PD\_CAS2148] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_pow\_off\_hwrsc(  const e\_impdrv\_instance\_t instance\_num,  const uint32\_t index  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| Const uint32\_t index | | Index number to Management table | |
| **Range** | Value less than IMPDRV\_HWRSC\_TABLE\_NUM |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_reg\_find\_resource

Table 2‑114: impdrv\_cmnctl\_reg\_find\_resource

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0036  impdrv\_cmnctl\_reg\_find\_resource  [Covers: AD\_PD\_CAS2126, AD\_PD\_CAS2160, AD\_PD\_CAS2174, AD\_PD\_CAS2181] | | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_find\_resource(  const char \*const p\_device\_id,  uint32\_t \*const p\_index,  [st\_impdrv\_hwrsc\_def\_t](#_st_impdrv_hwrsc_def_t) \*const p\_resource  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | | | |
| **Range** | Within the range of ENUM type. | | |
| **Parameters (In-out)** | N/A | | N/A | | | |
| **Parameters (Out)** | uint32\_t \*const p\_index | | Pointer to Resource index value. | | | |
| **Range** | | Not NULL | |
| [st\_impdrv\_hwrsc\_def\_t](#_st_impdrv_hwrsc_def_t) \*const p\_resource | | Pointer to Resource definition data | | | |
| **Range** | | | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| **Preconditions** | None | | | | | |
| **Remarks** | None | | | | | |

#### impdrv\_cmnctl\_reg\_chk\_rsc\_name

Table 2‑115: impdrv\_cmnctl\_reg\_chk\_rsc\_name

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0037  impdrv\_cmnctl\_reg\_chk\_rsc\_name  [Covers: AD\_PD\_CAS3003] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_chk\_rsc\_name(  const char \*const p\_rsc\_name,  const char \*const p\_device\_id  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const char \*const p\_rsc\_name | | Pointer to Resource name string. | |
| **Range** | Not NULL |
| const char \*const p\_device\_id | | Pointer to the Target OSAL device ID. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_reg\_mb\_initialize

Table 2‑116: impdrv\_cmnctl\_reg\_mb\_initialize

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0038  impdrv\_cmnctl\_reg\_mb\_initialize  [Covers: AD\_PD\_CAS2141, AD\_PD\_CAS2142] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_mb\_initialize(  const [e\_impdrv\_mb\_mem\_init\_t](#_e_impdrv_mb_mem_init_t) mb\_mem\_init\_kind  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const [e\_impdrv\_mb\_mem\_init\_t](#_e_impdrv_mb_mem_init_t) mb\_mem\_init\_kind | | Multi-Bank memory initialization kind | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_reg\_set\_checksum

Table 2‑117: impdrv\_cmnctl\_reg\_set\_checksum

|  |  |  |  |
| --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0055  impdrv\_cmnctl\_reg\_set\_checksum  [Covers: AD\_PD\_CAS2522, AD\_PD\_CAS2524] | | |
| **ASIL Level** | ASIL D | **Status** | New |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_set\_checksum(  void  ); | | |
| **Sync/Async** | Synchronous | | |
| **Reentrancy** | Non-Reentrant | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | |
| **Parameters (In)** | N/A | | N/A |
| **Parameters (In-out)** | N/A | | N/A |
| **Parameters (Out)** | N/A | | N/A |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL |
| **Description** | Refer to “3 Activity Diagrams”. | | |
| **Preconditions** | None | | |
| **Remarks** | None | | |

#### impdrv\_cmnctl\_reg\_test\_checksum

Table 2‑118: impdrv\_cmnctl\_reg\_test\_checksum

|  |  |  |  |
| --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0046  impdrv\_cmnctl\_reg\_test\_checksum  [Covers: AD\_PD\_CAS2523] | | |
| **ASIL Level** | ASIL D | **Status** | New |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_test\_checksum(  void  ); | | |
| **Sync/Async** | Synchronous | | |
| **Reentrancy** | Non-Reentrant | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | |
| **Parameters (In)** | N/A | | N/A |
| **Parameters (In-out)** | N/A | | N/A |
| **Parameters (Out)** | N/A | | N/A |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR |
| **Description** | Refer to “3 Activity Diagrams”. | | |
| **Preconditions** | None | | |
| **Remarks** | None | | |

#### impdrv\_cmnctl\_reg\_spm\_preset

Table 2‑126: impdrv\_cmnctl\_reg\_spm\_preset

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0050  impdrv\_cmnctl\_reg\_spm\_preset  [Covers: AD\_PD\_CAS2141] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_spm\_preset (  const e\_impdrv\_instance\_t instance\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams” | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impimpdrv\_cmnctl\_reg\_spm\_initialize

Table 2‑127:impdrv\_cmnctl\_reg\_spm\_initialize

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0054  impdrv\_cmnctl\_reg\_spm\_initialize  [Covers: AD\_PD\_CAS2141, AD\_PD\_CAS2142] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_spm\_initialize (  const e\_impdrv\_instance\_t instance\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams” | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_reg\_spm\_ena\_access

Table 2‑128: impdrv\_cmnctl\_reg\_spm\_ena\_access

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0051  impdrv\_cmnctl\_reg\_spm\_ena\_access  [Covers: AD\_PD\_CAS2141] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_spm\_ena\_access (  const uint32\_t index,  const bool enable  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const uint32\_t index | | Index number to Management table. | |
| **Range** | Value less than IMPDRV\_HWRSC\_TABLE\_NUM |
| const bool enable | | Enable flag of SPM register access. | |
| **Range** | true or false |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | MPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_reg\_spm\_wait\_init

Table 2‑129:impdrv\_cmnctl\_reg\_spm\_wait\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0053  impdrv\_cmnctl\_reg\_spm\_wait\_init  [Covers: AD\_PD\_CAS2136] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_spm\_wait\_init (  const e\_impdrv\_instance\_t instance\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams” | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

#### impdrv\_cmnctl\_reg\_spm\_chk\_init

Table 2‑129:impdrv\_cmnctl\_reg\_spm\_chk\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_03\_0052  impdrv\_cmnctl\_reg\_spm\_chk\_init  [Covers: AD\_PD\_CAS2136] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_cmnctl\_reg\_spm\_chk\_init (  const e\_impdrv\_instance\_t instance\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| const uint32\_t num\_devices | | Number of Target OSAL device ID. | |
| **Range** | Not 0. |
| const char \*const\*const p\_device\_id | | Pointer to the Target OSAL device ID. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams” | | | |
| **Preconditions** | None | | | |
| **Remarks** | None | | | |

## Functions of Core Control

Table 2‑119: Function List

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **No.** | **Function Name** | **Access** | **ASIL** | **Source File Name** |
|  | impdrv\_\*\*\*ctl\_is\_valid\_core | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_check\_state | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_set\_state | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_init\_start | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_init\_end | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_start | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_stop | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_quit | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_attr\_init | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_set\_mem\_init | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_set\_core\_map | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_set\_cl | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_set\_irq\_mask | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_set\_cl\_brk\_addr](#_impdrv_***ctl_set_cl_brk_addr) | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_execute](#_impdrv_***ctl_execute) | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_int\_handler | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_resume\_exe | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_pm\_set\_policy | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_pm\_get\_policy | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_pm\_get\_state | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_dmactl\_mb\_init](#_impdrv_dmactl_mb_init) | Public | ASIL D | r\_impdrv\_dmactl.c |
|  | [impdrv\_\*\*\*ctl\_bus\_if\_check](#_impdrv_***ctl_bus_if_check) | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_conf\_reg\_check](#_impdrv_***ctl_conf_reg_check) | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_dspctl\_dsp\_start\_pre | Public | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_dspctl\_set\_dsp](#_impdrv_dspctl_set_dsp) | Public | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_\*\*\*ctl\_set\_cond\_gosub](#_impdrv_***ctl_set_cond_gosub) | Public | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_init\_core | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_init\_core (\*\*\*:dma/dmas) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_get\_inten\_val | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_is\_sub\_thread | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_osal\_core\_num | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_read\_reg | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_write\_reg | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_dmactl\_tbl\_write\_reg](#_impdrv_dmactl_tbl_write_reg) | Private | ASIL D | r\_impdrv\_dmactl.c |
|  | [impdrv\_dmactl\_mb\_init\_pre](#_impdrv_dmactl_mb_init_pre) | Private | ASIL D | r\_impdrv\_dmactl.c |
|  | [impdrv\_dmactl\_mb\_init\_main](#_impdrv_dmactl_mb_init_main) | Private | ASIL D | r\_impdrv\_dmactl.c |
|  | [impdrv\_dmactl\_cl\_pre](#_impdrv_dmactl_cl_pre) | Private | ASIL D | r\_impdrv\_dmactl.c |
|  | [impdrv\_dmactl\_int\_safety\_func](#_impdrv_***ctl_int_main_func) | Private | ASIL D | r\_impdrv\_dmactl.c |
|  | [impdrv\_\*\*\*ctl\_int\_main\_func](#_impdrv_***ctl_int_main_func) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_int\_safety\_func](#_impdrv_dmactl_int_safety_func) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_dma\_transfer](#_impdrv_dmactl_dma_transfer) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_tbl\_write\_reg | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_check\_core\_busy | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_check\_core\_busy (\*\*\*:dma/dmas) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_soft\_reset](#_impdrv_***ctl_soft_reset) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_soft\_reset (\*\*\*:dma/dmas) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_set\_syncc\_config](#_impdrv_***ctl_set_syncc_config) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_set\_syncc\_config (\*\*\*:dma/dmas) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_int\_cb](#_impdrv_***ctl_int_cb) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | impdrv\_\*\*\*ctl\_int\_cb (\*\*\*:imp/imps) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_check\_inten](#_impdrv_***ctl_check_inten) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_ocvctl\_check\_inten](#_drv_ocvctl_check_inten) | Private | ASIL D | r\_impdrv\_ocvctl.c |
|  | [impdrv\_ocvctl\_irq\_status\_clear](#_impdrv_ocvctl_irq_status_clear) | Private | ASIL D | r\_impdrv\_ocvctl.c |
|  | [impdrv\_ocvctl\_check\_inten\_1st](#_impdrv_ocvctl_check_inten_1st) | Private | ASIL D | r\_impdrv\_ocvctl.c |
|  | [impdrv\_ocvctl\_check\_inten\_2nd](#_impdrv_ocvctl_check_inten_2st) | Private | ASIL D | r\_impdrv\_ocvctl.c |
|  | impdrv\_ocvctl\_init\_lwm | Private | ASIL D | r\_impdrv\_ocvctl.c |
|  | [impdrv\_ocvctl\_init\_core](#_impdrv_ocvctl_init_core) | Private | ASIL D | r\_impdrv\_ocvctl.c |
|  | impdrv\_dspctl\_dsp\_update\_app | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | impdrv\_dspctl\_load\_ptcm | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | impdrv\_dspctl\_stop\_reg | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_\*\*\*ctl\_set\_extend\_config](#_impdrv_***ctl_set_extend_config) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_\*\*\*ctl\_set\_extend\_config (\*\*\*:dma/dmas)](#_impdrv_***ctl_set_extend_config_(**) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_dspctl\_init\_dsp](#_impdrv_dspctl_init_dsp) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_dspctl\_get\_device\_io](#_impdrv_dspctl_get_device_io) | Private | ASIL D | r\_impdrv\_\*\*\*ctl.c |
|  | [impdrv\_dspctl\_init\_core](#_impdrv_dspctl_init_core) | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_dspctl\_chk\_execute\_data](#_impdrv_dspctl_chk_execute_data) | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_dspctl\_dsp\_execute\_pre](#_impdrv_dspctl_dsp_execute_pre) | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_dspctl\_tcm\_config\_d](#_impdrv_dspctl_tcm_config_d) | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_dspctl\_tcm\_config\_p](#_impdrv_dspctl_tcm_config_p) | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_dspctl\_load\_dtcm](#_impdrv_dspctl__load_dtcm) | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_dspctl\_dsp\_standby](#_impdrv_dspctl_dsp_standby) | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_dspctl\_dsp\_foece\_standby](#_impdrv_dspctl_dsp_foece_standby) | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | [impdrv\_dspctl\_chk\_int\_data](#_impdrv_dspctl_chk_int_data) | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | impdrv\_dspctl\_crc\_sub | Private | ASIL D | r\_impdrv\_dspctl.c |
|  | impdrv\_dspctl\_dsp\_start | Public | ASIL D | r\_impdrv\_dspctl.c |
|  | impdrv\_dspctl\_dsp\_execute | Public | ASIL D | r\_impdrv\_dspctl.c |

\*\*\* is present for each core.Specifically, there are the following

* imp
* psc
* dma
* ocv
* cnn
* imps
* dmas
* dsp

### Public function

#### impdrv\_\*\*\*ctl\_is\_valid\_core

Table 2‑120: impdrv\_\*\*\*ctl\_is\_valid\_core

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0001  impdrv\_\*\*\*ctl\_is\_valid\_core  [Covers: AD\_PD\_CAS1004, AD\_PD\_CAS3004] | | | | | |
| **ASIL Level** | ASIL D | | | **Status** | New | |
| **Syntax** | bool impdrv\_\*\*\*ctl\_is\_valid\_core(  const uint32\_t core\_num  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number.  The lifetime of this parameter is until this function returns. | |
| **Range** | Less than num of device |
| **Parameters (In-out)** | N/A | | | | N/A | |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | bool | | | | true  false | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | Check the validity of the core number. | | | |
| Imp | core\_num is less than IMPDRV\_IMP\_CORENUM\_VAL | | | |
| cnn | core\_num is less than IMPDRV\_CNN\_CORENUM\_VAL | | | |
| dma | core\_num is less than IMPDRV\_DMA\_CORENUM\_VAL | | | |
| ocv | core\_num is less than IMPDRV\_OCV\_CORENUM\_VAL | | | |
| psc | core\_num is less than IMPDRV\_PSC\_CORENUM\_VAL | | | |
| imps | core\_num is less than IMPDRV\_PSC\_CORENUM\_VAL | | | |
| dmas | core\_num is less than IMPDRV\_PSC\_CORENUM\_VAL | | | |
| dsp | core\_num is less than IMPDRV\_DSP\_CORENUM\_VAL | | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_check\_state

Table 2‑121: impdrv\_\*\*\*ctl\_check\_state

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0002  impdrv\_\*\*\*ctl\_check\_state  [Covers: AD\_PD\_CAS1001, AD\_PD\_CAS1004, AD\_PD\_CAS1007, AD\_PD\_CAS2032, AD\_PD\_CAS2033, AD\_PD\_CAS2096, AD\_PD\_CAS3004, AD\_PD\_CAS1005, AD\_PD\_CAS1006, AD\_PD\_CAS1008, AD\_PD\_CAS1009, AD\_PD\_CAS1010, AD\_PD\_CAS1011, AD\_PD\_CAS2313] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_check\_state(  const st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const e\_impdrv\_state\_t state  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core  The lifetime of this parameter is the period from the R\_IMPDRV\_Init is executed until R\_IMPDRV\_Quit is executed. | | |
| **Range** | Not NULL | |
| const uint32\_t core\_num | | | | Specified core number  The lifetime of this parameter is until this function returns. | | |
| **Range** | Less than num of device | |
| const e\_impdrv\_state\_t state | | | | IMP Driver state  The lifetime of this parameter is until this function returns. | | |
| **Range** | | Refer to 5.4.2.4.1. |
| **Parameters (In-out)** | N/A | | | | N/A | | |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | \*\*\* | |  | | | |
| imp | | no difference between the cores. | | | |
| Cnn | | no difference between the cores. | | | |
| Dma | | no difference between the cores. | | | |
| Ocv | | no difference between the cores. | | | |
| Psc | | no difference between the cores. | | | |
| Imps | | no difference between the cores. | | | |
| Dmas | | no difference between the cores. | | | |
| Dsp | | no difference between the cores. | | | |
| **Preconditions** | N/A | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_set\_state

Table 2‑122: impdrv\_\*\*\*ctl\_set\_state

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0003  impdrv\_\*\*\*ctl\_set\_state  [Covers: AD\_PD\_CAS1004, AD\_PD\_CAS1005, AD\_PD\_CAS1006, AD\_PD\_CAS1011, AD\_PD\_CAS2041, AD\_PD\_CAS3004] | | | | | | |
| **ASIL Level** | ASIL D | | | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_state(  st\_impdrv\_corectl\_t \*const p\_corectl,  const e\_impdrv\_state\_t state  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const e\_impdrv\_state\_t state | | | | IMP Driver state  The lifetime of this parameter is the period from the impdrv\_\*\*\*ctl\_init\_start is executed until impdrv\_\*\*\*ctl\_stop is executed. | | |
| **Range** | Refer to 5.4.2.4.1. | |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core.  The lifetime of this parameter is until this function returns. | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | \*\*\* |  | | | | |
| imp | no difference between the cores. | | | | |
| Cnn | no difference between the cores. | | | | |
| Dma | no difference between the cores. | | | | |
| Ocv | no difference between the cores. | | | | |
| Psc | no difference between the cores. | | | | |
| Imps | no difference between the cores. | | | | |
| Dmas | no difference between the cores. | | | | |
| **Preconditions** | N/A | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_init\_start

Table 2‑123: impdrv\_\*\*\*ctl\_init\_start

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0004  impdrv\_\*\*\*ctl\_init\_start  [Covers: AD\_PD\_CAS1003, AD\_PD\_CAS1005, AD\_PD\_CAS2034, AD\_PD\_CAS2035, AD\_PD\_CAS2036, AD\_PD\_CAS2037, AD\_PD\_CAS3004, AD\_PD\_CAS1033, AD\_PD\_CAS2321, AD\_PD\_CAS2322] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_init\_start(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const uint32\_t  core\_num | | | | Specified core number  The lifetime of this parameter is until impdrv\_\*\*\*ctl\_init\_start returns. | |
| **Range** | Less than num of device |
| **Parameters (In-out)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for each core type.  The lifetime of this parameter is the period from the impdrv\_\*\*\*ctl\_init\_start is executed until impdrv\_\*\*\*ctl\_stop is executed. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| About Request osdep to power on core.  <Only DSP core>  Call impdrv\_osdep\_pow\_on\_imp\_dsp and impdrv\_osdep\_reset\_core\_dsp  <Other than DSP core>  Call impdrv\_osdep\_pow\_on\_imp | | | | | |
| Differences between cores. | \*\*\* | | Check the IMP Core version | | |
| imp | | Version Control Register: IMPDRV\_REG\_IMP\_VCR  Check value: upper 16bit is IMPDRV\_IMP\_VCR | | |
| cnn | | Version Control Register: IMPDRV\_REG\_CNN\_VCR  Check value: IMPDRV\_CNN\_VCR | | |
| dma | | Version Control Register: IMPDRV\_REG\_DMA\_VCR  Check value: IMPDRV\_DMA\_VCR | | |
| ocv | | Version Control Register: IMPDRV\_REG\_OCV\_VCR0  Check value: IMPDRV\_OCV\_VCR | | |
| psc | | Version Control Register: IMPDRV\_REG\_PSC\_VCR  Check value: IMPDRV\_PSC\_VCR | | |
| imps | | Version Control Register: IMPDRV\_IMPS\_VCR  Check value: upper 16bit is IMPDRV\_IMPS\_VCR | | |
| dmas | | Version Control Register: IMPDRV\_DMAS\_VCR  Check value: IMPDRV\_DMAS\_VCR | | |
| dsp | | Version Control Register: IMPDRV\_REGOFS\_VDSP\_VERSION1  Check value: IMPDRV\_REGVAL\_VDSP\_VERSION1 | | |
| **Preconditions** | Must be in “Uninitialized State”. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_init\_end

Table 2‑124: impdrv\_\*\*\*ctl\_init\_end

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0005  impdrv\_\*\*\*ctl\_init\_end  [Covers: AD\_PD\_CAS1003, AD\_PD\_CAS2038, AD\_PD\_CAS2039, AD\_PD\_CAS2040, AD\_PD\_CAS3004, AD\_PD\_CAS1033, AD\_PD\_CAS2323] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_init\_end(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number  The lifetime of this parameter is until impdrv\_\*\*\*ctl\_init\_start returns. | | |
| **Range** | Less than num of device | |
| **Parameters (In-out)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for each core type  The lifetime of this parameter is the period from the impdrv\_\*\*\*ctl\_init\_start is executed impdrv\_\*\*\*ctl\_stop is executed. | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | \*\*\* | |  | | | |
| imp | | Difference is to describe the activity diagram. | | | |
| Cnn | | Difference is to describe the activity diagram. | | | |
| Dma | | Difference is to describe the activity diagram. | | | |
| Ocv | | Difference is to describe the activity diagram. | | | |
| Psc | | Difference is to describe the activity diagram. | | | |
| Imps | | Difference is to describe the activity diagram. | | | |
| Dmas | | Difference is to describe the activity diagram. | | | |
| Dsp | | Difference is to describe the activity diagram. | | | |
| **Preconditions** | Must be in “Uninitialized State”. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_start

Table 2‑125: impdrv\_\*\*\*ctl\_start

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0006  impdrv\_\*\*\*ctl\_start  [Covers: AD\_PD\_CAS2246, AD\_PD\_CAS2247, AD\_PD\_CAS2248, AD\_PD\_CAS2249, AD\_PD\_CAS2250, AD\_PD\_CAS2251] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_start(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number | |
| **Range** | Less than num of device |
| **Parameters (In-out)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | | Check thread, Init core and get core num | | |
| imp | | Initialization of specified core. | | |
| Cnn | | no difference between the cores. | | |
| Dma | | Check thread: call impdrv\_dmactl\_is\_sub\_thread() to check if main thread or sub thread .  Get core num: call impdrv\_dmactl\_osal\_core\_num() to get osal core number from core number.  Init core: call impdrv\_dmactl\_init\_core(). | | |
| Ocv | | Initialization of specified core. | | |
| Psc | | no difference between the cores. | | |
| Imps | | Initialization of specified core. | | |
| Dmas | | Check thread: call impdrv\_dmasctl\_is\_sub\_thread() to check if main thread or sub thread .  Get core num: call impdrv\_dmasctl\_osal\_core\_num() to get osal core number from core number.  Init core: call impdrv\_dmasctl\_init\_core(). | | |
| Dsp | | N/A | | |
| **Preconditions** | N/A. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_stop

Table 2‑126: impdrv\_\*\*\*ctl\_stop

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0007  impdrv\_\*\*\*ctl\_stop  [Covers: AD\_PD\_CAS1006, AD\_PD\_CAS2281, AD\_PD\_CAS2282, AD\_PD\_CAS2283, AD\_PD\_CAS2284, AD\_PD\_CAS2285, AD\_PD\_CAS2286, AD\_PD\_CAS2602, AD\_PD\_CAS2413, AD\_PD\_CAS2417] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_stop(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number | | |
| **Range** | Less than num of device | |
| **Parameters (In-out)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]  <Only DSP core>   * Add expression of whether ercd is IMPDRV\_EC\_OK or not when call impdrv\_dspctl\_stop\_reg | | | | | | |
| Differences between cores. | \*\*\* | | Check thread | | | |
| imp | | no difference between the cores. | | | |
| Cnn | | no difference between the cores. | | | |
| Dma | | Refer to 2.4.1.8 | | | |
| Ocv | | no difference between the cores. | | | |
| Psc | | no difference between the cores.. | | | |
| imps | | no difference between the cores. | | | |
| Dmas | | Refer to 2.4.1.8 | | | |
| **Preconditions** | N/A. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_stop(\*\*\*:dma/dmas)

Table 2‑126: impdrv\_\*\*\*ctl\_stop(\*\*\*:dma/dmas)

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0080  impdrv\_\*\*\*ctl\_stop  [Covers: AD\_PD\_CAS1006, AD\_PD\_CAS2281, AD\_PD\_CAS2282, AD\_PD\_CAS2283, AD\_PD\_CAS2284] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_stop(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number | | |
| **Range** | Less than num of device | |
| **Parameters (In-out)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]  <Only DSP core>   * Add expression of whether ercd is IMPDRV\_EC\_OK or not when call impdrv\_dspctl\_stop\_reg | | | | | | |
| Differences between cores. | \*\*\* | | Check thread | | | |
| Dma | | no difference between the cores. | | | |
| Dmas | | no difference between the cores. | | | |
| **Preconditions** | N/A. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_quit

Table 2‑127: impdrv\_\*\*\*ctl\_quit

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0024  impdrv\_\*\*\*ctl\_quit  [Covers: AD\_PD\_CAS2561, AD\_PD\_CAS2437, AD\_PD\_CAS2562, AD\_PD\_CAS2563] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_quit(  const uint32\_t core\_num  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number | |
| **Range** | Less than num of device |
| **Parameters (In-out)** | N/A | | | | N/A | |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | | Check thread | | |
| imp | | no difference between the cores. | | |
| Cnn | | When PM state is READY or RESET, call impdrv\_cnnctl\_force\_reset. | | |
| Dma | | When getting osal core number, call impdrv\_dmactl\_osal\_core\_num. | | |
| Ocv | | no difference between the cores. | | |
| Psc | | no difference between the cores. | | |
| Cnns | | no difference between the cores. | | |
| Dmas | | When getting osal core number, call impdrv\_dmactl\_osal\_core\_num. | | |
| Dsp | | When device open, call impdrv\_osdep\_dev\_open\_dsp instead of impdrv\_osdep\_dev\_open\_imp. | | |
| **Preconditions** | N/A. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_attr\_init

Table 2‑128: impdrv\_\*\*\*ctl\_attr\_init

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0008  impdrv\_\*\*\*ctl\_attr\_init  [Covers: AD\_PD\_CAS1007, AD\_PD\_CAS2130, AD\_PD\_CAS2131, AD\_PD\_CAS2132, AD\_PD\_CAS3004] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_attr\_init(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number  The lifetime of this parameter is until this function returns. | | |
| **Range** | Less than num of device | |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core  The lifetime of this parameter is the period from the impdrv\_\*\*\*ctl\_init\_start is executed until impdrv\_\*\*\*ctl\_init\_start is executed. | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | \*\*\* | | Check state | | | |
| imp | | call impdrv\_impctl\_check\_state() to check ‘INIT’.  Irqmask setting  (R-CarV3M / R-CarV3H / R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_HPINT] = true  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_APIPINT] = true  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_WUPCOVF] = true | | | |
| cnn | | call impdrv\_cnnctl\_check\_state() to check ‘INIT’.  Irqmask setting  (R-CarV3M / R-CarV3H / R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_MSCO] = true  (R-CarV3H / R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_WUPCOVF] = true | | | |
| dma | | call impdrv\_dmactl\_check\_state() to check ‘INIT’.  Irqmask setting  (R-CarV3H / R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_WUPCOVF] = true | | | |
| ocv | | call impdrv\_ocvctl\_check\_state() to check ‘INIT’.  (R-CarV3M / R-CarV3H / R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_USIER] = false;  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_USINT] = false;  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_PBCOVF] = true;  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_SBO0ME] = true;  (R-CarV3H / R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_WUPCOVF] = true; | | | |
| psc | | call impdrv\_pscctl\_check\_state() to check ‘INIT’.  (R-CarV3M / R-CarV3H / R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_END] = true  (R-CarV3H / R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_WUPCOVF] = true | | | |
| imps | | call impdrv\_impctl\_check\_state() to check ‘INIT’.  Irqmask setting  (R-CarV3H / R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_HPINT] = true  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_APIPINT] = true  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_WUPCOVF] = true | | | |
| dmas | | call impdrv\_dmasctl\_check\_state() to check ‘INIT’.  Irqmask setting  (R-CarV3H\_2)  p\_corectl->irq\_mask[IMPDRV\_IRQMASK\_WUPCOVF] = true . | | | |
| dsp | | call impdrv\_dspctl\_check\_state() to check ‘INIT’.  Irqmask setting  (R-CarV4H\_2)  p\_corectl->irq\_mask[i] = true .  \* i =0～IMPDRV\_IRQMASK\_MAX-1  Reset dsp\_info information  p\_corectl->dsp\_info.dsp\_app.addr\_phys = IMPDRV\_INIT\_DSPMEM\_ADDR  p\_corectl->dsp\_info.dsp\_app.size = 0U  p\_corectl->dsp\_info.dsp\_fw.addr\_phys = IMPDRV\_INIT\_DSPMEM\_ADDR  p\_corectl->dsp\_info.dsp\_fw.size = 0U  p\_corectl->dsp\_info.dsp\_data.addr\_phys = IMPDRV\_INIT\_DSPMEM\_ADDR  p\_corectl->dsp\_info.dsp\_data.size = 0U  p\_corectl->dsp\_info.dsp\_dtcm.addr\_phys = IMPDRV\_INIT\_DSPMEM\_ADDR  p\_corectl->dsp\_info.dsp\_dtcm.size = 0U  p\_corectl->dsp\_info.is\_update = false  p\_corectl->dsp\_info.is\_loaded = false  p\_corectl->dsp\_info.is\_executed = false | | | |
| **Preconditions** | Must be in “Initialization State”. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_set\_mem\_init

Table 2‑129: impdrv\_\*\*\*ctl\_set\_mem\_init

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0009  impdrv\_\*\*\*ctl\_set\_mem\_init  [Covers: AD\_PD\_CAS1005, AD\_PD\_CAS2149, AD\_PD\_CAS2150, AD\_PD\_CAS2151] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_mem\_init(  st\_impdrv\_corectl\_t \*const p\_corectl ,  const uint32\_t core\_num,  const e\_impdrv\_param\_t enable  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number | |
| **Range** | Less than num of device |
| const e\_impdrv\_param\_t enable | | | | memory initialization possible flag | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | | Check state | | |
| imp | | call impdrv\_impctl\_check\_state() to check ‘INIT’. | | |
| Cnn | | call impdrv\_cnnctl\_check\_state() to check ‘INIT’. | | |
| Dma | | call impdrv\_dmactl\_check\_state() to check ‘INIT’. | | |
| Ocv | | call impdrv\_ocvctl\_check\_state() to check ‘INIT’. | | |
| Psc | | call impdrv\_pscctl\_check\_state() to check ‘INIT’. | | |
| Imps | | call impdrv\_impsctl\_check\_state() to check ‘INIT’. | | |
| Dmas | | call impdrv\_dmasctl\_check\_state() to check ‘INIT’. | | |
| **Preconditions** | N/A. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_set\_core\_map

Table 2‑130: impdrv\_\*\*\*ctl\_set\_core\_map

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0010  impdrv\_\*\*\*ctl\_set\_core\_map  [Covers: AD\_PD\_CAS2168, AD\_PD\_CAS2169, AD\_PD\_CAS2170] | | | | | | |
| **ASIL Level** | ASIL D | | | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_core\_map(  st\_impdrv\_corectl\_t \*const p\_corectl ,  const uint32\_t core\_num,  const uint8\_t syncc\_val[IMPDRV\_COREMAP\_MAXID]  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Number of specified cores | | |
| **Range** | Less than num of device. | |
| Const uint8\_t syncc\_val | | | | Core sync value | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | \*\*\* | Check state | | | | |
| imp | call impdrv\_impctl\_check\_state() to check ‘READY’. | | | | |
| Cnn | call impdrv\_cnnctl\_check\_state() to check ‘READY’. | | | | |
| Dma | call impdrv\_dmactl\_check\_state() to check ‘READY’. | | | | |
| Ocv | call impdrv\_ocvctl\_check\_state() to check ‘READY’. | | | | |
| Psc | call impdrv\_pscctl\_check\_state() to check ‘READY’. | | | | |
| Imps | call impdrv\_impsctl\_check\_state() to check ‘READY’. | | | | |
| Dmas | call impdrv\_dmasctl\_check\_state() to check ‘READY’. | | | | |
| Dsp | call impdrv\_dspctl\_check\_state () to check ‘READY’ | | | | |
| **Preconditions** | N/A. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_set\_cl

Table 2‑131: impdrv\_\*\*\*ctl\_set\_cl

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0011  impdrv\_\*\*\*ctl\_set\_cl  [Covers: AD\_PD\_CAS1009, AD\_PD\_CAS2185 AD\_PD\_CAS2186, AD\_PD\_CAS2187] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_cl(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const uint32\_t claddr\_phys  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Number of specified cores | | |
| **Range** | Less than num of device. | |
| Const uint32\_t claddr\_phys | | | | CL address | | |
| **Range** | | 4byte alignments |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | \*\*\* | | Check state | | | |
| imp | | call impdrv\_impctl\_check\_state() to check ‘READY’. | | | |
| Cnn | | call impdrv\_cnnctl\_check\_state() to check ‘READY’. | | | |
| Dma | | call impdrv\_dmactl\_check\_state() to check ‘READY’. | | | |
| Ocv | | call impdrv\_ocvctl\_check\_state() to check ‘READY’. | | | |
| Psc | | call impdrv\_pscctl\_check\_state() to check ‘READY’. | | | |
| Imps | | call impdrv\_impsctl\_check\_state() to check ‘READY’. | | | |
| Dmas | | call impdrv\_dmasctl\_check\_state() to check ‘READY’. | | | |
| **Preconditions** | N/A. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_set\_irq\_mask

Table 2‑132: impdrv\_\*\*\*ctl\_set\_irq\_mask

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0012  impdrv\_\*\*\*ctl\_set\_irq\_mask  [Covers: AD\_PD\_CAS1008, AD\_PD\_CAS2202, AD\_PD\_CAS2203, AD\_PD\_CAS2204] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_irq\_mask (  st\_impdrv\_corectl\_t \*const p\_corectl ,  const uint32\_t core\_num,  const bool irq\_mask[IMPDRV\_IRQMASK\_MAX]  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Number of specified cores | |
| **Range** | Less than num of device. |
| Const bool  irq\_mask[IMPDRV\_IRQMASK\_MAX] | | | | Register bits to be masked  (different for each core, internally converted) | |
| **Range** | true or false |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | | Check state | | |
| imp | | call impdrv\_impctl\_check\_state() to check ‘READY’. | | |
| Cnn | | call impdrv\_cnnctl\_check\_state() to check ‘READY’. | | |
| Dma | | call impdrv\_dmactl\_check\_state() to check ‘READY’. | | |
| Ocv | | call impdrv\_ocvctl\_check\_state() to check ‘READY’. | | |
| Psc | | call impdrv\_pscctl\_check\_state() to check ‘READY’. | | |
| Imps | | call impdrv\_impsctl\_check\_state() to check ‘READY’. | | |
| Dmas | | call impdrv\_dmasctl\_check\_state() to check ‘READY’. | | |
| **Preconditions** | N/A. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_set\_cl\_brk\_addr

Table 2‑133 impdrv\_\*\*\*ctl\_set\_cl\_brk\_addr

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0053  impdrv\_\*\*\*ctl\_set\_cl\_brk\_addr  [Covers: AD\_PD\_CAS2544, AD\_PD\_CAS2545, AD\_PD\_CAS2546] | | | | |
| **ASIL Level** | ASIL D | | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_cl\_brk\_addr(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const uint32\_t cl\_brk\_addr  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | The state of the IMP driver can be executed at the ‘Ready’ or ‘Int’ state.  Refer to e\_impdrv\_state\_t for interrupt status. | | | | |
| **Parameters (In)** | const uint32\_t  core\_num | | | Number of specified cores | |
| **Range** | Less than num of device. |
| const uint32\_t  cl\_brk\_addr | | | CL beak address | |
| **Range** | 4byte alignments.  However, exclude the invalid value (0xFFFFFFFFU). |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t  \*const p\_corectl | | | The Core control handles | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | | N/A | |
| **Return Value** | [***e\_impdrv\_errorcode\_t***](#_API_Layer) | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Setting CL break address.  To do so, do the following.  ・Gets the following from work memory.  - Status  ・Setting CL break address in work memory. | | | | |
| Refer to “3 Activity Diagrams”. | | | | |
| Differences between cores. | \*\*\* |  | | |
| imp | no difference between the cores. | | |
| Cnn | no difference between the cores. | | |
| Dma | no difference between the cores. | | |
| Ocv | no difference between the cores. | | |
| Psc | no difference between the cores. | | |
| Imps | N/A | | |
| Dmas | no difference between the cores. | | |
| Dsp | N/A | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_\*\*\*ctl\_execute

Table 2‑134: impdrv\_\*\*\*ctl\_execute

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0014  impdrv\_\*\*\*ctl\_execute  [Covers: AD\_PD\_CAS1010, AD\_PD\_CAS2313, AD\_PD\_CAS2315, AD\_PD\_CAS2316, AD\_PD\_CAS2317, AD\_PD\_CAS2318, AD\_PD\_CAS2319, AD\_PD\_CAS2320, AD\_PD\_CAS2314] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_execute(  st\_impdrv\_corectl\_t \*const p\_corectl ,  const uint32\_t core\_num,  const p\_impdrv\_cbfunc\_t callback\_func ,  void \*const p\_callback\_args  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const p\_impdrv\_cbfunc\_t callback\_func | | | | Callback function | | |
| **Range** | Not NULL | |
| void  \*const p\_callback\_args | | | | Callback argument | | |
| **Range** | None | |
| const uint32\_t core\_num | | | | Specified core number | | |
| **Range** | Less than num of device. | |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_ATTRIBUTE | | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]  <Only DSP core>   * Remove expression other than whether ercd is IMPDRV\_EC\_OK or not when call impdrv\_dspctl\_dsp\_update\_app * Cast void of return value of callback\_func | | | | | | |
| Differences between cores. | \*\*\* | |  | | | |
| imp | | Difference is to describe the activity diagram. | | | |
| Cnn | | Difference is to describe the activity diagram. | | | |
| Dma | | Difference is to describe the activity diagram. | | | |
| Ocv | | Difference is to describe the activity diagram. | | | |
| Psc | | Difference is to describe the activity diagram. | | | |
| Imps | | Difference is to describe the activity diagram. | | | |
| Dmas | | Difference is to describe the activity diagram. | | | |
| **Preconditions** | N/A. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_int\_handler

Table 2‑135: impdrv\_\*\*\*ctl\_int\_handler

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0015  impdrv\_\*\*\*ctl\_int\_handler  [Covers: AD\_PD\_CAS1011, AD\_PD\_CAS2351, AD\_PD\_CAS2352, AD\_PD\_CAS2353, AD\_PD\_CAS2354, AD\_PD\_CAS2355, AD\_PD\_CAS2356, AD\_PD\_CAS2311, AD\_PD\_CAS2361, AD\_PD\_CAS1037] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_int\_handler(  st\_impdrv\_corectl\_t \*const p\_corectl ,  const uint32\_t core\_num  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number | | |
| **Range** | Less than num of device. | |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | \*\*\* | |  | | | |
| imp | | Difference is to describe the activity diagram. | | | |
| Cnn | | Difference is to describe the activity diagram. | | | |
| Dma | | Difference is to describe the activity diagram. | | | |
| Ocv | | Difference is to describe the activity diagram. | | | |
| Psc | | Difference is to describe the activity diagram. | | | |
| Imps | | Difference is to describe the activity diagram. | | | |
| Dmas | | Difference is to describe the activity diagram. | | | |
| Dsp | | Difference is to describe the activity diagram. | | | |
| **Preconditions** | N/A. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_resume\_exe

Table 2‑136: impdrv\_\*\*\*ctl\_resume\_exe

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0016  impdrv\_\*\*\*ctl\_resume\_exe  ***[Covers: AD\_PD\_CAS1014, AD\_PD\_CAS2408, AD\_PD\_CAS2409, AD\_PD\_CAS2410, AD\_PD\_CAS2411,*** AD\_PD\_CAS2312, AD\_PD\_CAS1038, AD\_PD\_CAS2433] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_resume\_exe(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback.  To enable the interrupt, set the following registers.  - Hardware interrupt | | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number | | |
| **Range** | Less than num of device. | |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t  \* const p\_corectl | | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | \*\*\* | |  | | | |
| imp | | Difference is to describe the activity diagram. | | | |
| Cnn | | Difference is to describe the activity diagram. | | | |
| Dma | | Difference is to describe the activity diagram. | | | |
| Ocv | | Difference is to describe the activity diagram. | | | |
| Psc | | Difference is to describe the activity diagram. | | | |
| Imps | | Difference is to describe the activity diagram. | | | |
| Dmas | | Difference is to describe the activity diagram. | | | |
| Dsp | | Difference is to describe the activity diagram. | | | |
| **Preconditions** | N/A. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_pm\_set\_policy

Table 2‑137: impdrv\_\*\*\*ctl\_pm\_set\_policy

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0017  impdrv\_\*\*\*ctl\_pm\_set\_policy  [Covers: AD\_PD\_CAS1015, AD\_PD\_CAS2434, AD\_PD\_CAS2435, AD\_PD\_CAS2436] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_pm\_set\_policy(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  const e\_impdrv\_pm\_policy\_t policy  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| const uint32\_t core\_num | | | | Specified core number | |
| **Range** | Less than num of device. |
| Const e\_impdrv\_pm\_policy\_t policy | | | | Policy you want to set | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | | | N/A | |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]  <Only DSP core>   * Remove call impdrv\_osdep\_pow\_on\_imp\_dsp and impdrv\_osdep\_pow\_off\_imp | | | | | |
| Differences between cores. | \*\*\* | |  | | |
| imp | | no difference between the cores. | | |
| Cnn | | no difference between the cores. | | |
| Dma | | Difference is to describe the activity diagram. | | |
| Ocv | | no difference between the cores. | | |
| Psc | | no difference between the cores. | | |
| Imps | | no difference between the cores. | | |
| Dmas | | Difference is to describe the activity diagram. | | |
| **Preconditions** | N/A. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_pm\_get\_policy

Table 2‑138: impdrv\_\*\*\*ctl\_pm\_get\_policy

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0018  impdrv\_\*\*\*ctl\_pm\_get\_policy  [Covers: AD\_PD\_CAS1016, AD\_PD\_CAS2466, AD\_PD\_CAS2467, AD\_PD\_CAS2468] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_pm\_get\_policy(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  e\_impdrv\_pm\_policy\_t \*const p\_policy  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| const uint32\_t core\_num | | | | Specified core number | | |
| **Range** | | Less than num of device. |
| **Parameters (In-out)** | N/A | | | | N/A | | |
| **Parameters (Out)** | e\_impdrv\_pm\_policy\_t \*const p\_policy | | | | Current PM Policy | | |
| **Range** | Not NULL | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]  <Only DSP core>   * Remove call impdrv\_osdep\_pow\_on\_imp\_dsp and impdrv\_osdep\_pow\_off\_imp | | | | | | |
| Differences between cores. | \*\*\* | |  | | | |
| imp | | no difference between the cores. | | | |
| Cnn | | no difference between the cores. | | | |
| Dma | | Difference is to describe the activity diagram. | | | |
| Ocv | | no difference between the cores. | | | |
| Psc | | no difference between the cores. | | | |
| Imps | | no difference between the cores. | | | |
| Dmas | | Difference is to describe the activity diagram. | | | |
| **Preconditions** | N/A. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_pm\_get\_state

Table 2‑139: impdrv\_\*\*\*ctl\_pm\_get\_state

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0013  impdrv\_\*\*\*ctl\_pm\_get\_state  [Covers: AD\_PD\_CAS2558, AD\_PD\_CAS2559, AD\_PD\_CAS2560] | | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_pm\_get\_state(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  e\_impdrv\_pm\_state\_t \*const p\_pmstate  ); | | | | | | |
| **Sync/Async** | Synchronous | | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Specified core number | | |
| **Range** | | Less than num of device. |
| **Parameters (In-out)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for specific core | | |
| **Range** | Not NULL | |
| **Parameters (Out)** | e\_impdrv\_pm\_state\_t \*const p\_pmstate | | | | Current PM State | | |
| **Range** | Not NULL | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PMSYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | \*\*\* | |  | | | |
| imp | | no difference between the cores. | | | |
| Cnn | | no difference between the cores. | | | |
| Dma | | Difference is to describe the activity diagram. | | | |
| Ocv | | no difference between the cores. | | | |
| Psc | | no difference between the cores. | | | |
| Imps | | no difference between the cores. | | | |
| Dmas | | Difference is to describe the activity diagram. | | | |
| Dsp | | Difference is to describe the activity diagram. | | | |
| **Preconditions** | N/A. | | | | | | |
| **Remarks** | N/A | | | | | | |

#### impdrv\_dmactl\_mb\_init

Table 2‑140: impdrv\_dmactl\_mb\_init

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0026  impdrv\_dmactl\_mb\_init  [Covers: AD\_PD\_CAS1024, AD\_PD\_CAS2229, AD\_PD\_CAS2469, AD\_PD\_CAS2470, AD\_PD\_CAS2472, AD\_PD\_CAS2473] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_dmactl\_mb\_init(  st\_impdrv\_corectl\_t \*const p\_corectl ,  const uint32\_t core\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core | |
| **Range** | Not NULL |
| const uint32\_t core\_num | | Specified core number | |
| **Range** | Less than num of device. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Refer to “3 Activity Diagrams”.  Retrurn values IMPDRV\_EC\_NG\_CHECKFAIL, IMPDRV\_EC\_NG\_SEQSTATE and IMPDRV\_EC\_NG\_SYSTEMERROR are used only V3\*\*. | | | |
| **Preconditions** | N/A. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_\*\*\*ctl\_bus\_if\_check

Table 2‑141: impdrv\_\*\*\*ctl\_bus\_if\_check

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0079  impdrv\_\*\*\*ctl\_bus\_if\_check  [Covers: AD\_PD\_CAS2401, AD\_PD\_CAS2489, AD\_PD\_CAS2490, AD\_PD\_CAS2491, AD\_PD\_CAS2492 AD\_PD\_CAS2493 AD\_PD\_CAS2494 AD\_PD\_CAS2495 AD\_PD\_CAS2496 AD\_PD\_CAS2497 AD\_PD\_CAS2498 AD\_PD\_CAS2499, AD\_PD\_CAS2525, AD\_PD\_CAS2528, AD\_PD\_CAS2527] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_bus\_if\_check(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t) \*const p\_chk\_resource  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const uint32\_t  core\_num | | | | Specified core number  The lifetime of this parameter is until impdrv\_\*\*\*ctl\_init\_start returns. | |
| **Range** | Less than num of device |
| const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t) \*const p\_chk\_resource | | | | Pointer to the OSAL resource for bus interface check. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for each core type.  The lifetime of this parameter is the period from the impdrv\_\*\*\*ctl\_init\_start is executed until impdrv\_\*\*\*ctl\_stop is executed. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | | Check the IMP Core version | | |
| imp | | Difference is to describe the activity diagram. | | |
| Cnn | | N/A. | | |
| dma | | Difference is to describe the activity diagram. | | |
| Ocv | | N/A. | | |
| psc | | N/A. | | |
| imps | | Difference is to describe the activity diagram. | | |
| Dmas | | N/A. | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_conf\_reg\_check

Table 2‑142: impdrv\_\*\*\*ctl\_conf\_reg\_check

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0054  impdrv\_\*\*\*ctl\_conf\_reg\_check  [Covers: AD\_PD\_CAS2407, AD\_PD\_CAS2526, AD\_PD\_CAS2500, AD\_PD\_CAS2501] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_conf\_reg\_check(  const st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num  const [st\_impdrv\_chk\_param\_t](#_st_impdrv_chkparam_t(T.B.D.)) \*const p\_chk\_param,  const uint32\_t param\_num  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | constst\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | | Control data structure for each core type. | |
| **Range** | Not NULL |
| const uint32\_t  core\_num | | | | Specified core number. | |
| **Range** | Less than num of device |
| const [st\_impdrv\_chk\_param\_t](#_st_impdrv_chkparam_t(T.B.D.)) \*const p\_chk\_param | | | | Pointer to Array of check parameters. | |
| **Range** | Not NULL |
| const uint32\_t param\_num | | | | Number of check parameters. | |
| **Range** | Not 0 |
| **Parameters (In-out)** | N/A | | | | N/A | |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | | Check the IMP Core version | | |
| imp | | Difference is to describe the activity diagram. | | |
| Cnn | | Difference is to describe the activity diagram. | | |
| Dma | | Difference is to describe the activity diagram. | | |
| Ocv | | Difference is to describe the activity diagram. | | |
| Psc | | Difference is to describe the activity diagram. | | |
| Imps | | Difference is to describe the activity diagram. | | |
| Dmas | | Difference is to describe the activity diagram. | | |
| Dsp | | Difference is to describe the activity diagram. | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_dspctl\_dsp\_start\_pre

Table 2‑143: impdrv\_dspctl\_dsp\_start\_pre

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0059  impdrv\_dspctl\_dsp\_start\_pre  [Covers: AD\_PD\_CAS2324, AD\_PD\_CAS2325, AD\_PD\_CAS2327, AD\_PD\_CAS2328, AD\_PD\_CAS2348, AD\_PD\_CAS2362] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_dspctl\_dsp\_start\_pre(  st\_impdrv\_corectl\_t \* p\_corectl,  const uint32\_t core\_num,  const e\_osal\_interrupt\_priority\_t irq\_priority,  const impdrv\_ctrl\_handle\_t osal\_cb\_args  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | Specified core number | | |
| **Range** | Less than num of device | |
| const e\_osal\_interrupt\_priority\_t irq\_priority | | The value of interrupt priority | | |
| **Range** | Within the range of ENUM type | |
| const impdrv\_ctrl\_handle\_t osal\_cb\_args | | OSAL callback argument  The lifetime of this parameter is the period from the impdrv\_genctl\_init is executed until impdrv\_genctl\_quit is executed. | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \* p\_corectl | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]  <Only DSP core>   * Remove expression of processing Application update requested and not loaded | | | | |
| **Preconditions** | N/A. | | | | |
| **Remarks** | This function is only used in DSP core | | | | |

#### impdrv\_dspctl\_set\_dsp

Table 2‑144: impdrv\_dspctl\_set\_dsp

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0060  impdrv\_dspctl\_set\_dsp  [Covers: AD\_PD\_CAS2418, AD\_PD\_CAS2426, AD\_PD\_CAS2427] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_dspctl\_set\_dsp(  st\_impdrv\_corectl\_t \* p\_corectl,  const uint32\_t core\_num,  const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_app,  const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_data,  const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_dtcm  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | Specified core number | | |
| **Range** | Less than num of device | |
| const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_app | | Information of DSP data | | |
| **Range** | Not NULL | |
| const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_data | | Information of DSP data | | |
| **Range** | Not NULL | |
| const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_dtcm | | Information of DSP data | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \* p\_corectl | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A. | | | | |
| **Remarks** | This function is only used in DSP core | | | | |

#### impdrv\_\*\*\*ctl\_set\_cond\_gosub

Table 2‑149: impdrv\_\*\*\*ctl\_set\_cond\_gosub

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0058  impdrv\_\*\*\*ctl\_set\_cond\_gosub  [Covers: AD\_PD\_CAS2428, AD\_PD\_CAS2429, AD\_PD\_CAS2430] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | e\_impdrv\_errorcode\_t i impdrv\_\*\*\*ctl\_set\_cond\_gosub(  st\_impdrv\_corectl\_t \* const p\_corectl,  const uint32\_t core\_num,  const e\_impdrv\_gosub\_cond\_t condition  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** |  | | | | | |
| **Parameters (In)** | const uint32\_t  core\_num | | | | Specified core number. | |
| **Range** | Less than num of device |
| const e\_impdrv\_gosub\_cond\_t condition | | | | Conditional GOSUB instruction attribute. | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \* const p\_corectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | | Check the IMP Core version | | |
| imp | | Difference is to describe the activity diagram. | | |
| Cnn | | Difference is to describe the activity diagram. | | |
| Dma | | Difference is to describe the activity diagram. | | |
| Ocv | | Difference is to describe the activity diagram. | | |
| Psc | | Difference is to describe the activity diagram. | | |
| Imps | | N/A | | |
| Dmas | | Difference is to describe the activity diagram. | | |
| Dsp | | N/A | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_dspctl\_dsp\_start

Table 2‑196: impdrv\_dspctl\_dsp\_start

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0073***  impdrv\_dspctl\_dsp\_start  ***[Covers: AD\_PD\_CAS2246, AD\_PD\_CAS2247, AD\_PD\_CAS2248, AD\_PD\_CAS2363, AD\_PD\_CAS2249, AD\_PD\_CAS2250, AD\_PD\_CAS2600, AD\_PD\_CAS2601, AD\_PD\_CAS2251]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_dsp\_start(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | Control data structure for each core type. | |
| **Range** | Not NULL |
| const uint32\_t  core\_num | | Specified core number. | |
| **Range** | 0 to 3 (only V4H)  0 to 1 (only V4M) |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_ATTRIBUTE  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_dsp\_execute

Table 2‑196: impdrv\_dspctl\_dsp\_execute

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0074***  impdrv\_dspctl\_dsp\_execute  ***[Covers: AD\_PD\_CAS2313, AD\_PD\_CAS2315, AD\_PD\_CAS2316, AD\_PD\_CAS2317, AD\_PD\_CAS2432, AD\_PD\_CAS2314, AD\_PD\_CAS2318, AD\_PD\_CAS2319, AD\_PD\_CAS2603, AD\_PD\_CAS2604, AD\_PD\_CAS2320, AD\_PD\_CAS1036]*** | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_dsp\_execute(  ***st\_impdrv\_corectl\_t*** \*p\_corectl,  const uint32\_t core\_num,  const ***p\_impdrv\_cbfunc\_t*** callback\_func,  void \*const p\_callback\_args  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | | |
| **Parameters (In)** | const uint32\_t  core\_num | | Core number. | | |
| **Range** | | 0 to 3 (only V4H)  0 to 1 (only V4M) |
| ***p\_impdrv\_cbfunc\_t***  callback\_func | | Callback function of execute request | | |
| **Range** | | Not NULL |
| void  \*const p\_callback\_args | | Callback arguments | | |
| **Range** | | N/A |
| **Parameters (In-out)** | const st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core. | | |
| **Range** | Not NULL | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ATTRIBUTE  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_PMSYSTEMERROR | | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | This function is only used in DSP core | | | | |

### Private function

#### impdrv\_\*\*\*ctl\_init\_core

Table 2‑144: impdrv\_\*\*\*ctl\_init\_core

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0076  impdrv\_\*\*\*ctl\_init\_core  [Covers: AD\_PD\_CAS2249, AD\_PD\_CAS2250] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_init\_core(  const st\_impdrv\_corectl\_t \*const p\_corectl  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | | | N/A | |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | |  | | |
| imp | | Difference is to describe the activity diagram. | | |
| Cnn | | N/A | | |
| dma | | Refer to 2.4.2.2 | | |
| ocv | | Refer to 2.4.2.31 | | |
| Psc | | N/A | | |
| imps | | Difference is to describe the activity diagram. (refer to imp) | | |
| dmas | | Refer to 2.4.2.2 | | |
| Dsp | | Refer to 2.4.2.2 | | |
| **Preconditions** | N/A. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_init\_core (\*\*\*:dma/dmas)

Table 2‑145: impdrv\_\*\*\*ctl\_init\_core (\*\*\*:dma/dmas)

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0020  impdrv\_\*\*\*ctl\_init\_core  [Covers: AD\_PD\_CAS2249, AD\_PD\_CAS2250] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_init\_core(  st\_impdrv\_corectl\_t \* const p\_corectl  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | st\_impdrv\_corectl\_t  \* const p\_corectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| N/A | | | | N/A | |
| **Parameters (In-out)** | N/A | | | | N/A | |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
|  | Differences between cores. | \*\*\* | |  | | |
|  |  | dma | | no difference between the cores. | | |
|  |  | Dmas | | no difference between the cores. | | |
| **Preconditions** | N/A. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_get\_inten\_val

Table 2‑146: impdrv\_\*\*\*ctl\_get\_inten\_val

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0025  impdrv\_\*\*\*ctl\_get\_inten\_val  [Covers: AD\_PD\_CAS2315] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | IMPDRV\_STATIC  uint32\_t impdrv\_\*\*\*ctl\_get\_inten\_val(  const bool irq\_mask[IMPDRV\_IRQMASK\_MAX]  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const bool irq\_mask[ IMPDRV\_IRQMASK\_MAX] | | | | IRQ mask setting value | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | | | N/A | |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | uint32\_t | | | | Interrupt enable register value | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | | interrupt enable value | | |
| imp | | (R-CarV3M)  inten\_val |= (IMPDRV\_IMP\_INTSTS\_TRAP | IMPDRV\_IMP\_INTSTS\_IER | IMPDRV\_IMP\_INTSTS\_INT);  (R-CarV3H / R-CarV3H\_2)  inten\_val |= (IMPDRV\_IMP\_INTSTS\_TRAP | IMPDRV\_IMP\_INTSTS\_IER | IMPDRV\_IMP\_INTSTS\_INT | IMPDRV\_IMP\_INTSTS\_WUP); | | |
| cnn | | (R-CarV3M)  inten\_val = (IMPDRV\_CNN\_SR\_TRAP | IMPDRV\_CNN\_SR\_IER | IMPDRV\_CNN\_SR\_INT);  (R-CarV3H / R-CarV3H\_2)  inten\_val = (IMPDRV\_CNN\_SR\_TRAP | IMPDRV\_CNN\_SR\_IER | IMPDRV\_CNN\_SR\_INT | IMPDRV\_CNN\_SR\_WUPCOVF); | | |
| dma | | (R-CarV3M)  inten\_val = (IMPDRV\_DMA\_SR\_TRAP | IMPDRV\_DMA\_SR\_IER | IMPDRV\_DMA\_SR\_INT);  (R-CarV3H / R-CarV3H\_2)  inten\_val = (IMPDRV\_DMA\_SR\_TRAP | IMPDRV\_DMA\_SR\_IER | IMPDRV\_DMA\_SR\_INT | IMPDRV\_DMA\_SR\_WUP); | | |
| ocv | | (R-CarV3M)  inten\_val = (IMPDRV\_OCV\_SR1\_TRAP | IMPDRV\_OCV\_SR1\_IER | IMPDRV\_OCV\_SR1\_INT);  (R-CarV3H / R-CarV3H\_2)  inten\_val = (IMPDRV\_OCV\_SR1\_TRAP | IMPDRV\_OCV\_SR1\_IER | IMPDRV\_OCV\_SR1\_INT | IMPDRV\_OCV\_SR1\_WUPCOVF); | | |
| psc | | (R-CarV3M / R-CarV3H)  inten\_val = (IMPDRV\_PSC\_SR\_TRAP | IMPDRV\_PSC\_SR\_IER | IMPDRV\_PSC\_SR\_INT);  (R-CarV3H\_2)  inten\_val = (IMPDRV\_PSC\_SR\_TRAP | IMPDRV\_PSC\_SR\_IER | IMPDRV\_PSC\_SR\_INT | IMPDRV\_PSC\_SR\_WUP); | | |
| imps | | ((R-CarV3H /R-CarV3H\_2)  inten\_val = IMPDRV\_IMPS\_INTSTS\_MASKCPU;  inten\_val |= (IMPDRV\_IMPS\_INTSTS\_TRAP | IMPDRV\_IMPS\_INTSTS\_IER | IMPDRV\_IMPS\_INTSTS\_INT | IMPDRV\_IMPS\_INTSTS\_WUP); | | |
| dmas | | (R-CarV3H\_2)  inten\_val = (IMPDRV\_DMAS\_SR\_TRAP | IMPDRV\_DMAS\_SR\_IER | IMPDRV\_DMAS\_SR\_INT | IMPDRV\_DMAS\_SR\_WUP); | | |
| **Preconditions** | N/A. | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_is\_sub\_thread

Table 2‑147: impdrv\_\*\*\*ctl\_is\_sub\_thread

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0021  impdrv\_\*\*\*ctl\_is\_sub\_thread  [Covers: AD\_PD\_CAS2034, AD\_PD\_CAS2039] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | IMPDRV\_STATIC  bool impdrv\_\*\*\*ctl\_is\_sub\_thread(  const uint32\_t core\_num  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Core number in the core type  The lifetime of this parameter is until this function returns. | |
| **Range** | DMAC core number (0 to 3) |
| **Parameters (In-out)** | N/A | | | | N/A | |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | bool | | | | true : sub thread  false : main thread | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | N/A | | | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | |  | | |
| imp | | N/A | | |
| cnn | | N/A | | |
| dma | | no difference between the cores. | | |
| Ocv | | N/A | | |
| psc | | N/A | | |
| imps | | N/A | | |
| dmas | | no difference between the cores. | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_osal\_core\_num

Table 2‑148: impdrv\_\*\*\*ctl\_osal\_core\_num

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0022  impdrv\_\*\*\*ctl\_osal\_core\_num  [Covers: AD\_PD\_CAS2034] | | | | | |
| **ASIL Level** | ASIL D | | **Status** | | New | |
| **Syntax** | IMPDRV\_STATIC  uint32\_t impdrv\_\*\*\*ctl\_osal\_core\_num(  const uint32\_t core\_num  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Reentrant | | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const uint32\_t core\_num | | | | Core number in the core type  The lifetime of this parameter is until this function returns. | |
| **Range** | DMAC core number (0 to 3) |
| **Parameters (In-out)** | N/A | | | | N/A | |
| **Parameters (Out)** | N/A | | | | N/A | |
| **Return Value** | uint32\_t | | | | OSAL resource number (0 or 1 or (uint32\_t)-1)) | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| Differences between cores. | \*\*\* | |  | | |
| imp | | N/A | | |
| cnn | | N/A | | |
| dma | | Different number of cores. | | |
| Ocv | | N/A | | |
| psc | | N/A | | |
| imps | | N/A | | |
| dmas | | Different number of cores. | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_read\_reg

Table 2‑149: impdrv\_\*\*\*ctl\_read\_reg

|  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0023  impdrv\_\*\*\*ctl\_read\_reg  [Covers: AD\_PD\_CAS2036] | | | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | | New | | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_read\_reg(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle ,  const uint32\_t offset,  uint32\_t \*p\_val,  const bool is\_sub\_theard  ); | | | | | | | |
| **Sync/Async** | | Synchronous | | | | | | | |
| **Reentrancy** | | Non-Reentrant | | | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | | | |
| **Parameters (In)** | | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | | | OSAL device handle  The lifetime of this parameter is the period from the impdrv\_\*\*\*ctl\_init\_start is executed until impdrv\_\*\*\*ctl\_init\_stop is executed. | | | |
| **Range** | | Not NULL | |
| const uint32\_t offset | | | | Offset to get to register  The lifetime of this parameter is until this function returns. | | | |
| **Range** | | | None. |
| Const bool is\_sub\_theard | | | | Select for DMAC Internal thread  The lifetime of this parameter is until this function returns. | | | |
| **Range** | | | true or false |
| **Parameters (In-out)** | | N/A | | | | N/A | | | |
| **Parameters (Out)** | | uint32\_t \*p\_val | | | | Storing values from registers | | | |
| **Range** | N/A | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | | | |
| Differences between cores. | | \*\*\* | |  | | | | |
| imp | | N/A | | | | |
| cnn | | N/A | | | | |
| dma | | no difference between the cores. | | | | |
| Ocv | | N/A | | | | |
| psc | | N/A | | | | |
| imps | | N/A | | | | |
| dmas | | no difference between the cores. | | | | |
| **Preconditions** | | N/A | | | | | | | |
| **Remarks** | | p\_val is pointer of output parameter, so the use of this pointer variable is acceptable | | | | | | | |

#### impdrv\_\*\*\*ctl\_write\_reg

Table 2‑150: impdrv\_\*\*\*ctl\_write\_reg

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0027  impdrv\_\*\*\*ctl\_write\_reg  [Covers: AD\_PD\_CAS2317] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_write\_reg(  const [st\_impdrv\_dma\_write\_info\_t](#_st_impdrv_dma_write_info_t) \*const p\_write\_info ,  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Non-Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | const [***st\_impdrv\_dma\_write\_info\_t***](#_st_impdrv_dma_write_info_t) \*const p\_write\_info | | | | Write register information. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | | N/A | | | | N/A | |
| **Parameters (Out)** | | N/A | | | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | |  | | |
| imp | | N/A | | |
| cnn | | N/A | | |
| dma | | no difference between the cores. | | |
| Ocv | | N/A | | |
| psc | | N/A | | |
| imps | | N/A | | |
| dmas | | no difference between the cores. | | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_dmactl\_tbl\_write\_reg

Table 2‑151: impdrv\_dmactl\_tbl\_write\_reg

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0028  impdrv\_dmactl\_tbl\_write\_reg  [Covers: AD\_PD\_CAS2470] | | | | | |
| **ASIL Level** | | ASIL D | **Status** | New | | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dmactl\_tbl\_write\_reg(  st\_impdrv\_corectl\_t \*const p\_corectl,  const bool is\_sub\_thread,  const [st\_impdrv\_dma\_write\_info\_tbl\_t](#_st_impdrv_dma_write_info_tbl_t) write\_info\_tbl[],  const uint32\_t write\_info\_tbl\_num  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core, | | | |
| **Range** | Not NULL | | |
| const bool is\_sub\_thread | | Thread selection, | | | |
| **Range** | | true or false | |
| const [st\_impdrv\_dma\_write\_info\_tbl\_t](#_st_impdrv_dma_write_info_tbl_t) write\_info\_tbl[] | | Write info table, | | | |
| **Range** | | | None. |
| Const uint32\_t  write\_info\_tbl\_num | | write\_info\_tbl\_num Number of writing info tables | | | |
| **Range** | | | None. |
| **Parameters (In-out)** | | N/A | | N/A | | | |
| **Parameters (Out)** | | N/A | | N/A | | | |
| **Return Value** | | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_dmactl\_mb\_init\_pre

Table 2‑152: impdrv\_dmactl\_mb\_init\_pre

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0029  impdrv\_dmactl\_mb\_init\_pre  [Covers: AD\_PD\_CAS2470] | | | |
| **ASIL Level** | | ASIL D | **Status** | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dmactl\_mb\_init\_pre(  st\_impdrv\_corectl\_t \*const p\_corectl,  const bool is\_sub\_thread,  ); | | | |
| **Sync/Async** | | Synchronous | | | |
| **Reentrancy** | | Reentrant | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | | st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core, | |
| **Range** | Not NULL |
| const bool is\_sub\_thread, | | Thread selection, | |
| **Range** | true or false |
| **Parameters (In-out)** | | N/A | | N/A | |
| **Parameters (Out)** | | N/A | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | | N/A | | | |
| **Remarks** | | N/A | | | |

#### impdrv\_dmactl\_mb\_init\_main

Table 2‑153: impdrv\_dmactl\_mb\_init\_main

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0030  impdrv\_dmactl\_mb\_init\_main  [Covers: AD\_PD\_CAS2470, AD\_PD\_CAS2472] | | | | | |
| **ASIL Level** | | ASIL D | **Status** | New | | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dmactl\_mb\_init\_main(  st\_impdrv\_corectl\_t \*const p\_corectl,  const bool is\_sub\_thread,  const uint32\_t start\_addr,  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core, | | | |
| **Range** | Not NULL | | |
| const bool is\_sub\_thread, | | Thread selection, | | | |
| **Range** | | true or false | |
| const uint32\_t start\_addr, | | Set the start address(odd bank / even bank) | | | |
| **Range** | | | None. |
| **Parameters (In-out)** | | N/A | | N/A | | | |
| **Parameters (Out)** | | N/A | | N/A | | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | | | |
| **Description** | | Refer to “3 Activity Diagrams”. | |  | | | |
| **Preconditions** | N/A | | | | | | |
| **Remarks** | | N/A | | | | | |
|  | |  | | | | | |

#### impdrv\_dmactl\_cl\_pre

Table 2‑154: impdrv\_dmactl\_cl\_pre

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0031  impdrv\_dmactl\_cl\_pre  [Covers: AD\_PD\_CAS2316, AD\_PD\_CAS2317] | | | | |
| **ASIL Level** | | ASIL D | **Status** | New | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dmactl\_cl\_pre(  st\_impdrv\_corectl\_t \*const p\_corectl,  const bool is\_sub\_thread  ); | | | | |
| **Sync/Async** | | Synchronous | | | | |
| **Reentrancy** | | Reentrant | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | |
| **Parameters (In)** | | st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core, | | |
| **Range** | Not NULL | |
| const bool is\_sub\_thread, | | Thread selection, | | |
| **Range** | | true or false |
| **Parameters (In-out)** | | N/A | | N/A | | |
| **Parameters (Out)** | | N/A | | N/A | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| **Preconditions** | | N/A | | | | |
| **Remarks** | | N/A | | | | |

#### impdrv\_dmactl\_int\_safety\_func

Table 2‑156: impdrv\_dmactl\_int\_safety\_func

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0037  impdrv\_dmactl\_int\_safety\_func  [Covers: AD\_PD\_CAS2352, AD\_PD\_CAS2353] | | | |
| **ASIL Level** | | ASIL D | **Status** | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dmactl\_int\_safety\_func (  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num  ); | | | |
| **Sync/Async** | | Synchronous | | | |
| **Reentrancy** | | Reentrant | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | | st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core, | |
| **Range** | Not NULL |
| const uint32\_t core\_num | | Core number. | |
| **Range** | Value less than IMPDRV\_CORE\_NUM\_MAX |
| **Parameters (In-out)** | | N/A | | N/A | |
| **Parameters (Out)** | | N/A | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | | N/A | | | |
| **Remarks** | | N/A | | | |

#### impdrv\_\*\*\*ctl\_int\_main\_func

Table 2‑155: impdrv\_\*\*\*ctl\_int\_main\_func

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0036  impdrv\_\*\*\*ctl\_int\_main\_func  [Covers: AD\_PD\_CAS2351, AD\_PD\_CAS2352, AD\_PD\_CAS2353, AD\_PD\_CAS2354, AD\_PD\_CAS2311, AD\_PD\_CAS2361, AD\_PD\_CAS2355, AD\_PD\_CAS2356] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_int\_main\_func (  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Non-Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | const uint32\_t core\_num | | | | Core number. | |
| **Range** | Value less than IMPDRV\_CORE\_NUM\_MAX |
| **Parameters (In-out)** | | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core, | |
| **Range** | Not NULL |
| **Parameters (Out)** | | N/A | | | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | |  | | |
| imp | | no difference between the cores. | | |
| Cnn | | N/A | | |
| dma | | no difference between the cores. | | |
| Ocv | | N/A | | |
| psc | | N/A | | |
| imps | | no difference between the cores. | | |
| Dmas | | N/A | | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_int\_safety\_func

Table 2‑156: impdrv\_\*\*\*ctl\_int\_safety\_func

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0078  impdrv\_\*\*\*ctl\_int\_safety\_func  [Covers: AD\_PD\_CAS2352, AD\_PD\_CAS2353] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_int\_safety\_func (  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Non-Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core, | |
| **Range** | Not NULL |
| const uint32\_t core\_num | | | | Core number. | |
| **Range** | Value less than IMPDRV\_CORE\_NUM\_MAX |
| **Parameters (In-out)** | | N/A | | | | N/A | |
| **Parameters (Out)** | | N/A | | | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | |  | | |
| imp | | no difference between the cores. | | |
| Cnn | | N/A | | |
| dma | | Refer to 2.4.2.12 | | |
| Ocv | | N/A | | |
| psc | | N/A | | |
| imps | | no difference between the cores. | | |
| Dmas | | N/A | | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_dma\_transfer

Table 2‑157: impdrv\_\*\*\*ctl\_dma\_transfer

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0038  impdrv\_\*\*\*ctl\_dma\_transfer  [Covers: AD\_PD\_CAS2527] | | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | New | | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_dma\_transfer  (  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t) \*const p\_chk\_resource,  const uintptr\_t physical\_adrs,  const uint32\_t transfer\_size  ); | | | | | | |
| **Sync/Async** | | Synchronous | | | | | | |
| **Reentrancy** | | Non-Reentrant | | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | | const uint32\_t core\_num | | | Specified core number. | | | |
| **Range** | | Value less than IMPDRV\_CORE\_NUM\_MAX | |
| const [st\_impdrv\_chk\_resource\_t](#_st_impdrv_chk_resource_t) \*const p\_chk\_resource | | | Pointer to the OSAL resource for bus interface check. | | | |
| **Range** | | Not NULL | |
| const uintptr\_t physical\_adrs | | | Physical address of the forwarding source | | | |
| **Range** | | None | |
| const uint32\_t transfer\_size | | | Transfer size | | | |
| **Range** | | None | |
| **Parameters (In-out)** | | st\_impdrv\_coretypectl\_t \*const p\_coretypectl | | | Control data structure for each core type | | | |
| **Range** | | | Not NULL |
| **Parameters (Out)** | | N/A | | | N/A | | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | | |
| Differences between cores. | | \*\*\* | | | N/A | | |
| imp | | | no difference between the cores. | | |
| Cnn | | | N/A | | |
| dma | | | no difference between the cores. | | |
| Ocv | | | N/A | | |
| psc | | | N/A | | |
| imps | | | no difference between the cores. | | |
| Dmas | | | N/A | | |
| **Preconditions** | | N/A | | | | | | |

#### impdrv\_\*\*\*ctl\_tbl\_write\_reg

Table 2‑158: impdrv\_\*\*\*ctl\_tbl\_write\_reg

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0033  impdrv\_\*\*\*ctl\_tbl\_write\_reg  [Covers: AD\_PD\_CAS2527] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_tbl\_write\_reg(  const st\_impdrv\_corectl\_t \*const p\_corectl,  const st\_impdrv\_imp\_write\_info\_tbl\_t write\_info\_tbl[],  const uint32\_t write\_info\_tbl\_num  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| const st\_impdrv\_imp\_write\_info\_tbl\_t write\_info\_tbl[] | | | | Write info table | |
| **Range** | Not NULL |
| const uint32\_t write\_info\_tbl\_num | | | | Number of writing info tables | |
| **Range** | N/A |
| **Parameters (In-out)** | | N/A | | | | N/A | |
| **Parameters (Out)** | | N/A | | | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | |  | | |
| imp | | no difference between the cores. | | |
| Cnn | | N/A | | |
| dma | | Refer to 2.4.2.8 | | |
| ocv | | N/A | | |
| psc | | N/A | | |
| imps | | no difference between the cores. | | |
| Dmas | | N/A | | |
| **Preconditions** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_check\_core\_busy

Table 2‑159: impdrv\_\*\*\*ctl\_check\_core\_busy

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0039  impdrv\_\*\*\*ctl\_check\_core\_busy  [Covers: AD\_PD\_CAS2316] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_check\_core\_busy(  const st\_impdrv\_corectl\_t \*const p\_corectl  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Non-Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| **Parameters (In-out)** | | N/A | | | | N/A | |
| **Parameters (Out)** | | N/A | | | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | |  | | |
| imp | | no difference between the cores. | | |
| Cnn | | no difference between the cores. | | |
| Dma | | Refer to 2.4.2.17 | | |
| ocv | | no difference between the cores. | | |
| Psc | | no difference between the cores. | | |
| Imps | | no difference between the cores. | | |
| Dmas | | Refer to 2.4.2.17 | | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_check\_core\_busy (\*\*\*:dma/dmas)

Table 2‑160: impdrv\_\*\*\*ctl\_check\_core\_busy (\*\*\*:dma/dmas)

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0040  impdrv\_\*\*\*ctl\_check\_core\_busy  [Covers: AD\_PD\_CAS2316] | | | | |
| **ASIL Level** | | ASIL D | | **Status** | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_check\_core\_busy(  const st\_impdrv\_corectl\_t \*const p\_corectl,  const bool is\_sub\_thread  ); | | | | |
| **Sync/Async** | | Synchronous | | | | |
| **Reentrancy** | | Non-Reentrant | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | Control data structure for specific core | |
| **Range** | Not NULL |
| const bool is\_sub\_thread | | | Thread selection | |
| **Range** | true or false |
| **Parameters (In-out)** | | N/A | | | N/A | |
| **Parameters (Out)** | | N/A | | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
|  | Differences between cores. | | \*\*\* |  | | |
|  |  | | dma | no difference between the cores. | | |
|  |  | | Dmas | no difference between the cores. | | |
| **Preconditions** | | N/A | | | | |
| **Remarks** | | N/A | | | | |

#### impdrv\_\*\*\*ctl\_soft\_reset

Table 2‑161: impdrv\_\*\*\*ctl\_soft\_reset

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0041  impdrv\_\*\*\*ctl\_soft\_reset  [Covers: AD\_PD\_CAS2317] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | New | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_soft\_reset(  const st\_impdrv\_corectl\_t \*const p\_corectl  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (In-out)** | | N/A | | | N/A | | |
| **Parameters (Out)** | | N/A | | | N/A | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | | |  | |
| imp | | | Difference is to describe the activity diagram. | |
| Cnn | | | Difference is to describe the activity diagram. | |
| Dma | | | Refer to 2.4.1.22 | |
| ocv | | | Difference is to describe the activity diagram. | |
| Psc | | | Difference is to describe the activity diagram. | |
| Imps | | | Difference is to describe the activity diagram. | |
| Dmas | | | Refer to 2.4.1.22 | |
| Dsp | | | N/A | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_soft\_reset (\*\*\*:dma/dmas)

Table 2‑162: impdrv\_\*\*\*ctl\_soft\_reset (\*\*\*:dma/dmas)

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0042  impdrv\_\*\*\*ctl\_soft\_reset  [Covers: AD\_PD\_CAS2317] | | | | | |
| **ASIL Level** | | ASIL D | **Status** | | | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_soft\_reset(  st\_impdrv\_corectl\_t \*const p\_corectl,  const bool is\_sub\_thread  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | st\_impdrv\_corectl\_t \*const p\_corectl | | | | Control data structure for specific core | |
| **Range** | Not NULL |
| const bool is\_sub\_thread | | | | Thread selection | |
| **Range** | true or false |
| **Parameters (In-out)** | | N/A | | | | N/A | |
| **Parameters (Out)** | | N/A | | | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
|  | Differences between cores. | | | \*\*\* |  | | |
|  |  | | | dma | no difference between the cores. | | |
|  |  | | | Dmas | no difference between the cores. | | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_set\_syncc\_config

Table 2‑163: impdrv\_\*\*\*ctl\_set\_syncc\_config

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0043  impdrv\_\*\*\*ctl\_set\_syncc\_config  [Covers: AD\_PD\_CAS2317] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | New | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_syncc\_config(  const st\_impdrv\_corectl\_t \*const p\_corectl  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| **Parameters (In-out)** | | N/A | | | N/A | | |
| **Parameters (Out)** | | N/A | | | N/A | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | | |  | |
| imp | | | no difference between the cores. | |
| Cnn | | | no difference between the cores. | |
| Dma | | | Refer to 2.4.2.21 | |
| ocv | | | no difference between the cores. | |
| Psc | | | no difference between the cores. | |
| Imps | | | no difference between the cores. | |
| Dmas | | | Refer to 2.4.2.21 | |
| Dsp | | | N/A | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_set\_syncc\_config (\*\*\*:dma/dmas)

Table 2‑164: impdrv\_\*\*\*ctl\_set\_syncc\_config (\*\*\*:dma/dmas)

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0044  impdrv\_\*\*\*ctl\_set\_syncc\_config  [Covers: AD\_PD\_CAS2317] | | | | | |
| **ASIL Level** | | ASIL D | **Status** | | New | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_syncc\_config(  const st\_impdrv\_corectl\_t \*const p\_corectl,  const bool is\_sub\_thread  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | Control data structure for specific core | | |
| **Range** | | Not NULL |
| const bool is\_sub\_thread | | | Thread selection | | |
| **Range** | | true or false |
| **Parameters (In-out)** | | N/A | | | N/A | | |
| **Parameters (Out)** | | N/A | | | N/A | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
|  | Differences between cores. | | | \*\*\* | |  | |
|  |  | | | dma | | no difference between the cores. | |
|  |  | | | Dmas | | no difference between the cores. | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_int\_cb

Table 2‑165: impdrv\_\*\*\*ctl\_int\_cb

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0045  impdrv\_\*\*\*ctl\_int\_cb  [Covers: AD\_PD\_CAS2351] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | New | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_int\_cb(  const st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX],  const uint32\_t cb\_ercd\_num,  const bool is\_check\_intclear,  const uint32\_t dtl\_stat\_val  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | Control data structure for specific core. | | |
| **Range** | | Not NULL |
| const uint32\_t core\_num | | | Specified core number. | | |
| **Range** | | Value less than IMPDRV\_\*\*\*\_CORENUM\_VAL |
| const e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX] | | | Callback error code. | | |
| **Range** | | Not NULL |
| const uint32\_t cb\_ercd\_num | | | Number of error codes in callback. | | |
| **Range** | | Value less than IMPDRV\_CB\_RET\_MAX |
| const bool is\_check\_intclear | | | Interrupt clear wait execution flag. | | |
| **Range** | | true or false |
| const uint32\_t dtl\_stat\_val | | | Detail status value. | | |
| **Range** | | None |
| **Parameters (In-out)** | | N/A | | | N/A | | |
| **Parameters (Out)** | | N/A | | | N/A | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | | | N/A | |
| imp | | | Refer to 2.4.2.23 | |
| cnn | | | no difference between the cores. | |
| Dma | | | no difference between the cores. | |
| Ocv | | | no difference between the cores. | |
| Psc | | | no difference between the cores. | |
| Imps | | | Refer to 2.4.2.23 | |
| dmas | | | no difference between the cores. | |
| Dsp | | | N/A | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_int\_cb (\*\*\*:imp/imps)

Table 2‑166: impdrv\_\*\*\*ctl\_int\_cb (\*\*\*:imp/imps)

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0046  impdrv\_\*\*\*ctl\_int\_cb  [Covers: AD\_PD\_CAS2351] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | New | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_int\_cb(  const st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX],  const uint32\_t cb\_ercd\_num,  const bool is\_check\_intclear,  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | Control data structure for specific core. | | |
| **Range** | | Not NULL |
| const uint32\_t core\_num | | | Specified core number. | | |
| **Range** | | Value less than IMPDRV\_\*\*\*\_CORENUM\_VAL |
| const e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX] | | | Callback error code. | | |
| **Range** | | Not NULL |
| const uint32\_t cb\_ercd\_num | | | Number of error codes in callback. | | |
| **Range** | | Value less than IMPDRV\_CB\_RET\_MAX |
| const bool is\_check\_intclear | | | Interrupt clear wait execution flag. | | |
| **Range** | | true or false |
| **Parameters (In-out)** | | N/A | | | N/A | | |
| **Parameters (Out)** | | N/A | | | N/A | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_NOTSUPPORT | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
|  | Differences between cores. | | \*\*\* | | |  | |
|  |  | | imp | | | no difference between the cores. | |
|  |  | | Imps | | | no difference between the cores. | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_check\_inten

Table 2‑167: impdrv\_\*\*\*ctl\_check\_inten

|  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0047  impdrv\_\*\*\*ctl\_check\_inten  [Covers: AD\_PD\_CAS2351] | | | | | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | New | | | | | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_check\_inten(  const uint32\_t stat\_val,  uint32\_t \*const p\_mask\_val,  e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX],  uint32\_t \*const p\_cb\_ercd\_num,  bool \*const p\_is\_check\_intclear,  e\_impdrv\_state\_t \*const p\_state  ); | | | | | | | | | |
| **Sync/Async** | | Synchronous | | | | | | | | | |
| **Reentrancy** | | Reentrant | | | | | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | | | | | |
| **Parameters (In)** | | const uint32\_t stat\_val | | | Status register value. | | | | | | |
| **Range** | None | | | | | |
| **Parameters (In-out)** | | N/A | | | N/A | | | | | | |
| **Parameters (Out)** | | uint32\_t \*const p\_mask\_val | | | Interrupt mask value. | | | | | | |
| **Range** | | | Not NULL | | | |
| e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX] | | | Callback error code. | | | | | | |
| **Range** | | Not NULL | | | | |
| uint32\_t \*const p\_cb\_ercd\_num | | | Number of error codes in callback. | | | | | | |
| **Range** | | | | Not NULL | | |
| bool \*const p\_is\_check\_intclear | | | Interrupt clear wait execution flag. | | | | | | |
| **Range** | | | | | | Not NULL |
| e\_impdrv\_state\_t \*const p\_state | | | IMP Driver state to be transitioned. | | | | | | |
| **Range** | | | | | Not NULL | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL | | | | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | | | | | |
| Differences between cores. | | \*\*\* | |  | | | | | | |
| imp | | Difference is to describe the activity diagram. | | | | | | |
| Cnn | | Difference is to describe the activity diagram. | | | | | | |
| Dma | | Difference is to describe the activity diagram. | | | | | | |
| Ocv | | Refer to 2.4.2.25 | | | | | | |
| psc | | Difference is to describe the activity diagram. | | | | | | |
| Imps | | Difference is to describe the activity diagram.. | | | | | | |
| Dmas | | Difference is to describe the activity diagram. | | | | | | |
| **Preconditions** | | N/A | | | | | | | | | |
| **Remarks** | | p\_mask\_val, cb\_ercd, p\_cb\_ercd\_num, p\_is\_check\_intclear and p\_state arre pointer of output parameter, so the use of those pointer variable is acceptable. | | | | | | | | | |

#### impdrv\_ocvctl\_check\_inten

Table 2‑168: impdrv\_ocvctl\_check\_inten

|  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0048  impdrv\_ocvctl\_check\_inten  [Covers: AD\_PD\_CAS2351] | | | | | | | | |
| **ASIL Level** | | ASIL D | **Status** | New | | | | | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_ocvctl\_check\_inten(  const uint32\_t stat\_sr1,  const uint32\_t stat\_sr2,  uint32\_t \*const p\_mask\_val,  e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX],  uint32\_t \*const p\_cb\_ercd\_num,  bool \*const p\_is\_check\_intclear,  e\_impdrv\_state\_t \*const p\_state  ); | | | | | | | | |
| **Sync/Async** | | Synchronous | | | | | | | | |
| **Reentrancy** | | Non-Reentrant | | | | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | | | | |
| **Parameters (In)** | | const uint32\_t stat\_sr1 | | SR1 register value. | | | | | | |
| **Range** | None | | | | | |
| const uint32\_t stat\_sr2 | | SR2 register value. | | | | | | |
| **Range** | None | | | | | |
| **Parameters (In-out)** | | N/A | | N/A | | | | | | |
| **Parameters (Out)** | | uint32\_t \*const p\_mask\_val | | Interrupt mask value. | | | | | | |
| **Range** | | | Not NULL | | | |
| e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX] | | Callback error code. | | | | | | |
| **Range** | | Not NULL | | | | |
| uint32\_t \*const p\_cb\_ercd\_num | | Number of error codes in callback. | | | | | | |
| **Range** | | | | Not NULL | | |
| bool \*const p\_is\_check\_intclear | | Interrupt clear wait execution flag. | | | | | | |
| **Range** | | | | | | Not NULL |
| e\_impdrv\_state\_t \*const p\_state | | IMP Driver state to be transitioned. | | | | | | |
| **Range** | | | | | Not NULL | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | | | | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | | | | |
| **Preconditions** | | N/A | | | | | | | | |
| **Remarks** | | p\_mask\_val, cb\_ercd, p\_cb\_ercd\_num, p\_is\_check\_intclear and p\_state arre pointer of output parameter, so the use of those pointer variable is acceptable. | | | | | | | | |

#### impdrv\_ocvctl\_irq\_status\_clear

Table 2‑169: impdrv\_ocvctl\_irq\_status\_clear

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0049  impdrv\_ocvctl\_irq\_status\_clear  [Covers: AD\_PD\_CAS2317] | | | |
| **ASIL Level** | | ASIL D | **Status** | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_ocvctl\_irq\_status\_clear(  const st\_impdrv\_corectl\_t \*const p\_corectl,  uint32\_t mask\_val  ); | | | |
| **Sync/Async** | | Synchronous | | | |
| **Reentrancy** | | Reentrant | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core | |
| **Range** | Not NULL |
| uint32\_t mask\_val | | IRQ status mask value | |
| **Range** | None |
| **Parameters (In-out)** | | N/A | | N/A | |
| **Parameters (Out)** | | N/A | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | | N/A | | | |
| **Remarks** | | N/A | | | |

#### impdrv\_ocvctl\_check\_inten\_1st

Table 2‑170: impdrv\_ocvctl\_check\_inten\_1st

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0050  impdrv\_ocvctl\_check\_inten\_1st  [Covers: AD\_PD\_CAS2351] | | | | | | |
| **ASIL Level** | | ASIL D | **Status** | New | | | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_ocvctl\_check\_inten\_1st(  const uint32\_t stat\_sr1,  const uint32\_t stat\_sr2,  uint32\_t \*const p\_mask\_val,  e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX],  uint32\_t \*const p\_cb\_ercd\_num,  bool \*const p\_is\_check\_intclear,  e\_impdrv\_state\_t \*const p\_state  ); | | | | | | |
| **Sync/Async** | | Synchronous | | | | | | |
| **Reentrancy** | | Reentrant | | | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | | | |
| **Parameters (In)** | | const uint32\_t stat\_sr1 | | SR1 register value. | | | | |
| **Range** | None | | | |
| const uint32\_t stat\_sr2 | | SR2 register value. | | | | |
| **Range** | None | | | |
| **Parameters (In-out)** | | uint32\_t \*const p\_mask\_val | | Interrupt mask value. | | | | |
| **Range** | Not NULL | | | |
| uint32\_t \*const p\_cb\_ercd\_num | | Number of error codes in callback. | | | | |
| **Range** | Not NULL | | | |
| **Parameters (Out)** | | e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX] | | Callback error code. | | | | |
| **Range** | | Not NULL | | |
| bool \*const p\_is\_check\_intclear | | Interrupt clear wait execution flag. | | | | |
| **Range** | | | | Not NULL |
| e\_impdrv\_state\_t \*const p\_state | | IMP Driver state to be transitioned. | | | | |
| **Range** | | | Not NULL | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | | |
| **Preconditions** | | N/A | | | | | | |
| **Remarks** | | p\_mask\_val, cb\_ercd, p\_cb\_ercd\_num, p\_is\_check\_intclear and p\_state are pointer of output parameter, so the use of those pointer variable is acceptable. | | | | | | |

#### impdrv\_ocvctl\_check\_inten\_2nd

Table 2‑171: impdrv\_ocvctl\_check\_inten\_2nd

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0051  impdrv\_ocvctl\_check\_inten\_2nd  [Covers: AD\_PD\_CAS2351] | | | | |
| **ASIL Level** | | ASIL D | **Status** | New | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_ocvctl\_check\_inten\_2nd(  const uint32\_t stat\_sr1,  e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX],  uint32\_t \*const p\_cb\_ercd\_num,  e\_impdrv\_state\_t \*const p\_state  ); | | | | |
| **Sync/Async** | | Synchronous | | | | |
| **Reentrancy** | | Reentrant | | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | | |
| **Parameters (In)** | | const uint32\_t stat\_sr1 | | SR1 register value. | | |
| **Range** | None | |
| **Parameters (In-out)** | | uint32\_t \*const p\_cb\_ercd\_num | | Number of error codes in callback. | | |
| **Range** | Not NULL | |
| e\_impdrv\_state\_t \*const p\_state | | IMP Driver state to be transitioned. | | |
| **Range** | Not NULL | |
| **Parameters (out)** | | e\_impdrv\_cb\_ret\_t cb\_ercd[IMPDRV\_CB\_RET\_MAX] | | Callback error code. | | |
| **Range** | | Not NULL |
| **Return Value** | | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| **Preconditions** | | N/A | | | | |
| **Remarks** | | p\_mask\_val, cb\_ercd, p\_cb\_ercd\_num, and p\_state are pointer of output parameter, so the use of those pointer variable is acceptable. | | | | |

#### impdrv\_ocvctl\_init\_lwm

Table 2‑172: impdrv\_ocvctl\_init\_lwm

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0052  impdrv\_ocvctl\_init\_lwm  [Covers: AD\_PD\_CAS2249] | | | |
| **ASIL Level** | | ASIL D | **Status** | New | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_ocvctl\_init\_lwm(  const st\_impdrv\_corectl\_t \*const p\_corectl  ); | | | |
| **Sync/Async** | | Synchronous | | | |
| **Reentrancy** | | Non-Reentrant | | | |
| **Interrupt State** | | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core | |
| **Range** | Not NULL |
| **Parameters (In-out)** | | N/A | | N/A | |
| **Parameters (Out)** | | N/A | | N/A | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | | N/A | | | |
| **Remarks** | | V3H2 is not supported. | | | |

#### impdrv\_ocvctl\_init\_core

Table 2‑144: impdrv\_ocvctl\_init\_core

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0019  impdrv\_ocvctl\_init\_core  [Covers: AD\_PD\_CAS2249, AD\_PD\_CAS2250] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_ocvctl\_init\_core(  const st\_impdrv\_corectl\_t \*const p\_corectl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_dspctl\_dsp\_update\_app

Table 2‑173: impdrv\_dspctl\_dsp\_update\_app

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0073  impdrv\_dspctl\_dsp\_update\_app  [Covers: AD\_PD\_CAS2315, AD\_PD\_CAS2316, AD\_PD\_CAS2317, AD\_PD\_CAS2432, AD\_PD\_CAS2246, AD\_PD\_CAS2363, AD\_PD\_CAS2249, AD\_PD\_CAS2250] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dspctl\_dsp\_update\_app (  st\_impdrv\_corectl\_t \*const p\_corectl,  st\_impdrv\_device\_handle\_t \*const p\_device\_io  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | st\_impdrv\_device\_handle\_t \*const p\_device\_io | | Device io handle for DSP | | |
| **Range** | | Not Null |
| **Parameters (In-out)** | st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core | | |
| **Range** | Not Null | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]  <Only DSP core>   * Add expression that whether DSP information (is\_update, is\_loaded and is\_executed) is true or not when call impdrv\_dspctl\_dsp\_foece\_standby * Add expression that whether DSP information (is\_update, is\_loaded and is\_executed) is true or not when call impdrv\_dspctl\_load\_ptcm | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | This function is only used in DSP core | | | | |

#### impdrv\_dspctl\_load\_ptcm

Table 2‑174: impdrv\_dspctl\_load\_ptcm

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0065  impdrv\_dspctl\_load\_ptcm  [Covers: AD\_PD\_CAS2246, AD\_PD\_CAS2363, AD\_PD\_CAS2249, AD\_PD\_CAS2250, AD\_PD\_CAS2315, AD\_PD\_CAS2316, AD\_PD\_CAS2317, AD\_PD\_CAS2432] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dspctl\_load\_ptcm (  const st\_impdrv\_corectl\_t \*const p\_corectl,  st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core | |
| **Range** | Not Null |
| st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP | |
| **Range** | Not Null |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_ATTRIBUTE  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * For processing of Start from the vector address RST\_VEC\_ADDR, Include expression of whether ercd is IMPDRV\_EC\_OK or not in the previous expression * For processing of Transfer the boot program from external to internal program, remove expression of whether ercd is IMPDRV\_EC\_OK or not | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_stop\_reg

Table 2‑175: impdrv\_dspctl\_stop\_reg

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0069  impdrv\_dspctl\_stop\_reg  [Covers: AD\_PD\_CAS2364] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dspctl\_stop\_reg(  const bool is\_executed,  st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const bool is\_executed | | Is the DSP application already executed on DSP | |
| **Range** | true or false |
| st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP | |
| **Range** | Not Null |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * For processing of Clear GPIO\_IN register, remove expression of whether ercd is IMPDRV\_EC\_OK or not | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_\*\*\*ctl\_set\_extend\_config

Table 2‑177: impdrv\_\*\*\*ctl\_set\_extend\_config

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0056  impdrv\_\*\*\*ctl\_set\_extend\_config  [Covers: AD\_PD\_CAS2317] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | New | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_extend\_config(  const st\_impdrv\_corectl\_t \*const p\_corectll  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | |  | | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | Control data structure for specific core. | | |
| **Range** | | Not NULL |
| **Parameters (In-out)** | | N/A | | | N/A | | |
| **Parameters (Out)** | | N/A | | | N/A | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_SEQSTATE | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | | | N/A | |
| imp | | | no difference between the cores. | |
| cnn | | | no difference between the cores. | |
| Dma | | | Refer to 2.4.2.34 | |
| Ocv | | | no difference between the cores. | |
| Psc | | | no difference between the cores. | |
| Imps | | | N/A. | |
| dmas | | | Refer to 2.4.2.34 | |
| dsp | | | N/A | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_\*\*\*ctl\_set\_extend\_config (\*\*\*:dma/dmas)

Table 2‑178: impdrv\_\*\*\*ctl\_set\_extend\_config(\*\*\*:dma/dmas)

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | | UD\_PD\_UD02\_04\_0057  impdrv\_\*\*\*ctl\_set\_extend\_config  [Covers: AD\_PD\_CAS2317] | | | | | |
| **ASIL Level** | | ASIL D | | **Status** | New | | |
| **Syntax** | | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_\*\*\*ctl\_set\_extend\_config(  const st\_impdrv\_corectl\_t \*const p\_corectll,  const bool is\_sub\_thread  ); | | | | | |
| **Sync/Async** | | Synchronous | | | | | |
| **Reentrancy** | | Reentrant | | | | | |
| **Interrupt State** | |  | | | | | |
| **Parameters (In)** | | const st\_impdrv\_corectl\_t \*const p\_corectl | | | Control data structure for specific core. | | |
| **Range** | | Not NULL |
| const bool is\_sub\_thread | | | Thread selection. | | |
| **Range** | true or false | |
| **Parameters (In-out)** | | N/A | | | N/A | | |
| **Parameters (Out)** | | N/A | | | N/A | | |
| **Return Value** | | e\_impdrv\_errorcode\_t | | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_SEQSTATE | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | | |
| Differences between cores. | | \*\*\* | | | N/A | |
| Dma | | | no difference between the cores. | |
| dmas | | | no difference between the cores. | |
| **Preconditions** | | N/A | | | | | |
| **Remarks** | | N/A | | | | | |

#### impdrv\_dspctl\_init\_dsp

Table 2‑179: impdrv\_dspctl\_init\_dsp

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0061  impdrv\_dspctl\_init\_dsp  [Covers: AD\_PD\_CAS2315, AD\_PD\_CAS2316, AD\_PD\_CAS2317] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dspctl\_init\_dsp(  st\_impdrv\_corectl\_t \* p\_corectl  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_get\_device\_io

Table 2‑180: impdrv\_dspctl\_get\_device\_io

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0062  impdrv\_dspctl\_get\_device\_io  [Covers: AD\_PD\_CAS2315, AD\_PD\_CAS2281, AD\_PD\_CAS2246, AD\_PD\_CAS2348, AD\_PD\_CAS2038, AD\_PD\_CAS2034] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dspctl\_init\_dsp(  st\_impdrv\_corectl\_t \* p\_corectl,  st\_impdrv\_device\_handle\_t \*p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | const st\_impdrv\_corectl\_t \*const p\_corectl | | Control data structure for specific core. | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | st\_impdrv\_device\_handle\_t \*  p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP | | |
| **Range** | | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | This function is only used in DSP core | | | | |

#### impdrv\_dspctl\_init\_core

Table 2‑194: impdrv\_dspctl\_init\_core

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_04\_0077  impdrv\_dspctl\_init\_core  [Covers: AD\_PD\_CAS2249, AD\_PD\_CAS2250] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_dspctl\_init\_core(  st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t  \*const  p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A. | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_chk\_execute\_data

Table 2‑195: impdrv\_dspctl\_chk\_execute\_data

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0063***  impdrv\_dspctl\_chk\_execute\_data  ***[Covers: AD\_PD\_CAS2315]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_chk\_execute\_data (  const ***st\_impdrv\_corectl\_t*** \* const p\_corectl,  const uint32\_t core\_num,  const ***p\_impdrv\_cbfunc\_t*** callback\_func  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const ***st\_impdrv\_corectl\_t***  \*const p\_corectl | | Control data structure for specific core. | |
| **Range** | Not NULL |
| const uint32\_t  core\_num | | Core number. | |
| **Range** | Not NULL |
| ***p\_impdrv\_cbfunc\_t*** callback\_func | | Callback function of execute request | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_ATTRIBUTE  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_dsp\_execute\_pre

Table 2‑196: impdrv\_dspctl\_dsp\_execute\_pre

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0064***  impdrv\_dspctl\_dsp\_execute\_pre  ***[Covers: AD\_PD\_CAS2315, AD\_PD\_CAS2431, AD\_PD\_CAS2317]*** | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | IMPDRV\_STATIC  ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_dsp\_execute\_pre(  ***st\_impdrv\_corectl\_t*** \* const p\_corectl,  const uint32\_t core\_num,  st\_impdrv\_device\_handle\_t \*p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | const ***st\_impdrv\_corectl\_t***  \*const p\_corectl | | Control data structure for specific core. | | |
| **Range** | | Not NULL |
| const uint32\_t  core\_num | | Core number. | | |
| **Range** | | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | st\_impdrv\_device\_handle\_t \*p\_device\_io  [IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP. | | |
| **Range** | Not NULL | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | This function is only used in DSP core | | | | |

#### impdrv\_dspctl\_tcm\_config\_d

Table 2‑197:impdrv\_dspctl\_tcm\_config\_d

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0066***  impdrv\_dspctl\_tcm\_config\_d  ***[Covers: AD\_PD\_CAS2249, AD\_PD\_CAS2317]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_tcm\_config\_d(  const ***st\_impdrv\_corectl\_t*** \* const p\_corectl,  st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const ***st\_impdrv\_corectl\_t***  \*const p\_corectl | | Control data structure for specific core. | |
| **Range** | Not NULL |
| st\_impdrv\_device\_handle\_t  \*const p\_device\_io  [IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_tcm\_config\_p

Table 2‑197:impdrv\_dspctl\_tcm\_config\_p

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0067***  impdrv\_dspctl\_tcm\_config\_p  ***[Covers: AD\_PD\_CAS2249, AD\_PD\_CAS2317]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_tcm\_config\_p(  const ***st\_impdrv\_corectl\_t*** \* const p\_corectl,  st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const ***st\_impdrv\_corectl\_t***  \*const p\_corectl | | Control data structure for specific core. | |
| **Range** | Not NULL |
| st\_impdrv\_device\_handle\_t  \*const p\_device\_io  [IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_ load\_dtcm

Table 2‑197:impdrv\_dspctl\_ load\_dtcm

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0068***  impdrv\_dspctl\_load\_dtcm  ***[Covers: AD\_PD\_CAS2249, AD\_PD\_CAS2317]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_load\_dtcm(  const ***st\_impdrv\_corectl\_t*** \* const p\_corectl,  st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const ***st\_impdrv\_corectl\_t***  \*const p\_corectl | | Control data structure for specific core. | |
| **Range** | Not NULL |
| st\_impdrv\_device\_handle\_t  \*const p\_device\_io  [IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_dsp\_standby

Table 2‑200: impdrv\_dspctl\_dsp\_standby

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0070***  impdrv\_dspctl\_dsp\_standby  ***[Covers: AD\_PD\_CAS2432, AD\_PD\_CAS2364]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_dsp\_standby(  st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | st\_impdrv\_device\_handle\_t  \*const p\_device\_io  [IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_dsp\_foece\_standby

Table 2‑201: impdrv\_dspctl\_dsp\_foece\_standby

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0071***  impdrv\_dspctl\_dsp\_foece\_standby  ***[Covers: AD\_PD\_CAS2432, AD\_PD\_CAS2364]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_dsp\_foece\_standby(  st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | st\_impdrv\_device\_handle\_t  \*const p\_device\_io  [IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR  IMPDRV\_EC\_NG\_DSP\_HALT | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |

#### impdrv\_dspctl\_chk\_int\_data

Table 2‑196: impdrv\_dspctl\_chk\_int\_data

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0071***  impdrv\_dspctl\_chk\_int\_data  ***[Covers: AD\_PD\_CAS2351]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_chk\_int\_data (  ***st\_impdrv\_corectl\_t*** \* const p\_corectl,  const uint32\_t core\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const ***st\_impdrv\_corectl\_t***  \*const p\_corectl | | Control data structure for specific core. | |
| **Range** | Not NULL |
| const uint32\_t  core\_num | | Core number. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  MPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_NOTSUPPORT | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |







#### impdrv\_dspctl\_crc\_sub

Table 2‑196: impdrv\_dspctl\_crc\_sub

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ***UD\_PD\_UD02\_04\_0075***  impdrv\_dspctl\_crc\_sub  ***[Covers: AD\_PD\_CAS2603, AD\_PD\_CAS2317, AD\_PD\_CAS2600, AD\_PD\_CAS2249]*** | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  ***e\_impdrv\_errorcode\_t*** impdrv\_dspctl\_crc\_sub(  const uint32\_t st,  const uint32\_t sz,  st\_impdrv\_device\_handle\_t \*const p\_device\_io[IMPDRV\_DSP\_DEV\_NUM\_MAX]  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | uint32\_t st | | Start Address. | |
| **Range** | N/A |
| uint32\_t sz | | Size of Memory (Long Word). | |
| **Range** | N/A |
| st\_impdrv\_device\_handle\_t  \*const p\_device\_io  [IMPDRV\_DSP\_DEV\_NUM\_MAX] | | Device io handle for DSP. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | ***e\_impdrv\_errorcode\_t*** | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “***3 Activity Diagrams***”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is only used in DSP core | | | |







## Functions of OS Dependence Layer

Table 2‑176: Function List

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **No.** | **Function Name** | **Access** | **ASIL** | **Source File Name** |
|  | impdrv\_osdep\_pow\_on\_imp\_top | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_pow\_off\_imp\_top | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_register\_irq | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_enable\_irq | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_disable\_irq | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_unregister\_irq | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_pow\_on\_imp | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_pow\_off\_imp | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_pm\_set\_policy | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_pm\_get\_policy | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_pm\_get\_state | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_write\_reg | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_read\_reg | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_mutex\_create | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_mutex\_destroy | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_mutex\_lock | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_mutex\_unlock | Public | ASIL D | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_reset\_core](#_impdrv_osdep_reset_core) | Public | ASIL D | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_pow\_on\_hwrsc](#_impdrv_osdep_pow_on_hwrsc) | Public | ASIL D | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_pow\_off\_hwrsc](#_impdrv_osdep_pow_off_hwrsc) | Public | ASIL D | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_memory\_barrier](#_impdrv_osdep_memory_barrier) | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_queue\_create | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_queue\_destroy | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_queue\_wait\_period | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_queue\_send\_period | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_dev\_open\_imp | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_memory\_get\_size | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_memory\_get\_logical | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_memory\_get\_physical | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_memory\_cache\_flush | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_memory\_cache\_clean | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_memory\_data\_set | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_memory\_compare | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_dev\_open\_dsp | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_pow\_on\_imp\_dsp | Public | ASIL D | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_register\_dsp\_irq](#_impdrv_osdep_register_dsp_irq_1) | Public | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_enable\_dsp\_irq](#_impdrv_osdep_enable_dsp_irq) | Public | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_disable\_dsp\_irq](#_impdrv_osdep_disable_dsp_irq) | Public | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_unregister\_dsp\_irq](#_impdrv_osdep_unregister_dsp_irq_1) | Public | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_pow\_on\_dsp](#_impdrv_osdep_pow_on_dsp) | Public | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_pow\_off\_dsp](#_impdrv_osdep_pow_off_dsp) | Public | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_dsp\_close](#_impdrv_osdep_dsp_close) | Public | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_reset\_core\_dsp](#_impdrv_osdep_reset_core_dsp) | Public | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_dev\_open | Private | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_pow\_on | Private | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_pow\_off | Private | ASIL D | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_int\_handler](#_impdrv_osdep_int_handler) | Private | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_chk\_core\_info | Private | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_chk\_instance\_num | Private | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_get\_irq\_channel | Private | ASIL D | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_dev\_open\_dsp\_sub | Private | ASIL D | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_get\_dsp\_irq\_channel](#_impdrv_osdep_get_dsp_irq_channel) | Private | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_dsp0\_int\_handler](#_impdrv_osdep_dsp0_int_handler) | Private | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_dsp1\_int\_handler](#_impdrv_osdep_dsp1_int_handler) | Private | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_dsp2\_int\_handler](#_impdrv_osdep_dsp2_int_handler) | Private | - | r\_impdrv\_osdep.c |
|  | [impdrv\_osdep\_dsp3\_int\_handler](#_impdrv_osdep_dsp3_int_handler) | Private | - | r\_impdrv\_osdep.c |
|  | impdrv\_osdep\_wait\_for\_req\_state | Private | ASIL D | r\_impdrv\_osdep.c |

### Public function

#### impdrv\_osdep\_pow\_on\_imp\_top

Table 2‑177: impdrv\_osdep\_pow\_on\_imp\_top

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0001  impdrv\_osdep\_pow\_on\_imp\_top  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1002, AD\_PD\_CAS2048, AD\_PD\_CAS2049, AD\_PD\_CAS2050, AD\_PD\_CAS1005, AD\_PD\_CAS2564, AD\_PD\_CAS2465, AD\_PD\_CAS2478] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pow\_on\_imp\_top(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_pow\_off\_imp\_top

Table 2‑178: impdrv\_osdep\_pow\_off\_imp\_top

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0002  impdrv\_osdep\_pow\_off\_imp\_top  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1004, AD\_PD\_CAS2108, AD\_PD\_CAS2109 AD\_PD\_CAS2110, AD\_PD\_CAS1006, AD\_PD\_CAS2547] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pow\_off\_imp\_top(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_register\_irq

Table 2‑179: impdrv\_osdep\_register\_irq

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0003  impdrv\_osdep\_register\_irq  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1002, AD\_PD\_CAS2051, AD\_PD\_CAS2052] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_register\_irq(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const e\_impdrv\_instance\_t instance\_num ,  const e\_osal\_interrupt\_priority\_t irq\_priority,  const impdrv\_ctrl\_handle\_t osal\_cb\_args  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | | |
| **Range** | Not NULL | |
| const e\_impdrv\_instance\_t instance\_num | | Instance number  The lifetime of this parameter is until impdrv\_osdep\_pow\_on\_imp\_top returns. | | |
| **Range** | Refer to 5.4.2.1.3. | |
| const e\_osal\_interrupt\_priority\_t irq\_priority | |  | | |
| **Range** | | Within the range of ENUM type. |
| Const impdrv\_ctrl\_handle\_t osal\_cb\_args | | OSAL callback argument  The lifetime of this parameter is the period from the R\_IMPDRV\_Init is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | | |
| **Range** | | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Range** | | N/A |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_enable\_irq

Table 2‑180: impdrv\_osdep\_enable\_irq

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0004  impdrv\_osdep\_enable\_irq  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1002, AD\_PD\_CAS2053, AD\_PD\_CAS2054] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_enable\_irq(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle ,  const e\_impdrv\_instance\_t instance\_num  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | | |
| **Range** | Not NULL | |
| const e\_impdrv\_instance\_t instance\_num | | Num of instance  The lifetime of this parameter is until impdrv\_osdep\_pow\_on\_imp\_top returns. | | |
| **Range** | | Refer to 5.4.2.1.3. |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Range** | | N/A |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_disable\_irq

Table 2‑181: impdrv\_osdep\_disable\_irq

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0005  impdrv\_osdep\_disable\_irq  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1004, AD\_PD\_CAS2102, AD\_PD\_CAS2103] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_disable\_irq(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const e\_impdrv\_instance\_t instance\_num  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | Not NULL | |
| const e\_impdrv\_instance\_t instance\_num | | Num of instance | | |
| **Range** | | Refer to 5.4.2.1.3. |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Range** | | N/A |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_unregister\_irq

Table 2‑182: impdrv\_osdep\_unregister\_irq

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0006  impdrv\_osdep\_unregister\_irq  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1004, AD\_PD\_CAS2106, AD\_PD\_CAS2107] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_unregister\_irq(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const e\_impdrv\_instance\_t instance\_num  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | Not NULL | |
| const e\_impdrv\_instance\_t instance\_num | | Num of instance | | |
| **Range** | | Refer to 5.4.2.1.3. |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Range** | | N/A |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_pow\_on\_imp

Table 2‑183: impdrv\_osdep\_pow\_on\_imp

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0007  impdrv\_osdep\_pow\_on\_imp  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1003, AD\_PD\_CAS2059, AD\_PD\_CAS2257, AD\_PD\_CAS2258, AD\_PD\_CAS2259, AD\_PD\_CAS2548, AD\_PD\_CAS2438, AD\_PD\_CAS2440] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pow\_on\_imp(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle ,  const [st\_impdrv\_core\_info\_t](#_API_Layer_2) core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const [st\_impdrv\_core\_info\_t](#_API_Layer_2)  core\_info | | Core information  The lifetime of this parameter is until impdrv\_osdep\_pow\_on\_imp\_top returns. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * Change from impdrv\_osdep\_dev\_open to impdrv\_osdep\_dev\_open\_imp | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_pow\_off\_imp

Table 2‑184: impdrv\_osdep\_pow\_off\_imp

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0008  impdrv\_osdep\_pow\_off\_imp  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1003, AD\_PD\_CAS2062, AD\_PD\_CAS2063, AD\_PD\_CAS2064, AD\_PD\_CAS2549] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pow\_off\_imp(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_pm\_set\_policy

Table 2‑185: impdrv\_osdep\_pm\_set\_policy

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0009  impdrv\_osdep\_pm\_set\_policy  [Covers: AD\_PD\_CAS2439, AD\_PD\_CAS2442, AD\_PD\_CAS2443, AD\_PD\_CAS2444, AD\_PD\_CAS2445, AD\_PD\_CAS2447, AD\_PD\_CAS2448] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pm\_set\_policy(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const st\_impdrv\_core\_info\_t core\_info,  const e\_impdrv\_pm\_policy\_t pm\_policy  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | st\_impdrv\_device\_handle\_t  const \*p\_device\_handle | | OSAL device handle | |
| **Range** | Not NULL |
| const st\_impdrv\_core\_info\_t core\_info, | | Core information | |
| **Range** | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX |
| const e\_impdrv\_pm\_policy\_t pm\_policy | | Policy you want to set | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * For the process of Open the Hardware resource of core, the function to call is changed from impdrv\_osdep\_dev\_open. (To impdrv\_osdep\_dev\_open\_dsp when the core is DSP, to impdrv\_osdep\_dev\_open\_imp otherwise) * Change the third argument of R\_OSAL\_PmSetPolicy from true to false * Remove power on/off processing before calling impdrv\_osdep\_dev\_close | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_pm\_get\_policy

Table 2‑186: impdrv\_osdep\_pm\_get\_policy

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0010  impdrv\_osdep\_pm\_get\_policy  [Covers: AD\_PD\_CAS1016, AD\_PD\_CAS2471, AD\_PD\_CAS2474, AD\_PD\_CAS2475, AD\_PD\_CAS2476, AD\_PD\_CAS2477] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pm\_get\_policy(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle ,  const st\_impdrv\_core\_info\_t core\_info,  e\_impdrv\_pm\_policy\_t \*const p\_pm\_policy  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | Not NULL | |
| const st\_impdrv\_core\_info\_t core\_info, | | Core information | | |
| **Range** | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | e\_impdrv\_pm\_policy\_t \*const pm\_policy | | Current PM Policy | | |
| **Range** | | Not NULL. |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * For the process of Open the Hardware resource of core, the function to call is changed from impdrv\_osdep\_dev\_open. (To impdrv\_osdep\_dev\_open\_dsp when the core is DSP, to impdrv\_osdep\_dev\_open\_imp otherwise) | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_pm\_get\_state

Table 2‑187: impdrv\_osdep\_pm\_get\_state

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0044  impdrv\_osdep\_pm\_get\_state  [Covers: AD\_PD\_CAS2552, AD\_PD\_CAS2553, AD\_PD\_CAS2554, AD\_PD\_CAS2555, AD\_PD\_CAS2556] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pm\_get\_state(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle ,  const st\_impdrv\_core\_info\_t core\_info,  e\_impdrv\_pm\_state\_t \*const p\_pmstate  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t core\_info, | | Core information | | |
| **Range** | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX | |
| **Parameters (In-out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | Not NULL | |
| **Parameters (Out)** | e\_impdrv\_pm\_state\_t \*const p\_pmstate | | Current PM State | | |
| **Range** | | Not NULL. |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_write\_reg

Table 2‑188: impdrv\_osdep\_write\_reg

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0011  impdrv\_osdep\_write\_reg  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1002, AD\_PD\_CAS1003, AD\_PD\_CAS2055, AD\_PD\_CAS2056, AD\_PD\_CAS1005, AD\_PD\_CAS1010, AD\_PD\_CAS1011, AD\_PD\_CAS2326, AD\_PD\_CAS1014] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_write\_reg(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const uint32\_t offset,  const uint32\_t val,  const bool read\_back,  const uint32\_t chk\_val  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | | |
| **Range** | Not NULL | |
| const uint32\_t offset | | Offset to set to register  The lifetime of this parameter is until this function returns. | | |
| **Range** | | Less than IMPDRV\_REG\_OFFSET\_MAX and 4 byte alignment. |
| Const uint32\_t val | | Value to set to register  The lifetime of this parameter is until this function returns. | | |
| **Range** | | None. |
| Const bool read\_back | | Whether to read back. | | |
| **Range** | | true or false. |
| Const uint32\_t chk\_val | | Value to read back register. | | |
| **Range** | | None. |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_read\_reg

Table 2‑189: impdrv\_osdep\_read\_reg

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0012  impdrv\_osdep\_read\_reg  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1002, AD\_PD\_CAS1003, AD\_PD\_CAS2057, AD\_PD\_CAS2058, AD\_PD\_CAS1010, AD\_PD\_CAS1011] | | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_read\_reg(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle ,  const uint32\_t offset,  uint32\_t \*p\_val  ); | | | | | |
| **Sync/Async** | Synchronous | | | | | |
| **Reentrancy** | Non-Reentrant | | | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | | | |
| **Range** | | Not NULL | |
| const uint32\_t offset | | Offset to get to register | | | |
| **Range** | | | Less　than IMPDRV\_REG\_OFFSET\_MAX and 4 byte alignment. |
| **Parameters (In-out)** | N/A | | N/A | | | |
| **Parameters (Out)** | uint32\_t \*p\_val | | Storing values from registers  The lifetime of this parameter is until this function returns. | | | |
| **Range** | Not NULL | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | | |
| **Preconditions** | N/A | | | | | |
| **Remarks** | p\_val is pointer of output parameter, so the use of this pointer variable is acceptable | | | | | |

#### impdrv\_osdep\_mutex\_create

Table 2‑190: impdrv\_osdep\_mutex\_create

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0013  impdrv\_osdep\_mutex\_create  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1001, AD\_PD\_CAS2042, AD\_PD\_CAS2043] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_mutex\_create(  st\_impdrv\_mutex\_handle\_t \*const p\_mutex\_handle,  const osal\_mutex\_id\_t mutex\_id  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const osal\_mutex\_id\_t  mutex\_id | | To set value of mutex id.  The lifetime of this parameter is until impdrv\_osdep\_pow\_on\_imp\_top returns.  This ID is user-defined, so the range is not stated. | |
| **Range** | None. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_mutex\_handle\_t \*const p\_mutex\_handle | | OSAL mutex handle | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_mutex\_destroy

Table 2‑191: impdrv\_osdep\_mutex\_destroy

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0014  impdrv\_osdep\_mutex\_destroy  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS2113, AD\_PD\_CAS2114] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_mutex\_destroy(  st\_impdrv\_mutex\_handle\_t \*const p\_mutex\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_mutex\_handle\_t \*const p\_mutex\_handle | | OSAL mutex handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_mutex\_lock

Table 2‑192: impdrv\_osdep\_mutex\_lock

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0015  impdrv\_osdep\_mutex\_lock  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1007, AD\_PD\_CAS2044, AD\_PD\_CAS2045, AD\_PD\_CAS1014, AD\_PD\_CAS1015, AD\_PD\_CAS1016] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_mutex\_lock(  const st\_impdrv\_mutex\_handle\_t \*const p\_mutex\_handle ,  const osal\_milli\_sec\_t time\_period  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_mutex\_handle\_t \*const p\_mutex\_handle | | OSAL mutex handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | | |
| **Range** | Not NULL | |
| const osal\_milli\_sec\_t  time\_period | | Mutex timeout value by [msec] order  The lifetime of this parameter is until this function returns. | | |
| **Range** | | 0 or more |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_mutex\_unlock

Table 2‑193: impdrv\_osdep\_mutex\_unlock

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0016  impdrv\_osdep\_mutex\_unlock  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS1007, AD\_PD\_CAS2065, AD\_PD\_CAS2066, AD\_PD\_CAS1014, AD\_PD\_CAS1015, AD\_PD\_CAS1016] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_mutex\_unlock(  const st\_impdrv\_mutex\_handle\_t \*const p\_mutex\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_mutex\_handle\_t \*const p\_mutex\_handle | | OSAL mutex handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_reset\_core

Table 2‑194: impdrv\_osdep\_reset\_core

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0025  impdrv\_osdep\_reset\_core  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS2252, AD\_PD\_CAS2332, AD\_PD\_CAS2536] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_reset\_core (  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | This function is used in V3M/V3H/V3H\_2 | | | |

#### impdrv\_osdep\_pow\_on\_hwrsc

Table 2‑195: impdrv\_osdep\_pow\_on\_hwrsc

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0026  impdrv\_osdep\_pow\_on\_hwrsc  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS2129, AD\_PD\_CAS2333, AD\_PD\_CAS2334, AD\_PD\_CAS2335, AD\_PD\_CAS2550] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pow\_on\_hwrsc(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const char \*const p\_device\_id  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const char \*const p\_device\_id | | Pointer to the Target OSAL device ID. | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Parameters (Out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_pow\_off\_hwrsc

Table 2‑196: impdrv\_osdep\_pow\_off\_hwrsc

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0027  impdrv\_osdep\_pow\_off\_hwrsc  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS2148, AD\_PD\_CAS2330, AD\_PD\_CAS2336, AD\_PD\_CAS2337, AD\_PD\_CAS2551] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pow\_off\_hwrsc(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Range** |  |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_SYSTEMERROR  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_memory\_barrier

Table 2‑197: impdrv\_osdep\_memory\_barrier

|  |  |  |  |
| --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0028  impdrv\_osdep\_memory\_barrier  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS2329] | | |
| **ASIL Level** | ASIL D | **Status** | New |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_memory\_barrier(  void  ); | | |
| **Sync/Async** | Synchronous | | |
| **Reentrancy** | Non-Reentrant | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | |
| **Parameters (In)** | N/A | | N/A |
| **Parameters (In-out)** | N/A | | N/A |
| **Parameters (Out)** | N/A | | N/A |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SYSTEMERROR |
| **Description** | Refer to “3 Activity Diagrams”. | | |
| **Preconditions** | N/A | | |
| **Remarks** | N/A | | |

#### impdrv\_osdep\_queue\_create

Table 2‑198: impdrv\_osdep\_queue\_create

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0029  impdrv\_osdep\_queue\_create  [Covers: AD\_PD\_CAS2493, AD\_PD\_CAS2502, AD\_PD\_CAS2503] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_queue\_create(  st\_impdrv\_queue\_handle\_t \*const p\_queue\_handle,  const osal\_mq\_id\_t queue\_id  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const osal\_mq\_id\_t queue\_id | | OSAL message queue ID | | |
| **Range** | More than 0 | |
| **Parameters (In-out)** | st\_impdrv\_queue\_handle\_t \*const p\_queue\_handle | | OSAL message queue handle | | |
| **Range** | | Not Null |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_queue\_destroy

Table 2‑199: impdrv\_osdep\_queue\_destroy

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0030  impdrv\_osdep\_queue\_destroy  [Covers: AD\_PD\_CAS2496, AD\_PD\_CAS2504, AD\_PD\_CAS2505, AD\_PD\_CAS2506] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_register\_irq(  st\_impdrv\_queue\_handle\_t \*const p\_queue\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | st\_impdrv\_queue\_handle\_t \*const p\_queue\_handle | | OSAL message queue handle | |
| **Range** | Not Null |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_queue\_wait\_period

Table 2‑200: impdrv\_osdep\_queue\_wait\_period

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0031  impdrv\_osdep\_queue\_wait\_period  [Covers: AD\_PD\_CAS2495, AD\_PD\_CAS2507, AD\_PD\_CAS2508] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_queue\_wait\_period (  const st\_impdrv\_queue\_handle\_t \*const p\_queue\_handle,  const osal\_milli\_sec\_t time\_period,  uint32\_t \*const p\_receive\_buffer  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_queue\_handle\_t \*const p\_queue\_handle | | OSAL message queue handle | | |
| **Range** | Not Null | |
| const osal\_milli\_sec\_t time\_period | | Timeout period of millisecond order | | |
| **Range** | 0 or more than | |
| **Parameters (In-out)** | uint32\_t \*const p\_receive\_buffer | | Message receive buffer pointer | | |
| **Range** | | Not Null |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_CHECKFAIL  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_queue\_send\_period

Table 2‑201: impdrv\_osdep\_queue\_send\_period

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0032  impdrv\_osdep\_queue\_send\_period  [Covers: AD\_PD\_CAS2509, AD\_PD\_CAS2510] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_queue\_send\_period (  const st\_impdrv\_queue\_handle\_t \*const p\_queue\_handle,  const osal\_milli\_sec\_t time\_period,  const uint32\_t \*const p\_send\_buffer  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_queue\_handle\_t \*const p\_queue\_handle | | OSAL message queue handle | |
| **Range** | Not Null |
| const osal\_milli\_sec\_t time\_period | | Timeout period of millisecond order | |
| **Range** | 0 or more |
| const uint32\_t \*const p\_send\_buffer | | Message send buffer pointer | |
| **Range** | Not Null |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_dev\_open\_imp

Table 2‑202: impdrv\_osdep\_dev\_open\_imp

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0046  impdrv\_osdep\_dev\_open\_imp  [Covers: AD\_PD\_CAS2565, AD\_PD\_CAS2566, AD\_PD\_CAS2567] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_dev\_open\_imp (  st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const [st\_impdrv\_core\_info\_t](#_API_Layer_2) core\_info  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const [st\_impdrv\_core\_info\_t](#_API_Layer_2) core\_info | | Core information | | |
| **Range** | | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX |
| **Parameters (In-out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | Not Null | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_dev\_close

Table 2‑203: impdrv\_osdep\_dev\_close

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0018  impdrv\_osdep\_dev\_close  [Covers: AD\_PD\_CAS3005, AD\_PD\_CAS2446] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_dev\_close(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | N/A | | N/A | |
| **Parameters (In-out)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_memory\_get\_size

Table 2‑204: impdrv\_osdep\_memory\_get\_size

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0033  impdrv\_osdep\_memory\_get\_size  [Covers: AD\_PD\_CAS2489, AD\_PD\_CAS2511, AD\_PD\_CAS2512] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_memory\_get\_size (  const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle,  size\_t \*const p\_size  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle | | OSAL memory buffer handle | | |
| **Range** | Not Null | |
| **Parameters (In-out)** | size\_t \*const p\_size | | buffer size pointer | | |
| **Range** | | Not Null |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_memory\_get\_logical

Table 2‑205: impdrv\_osdep\_memory\_get\_logical

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0034  impdrv\_osdep\_memory\_get\_logical  [Covers: AD\_PD\_CAS2490, AD\_PD\_CAS2515, AD\_PD\_CAS2514] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_memory\_get\_logical (  const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle,  void \*\*const p\_logical\_adrs  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle | | OSAL memory buffer handle | | |
| **Range** | Not Null | |
| **Parameters (In-out)** | void \*\*const p\_logical\_adrs | | logical address pointer | | |
| **Range** | | Not Null |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_memory\_get\_physical

Table 2‑206: impdrv\_osdep\_memory\_get\_physical

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0035  impdrv\_osdep\_memory\_get\_physical  [Covers: AD\_PD\_CAS2491, AD\_PD\_CAS2516, AD\_PD\_CAS2517] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_memory\_get\_physical (  const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle,  const osal\_axi\_bus\_id\_t axi\_id,  uintptr\_t \*const p\_physical\_adrs  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle | | OSAL memory buffer handle | | |
| **Range** | Not Null | |
| const osal\_axi\_bus\_id\_t axi\_id | | OSAL AXI bus ID | | |
| **Range** | Not OSAL\_AXI\_BUS\_ID\_INVALID | |
| **Parameters (In-out)** | uintptr\_t \*const p\_physical\_adrs | | physical address pointer | | |
| **Range** | | Not Null |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_memory\_cache\_flush

Table 2‑207: impdrv\_osdep\_memory\_cache\_flush

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0036  impdrv\_osdep\_memory\_cache\_flush  [Covers: AD\_PD\_CAS2492, AD\_PD\_CAS2531, AD\_PD\_CAS2532] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_memory\_cache\_flush (  const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle,  const uintptr\_t offset,  const size\_t size  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle | | OSAL memory buffer handle | |
| **Range** | Not Null |
| const uintptr\_t offset | | Offset address | |
| **Range** | Not IMPDRV\_CHK\_CACHE\_ALIGN |
| const size\_t size | | Cache flush size | |
| **Range** | N/A |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_memory\_cache\_clean

Table 2‑208: impdrv\_osdep\_memory\_cache\_clean

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0037  impdrv\_osdep\_memory\_cache\_clean  [Covers: AD\_PD\_CAS2497, AD\_PD\_CAS2518, AD\_PD\_CAS2519] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_memory\_cache\_clean (  const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle,  const uintptr\_t offset,  const size\_t size  ); ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_memory\_handle\_t \*const p\_memory\_handle | | OSAL memory buffer handle | |
| **Range** | Not Null |
| const uintptr\_t offset | | Offset address | |
| **Range** | Not IMPDRV\_CHK\_CACHE\_ALIGN |
| const size\_t size | | Cache clean size | |
| **Range** | N/A |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_memory\_data\_set

Table 2‑209: impdrv\_osdep\_memory\_data\_set

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0038  impdrv\_osdep\_memory\_data\_set  [Covers: AD\_PD\_CAS2528, AD\_PD\_CAS2529, AD\_PD\_CAS2530] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_memory\_data\_set (  uint32\_t \*const p\_buffer,  const uint32\_t data,  const size\_t size  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const uint32\_t data, | | Data to write | | |
| **Range** | N/A | |
| const size\_t size | | Data size | | |
| **Range** | Not IMPDRV\_CHK\_MEM\_ALIGN | |
| **Parameters (In-out)** | uint32\_t \*const p\_buffer | | Memory buffer address | | |
| **Range** | | Not Null |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_memory\_compare

Table 2‑210: impdrv\_osdep\_memory\_compare

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0039  impdrv\_osdep\_memory\_compare  [Covers: AD\_PD\_CAS2498, AD\_PD\_CAS2520, AD\_PD\_CAS2521] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_memory\_compare (  const uint32\_t \*const p\_expected\_area,  const uint32\_t \*const p\_result\_area,  const size\_t size  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const uint32\_t \* const p\_expected\_area | | Data area for test expectations | |
| **Range** | Not Null |
| const uint32\_t \* const p\_result\_area, | | Data area for test result | |
| **Range** | Not Null |
| const size\_t size | | Data size | |
| **Range** | Not IMPDRV\_CHK\_MEM\_ALIGN |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_CHECKFAIL | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_dev\_open\_dsp

Table 2‑211: impdrv\_osdep\_dev\_open\_dsp

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0045  impdrv\_osdep\_dev\_open\_dsp  [Covers: AD\_PD\_CAS2462, AD\_PD\_CAS2463, AD\_PD\_CAS2464] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_dev\_open\_dsp (  st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const [st\_impdrv\_core\_info\_t](#_API_Layer_2) core\_info,  const uint32\_t sub\_dev\_num  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | | |
| **Parameters (In)** | const [st\_impdrv\_core\_info\_t](#_API_Layer_2) core\_info | | Core information | | |
| **Range** | | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX |
| const uint32\_t sub\_dev\_num | | Sub device number | | |
| **Range** | | Less than num of sub device |
| **Parameters (In-out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | Not Null | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_pow\_on\_imp\_dsp

Table 2‑212: impdrv\_osdep\_pow\_on\_imp\_dsp

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0051  impdrv\_osdep\_pow\_on\_imp\_dsp  [Covers: AD\_PD\_CAS2479, AD\_PD\_CAS2488, AD\_PD\_CAS2543, AD\_PD\_CAS2568, AD\_PD\_CAS2569, AD\_PD\_CAS2570, AD\_PD\_CAS2571] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_pow\_on\_imp\_dsp (  st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const [st\_impdrv\_core\_info\_t](#_API_Layer_2) core\_info,  const uint32\_t sub\_dev\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const [st\_impdrv\_core\_info\_t](#_API_Layer_2) core\_info | | Core information  The lifetime of this parameter is until impdrv\_osdep\_pow\_on\_imp\_top returns. | |
| **Range** | Not Null |
| const uint32\_t sub\_dev\_num | | Sub device number | |
| **Range** | Less than num of sub device |
| **Parameters (In-out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * Change from Private function impdrv\_osdep\_dev\_open\_dsp\_sub (old name : impdrv\_osdep\_dev\_open\_dsp) to Public function impdrv\_osdep\_dev\_open\_dsp | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_register\_dsp\_irq

Table 2‑226: impdrv\_osdep\_register\_dsp\_irq

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0040  impdrv\_osdep\_register\_dsp\_irq  [Covers: AD\_PD\_CAS2458, AD\_PD\_CAS2459] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_register\_dsp\_irq(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  unit32\_t const core\_num ,  const e\_osal\_interrupt\_priority\_t irq\_priority,  const impdrv\_ctrl\_handle\_t osal\_cb\_args  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | Unit32\_t  const core\_num | | DSP core number | | |
| **Range** | Less than num of DSP device | |
| const e\_osal\_interrupt\_priority\_t irq\_priority | | Interrupt priority. | | |
| **Range** | | Within the range of ENUM type. |
| Const impdrv\_ctrl\_handle\_t osal\_cb\_args | | OSAL callback argument | | |
| **Range** | | Not NULL |
| **Parameters (In-out)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | | Not NULL |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_enable\_dsp\_irq

Not use. (Out of scope)

#### impdrv\_osdep\_disable\_dsp\_irq

Table 2‑226: impdrv\_osdep\_disable\_dsp\_irq

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0056  impdrv\_osdep\_disable\_dsp\_irq  [Covers: AD\_PD\_CAS2460, AD\_PD\_CAS2461] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_disable\_dsp\_irq(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | Not NULL | |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Range** | | N/A |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IIMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_unregister\_dsp\_irq

Table 2‑228: impdrv\_osdep\_unregister\_dsp\_irq

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0055  impdrv\_osdep\_unregister\_dsp\_irq  [Covers: AD\_PD\_CAS2572, AD\_PD\_CAS2573] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_unregister\_dsp\_irq(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const unit32\_t core\_num  ); | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | | |
| **Range** | Not NULL | |
| const unit32\_t core\_num | | DSP core number | | |
| **Range** | | Less than num of DSP device |
| **Parameters (In-out)** | N/A | | N/A | | |
| **Range** | | N/A |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM  IMPDRV\_EC\_NG\_SYSTEMERROR | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A. | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_pow\_on\_dsp

Not use. (Out of scope)

#### impdrv\_osdep\_pow\_off\_dsp

Not use. (Out of scope)

#### impdrv\_osdep\_dsp\_close

Not use. (Out of scope)

#### impdrv\_osdep\_reset\_core\_dsp

Table 2‑228: impdrv\_osdep\_reset\_core\_dsp

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0054  impdrv\_osdep\_reset\_core\_dsp  [Covers: AD\_PD\_CAS2574, AD\_PD\_CAS2575, AD\_PD\_CAS2576, AD\_PD\_CAS2577] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | e\_impdrv\_errorcode\_t impdrv\_osdep\_reset\_core\_dsp (  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle,  const bool reset  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Range** | Not NULL |
| const bool reset | | Rest State | |
| **Range** | true or false |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

### Private function

#### impdrv\_osdep\_dev\_open

Table 2‑213: impdrv\_osdep\_dev\_open

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0017  impdrv\_osdep\_dev\_open  [Covers: AD\_PD\_CAS3005] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_osdep\_dev\_open(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle ,  const char \*const type,  const size\_t dev\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const char \*const type | | Specific device type  The lifetime of this parameter is until this function returns. | |
| **Range** | Not NULL |
| const size\_t dev\_num | | Specific device number  The lifetime of this parameter is until this function returns. | |
| **Range** | None. |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_pow\_on

Table 2‑214: impdrv\_osdep\_pow\_on

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0019  impdrv\_osdep\_pow\_on  [Covers: AD\_PD\_CAS3005] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_osdep\_pow\_on(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \* const p\_device\_handle | | OSAL device handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * Add call R\_OSAL\_PmGetRequiredState before call R\_OSAL\_PmSetRequiredState * Add a condition for call R\_OSAL\_PmSetRequiredState: State obtained in R\_OSAL\_PmGetRequiredState is not REQUIRED | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_pow\_off

Table 2‑215: impdrv\_osdep\_pow\_off

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0020  impdrv\_osdep\_pow\_off  [Covers: AD\_PD\_CAS3005] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_osdep\_pow\_off(  const st\_impdrv\_device\_handle\_t \*const p\_device\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_device\_handle\_t \* const p\_device\_handle | | OSAL device handle  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”.  [Update Information]   * Add call R\_OSAL\_PmGetRequiredState before call R\_OSAL\_PmSetRequiredState * Add a condition for call R\_OSAL\_PmSetRequiredState: State obtained in R\_OSAL\_PmGetRequiredState is not RELEASE | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_int\_handler

Table 2‑216: impdrv\_osdep\_int\_handler

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0021  impdrv\_osdep\_int\_handler  [Covers: AD\_PD\_CAS1011, AD\_PD\_CAS2331, AD\_PD\_CAS3005] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  void impdrv\_osdep\_int\_handler(  osal\_device\_handle\_t device\_handle ,  const uint64\_t irq\_channel,  void\* irq\_arg  ) | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | osal\_device\_handle\_t device\_handle | | Device handle associated with OSAL interrupt manager.  The lifetime of this parameter is the period from the impdrv\_osdep\_pow\_on\_imp\_top is executed until impdrv\_osdep\_pow\_off\_imp\_top is executed. | |
| **Range** | Not NULL |
| const uint64\_t irq\_channel, | | IRQ channel associated with OSAL interrupt manager.  The lifetime of this parameter is until this function returns. | |
| **Range** | None. |
| Void\* irq\_arg | | User argument (control handle) specified when registered interrupt.  The lifetime of this parameter is until this function returns. | |
| **Range** | Not NULL |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | N/A | | N/A | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_chk\_core\_info

Table 2‑217: impdrv\_osdep\_chk\_core\_info

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0022  impdrv\_osdep\_chk\_core\_info  [Covers: AD\_PD\_CAS3005] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_osdep\_chk\_core\_info(  const st\_impdrv\_core\_info\_t core\_info  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t core\_info | | Core information | |
| **Range** | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_chk\_instance\_num

Table 2‑218: impdrv\_osdep\_chk\_instance\_num

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0024  impdrv\_osdep\_chk\_instance\_num  [Covers: AD\_PD\_CAS3005] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_osdep\_chk\_instance\_num(  const e\_impdrv\_instance\_t instance\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | N/A | | | |

#### impdrv\_osdep\_get\_irq\_channel

Table 2‑219: impdrv\_osdep\_get\_irq\_channel

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0023  impdrv\_osdep\_get\_irq\_channel  [Covers: AD\_PD\_CAS2053, AD\_PD\_CAS2084, AD\_PD\_CAS2086] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_osdep\_get\_irq\_channel(  const e\_impdrv\_instance\_t instance\_num,  uint64\_t \*const irq\_channel  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (In)** | const e\_impdrv\_instance\_t instance\_num | | Instance number | |
| **Range** | Within the range of ENUM type. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | uint64\_t \*const irq\_channel | | Interrupt channel  The validity period of this parameter is the period from when this function is called to when it ends. | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PARAM | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | irq\_channel is pointer of output parameter, so the use of this pointer variable is acceptable | | | |

#### impdrv\_osdep\_dev\_open\_dsp\_sub

Table 2‑220: impdrv\_osdep\_dev\_open\_dsp\_sub

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0052  impdrv\_osdep\_dev\_open\_dsp\_sub  [Covers: AD\_PD\_CAS2463] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_osdep\_dev\_open\_dsp\_sub(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle ,  const char \*const type,  const size\_t dev\_num,  const uint32\_t sub\_dev\_num  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can not be called from OSAL Callback. | | | |
| **Parameters (in)** | const char \*const type | | Device type | |
| **Range** | Not NULL |
| const size\_t dev\_num | | Device number | |
| **Range** | Within the range of ENUM type.  Value less than IMPDRV\_CORE\_NUM\_MAX |
| const uint32\_t sub\_dev\_num | | Sub device number | |
| **Range** | Less than num of sub device |
| **Parameters (In-Out)** | st\_impdrv\_device\_handle\_t \*const p\_device\_handle | | OSAL device handle | |
| **Range** | Not NULL |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_SYSTEMERROR | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”.  [Update Information]   * Change Function Name from impdrv\_osdep\_dev\_open\_dsp | | | |
| **Preconditions** | None. | | | |
| **Remarks** | None. | | | |

#### impdrv\_osdep\_get\_dsp\_irq\_channel

Table 2‑235: impdrv\_osdep\_get\_dsp\_irq\_channel

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0053  impdrv\_osdep\_get\_dsp\_irq\_channel  [Covers: AD\_PD\_CAS2449, AD\_PD\_CAS2450, AD\_PD\_CAS2458, AD\_PD\_CAS2459, AD\_PD\_CAS2572, AD\_PD\_CAS2573, AD\_PD\_CAS2460, AD\_PD\_CAS2461] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_osdep\_get\_dsp\_irq\_channel(  unit64\_t \*const irq\_channel  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (in)** | N/A | | N/A | |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | unit64\_t \*const irq\_channel | | Interrupt channel | |
| **Range** | Not NULL |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_ARGNULL | |
| **Description** | Details of internal processing, refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | None. | | | |
| **Remarks** | None. | | | |

#### impdrv\_osdep\_dsp0\_int\_handler

Table 2‑233: impdrv\_osdep\_dsp0\_int\_handler

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0050  impdrv\_osdep\_dsp0\_int\_handler  [Covers: AD\_PD\_CAS2578] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | IMPDRV\_STATIC  void impdrv\_osdep\_dsp0\_int\_handler (  osal\_device\_handle\_t device\_handle ,  const uint64\_t irq\_channel,  void\* irq\_arg  ) | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | osal\_device\_handle\_t device\_handle | | Device handle associated with OSAL interrupt manager. | | |
| **Range** | | Not NULL |
| const uint64\_t irq\_channel, | | IRQ channel associated with OSAL interrupt manager. | | |
| **Range** | | None. |
| **Parameters (In-Out)** | Void\* irq\_arg | | User argument (control handle) specified when registered interrupt. | | |
| **Range** | Not NULL | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | N/A | | N/A | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_dsp1\_int\_handler

Table 2‑234: impdrv\_osdep\_dsp1\_int\_handler

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0049  impdrv\_osdep\_dsp1\_int\_handler  [Covers: AD\_PD\_CAS2578] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | IMPDRV\_STATIC  void impdrv\_osdep\_dsp1\_int\_handler (  osal\_device\_handle\_t device\_handle ,  const uint64\_t irq\_channel,  void\* irq\_arg  ) | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | osal\_device\_handle\_t device\_handle | | Device handle associated with OSAL interrupt manager. | | |
| **Range** | | Not NULL |
| const uint64\_t irq\_channel, | | IRQ channel associated with OSAL interrupt manager.. | | |
| **Range** | | None. |
| **Parameters (In-Out)** | Void\* irq\_arg | | User argument (control handle) specified when registered interrupt. | | |
| **Range** | Not NULL | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | N/A | | N/A | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_dsp2\_int\_handler

Table 2‑235: impdrv\_osdep\_dsp2\_int\_handler

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0048  impdrv\_osdep\_dsp2\_int\_handler  [Covers: AD\_PD\_CAS2578] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | IMPDRV\_STATIC  void impdrv\_osdep\_dsp2\_int\_handler (  osal\_device\_handle\_t device\_handle ,  const uint64\_t irq\_channel,  void\* irq\_arg  ) | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | osal\_device\_handle\_t device\_handle | | Device handle associated with OSAL interrupt manager. | | |
| **Range** | | Not NULL |
| const uint64\_t irq\_channel, | | IRQ channel associated with OSAL interrupt manager. | | |
| **Range** | | None. |
| **Parameters (In-Out)** | Void\* irq\_arg | | User argument (control handle) specified when registered interrupt. | | |
| **Range** | Not NULL | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | N/A | | N/A | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_dsp3\_int\_handler

Table 2‑236: impdrv\_osdep\_dsp3\_int\_handler

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0041  impdrv\_osdep\_dsp3\_int\_handler  [Covers: AD\_PD\_CAS2578] | | | | |
| **ASIL Level** | ASIL D | **Status** | New | | |
| **Syntax** | IMPDRV\_STATIC  void impdrv\_osdep\_dsp3\_int\_handler (  osal\_device\_handle\_t device\_handle ,  const uint64\_t irq\_channel,  void\* irq\_arg  ) | | | | |
| **Sync/Async** | Synchronous | | | | |
| **Reentrancy** | Non-Reentrant | | | | |
| **Interrupt State** |  | | | | |
| **Parameters (In)** | osal\_device\_handle\_t device\_handle | | Device handle associated with OSAL interrupt manager. | | |
| **Range** | | Not NULL |
| const uint64\_t irq\_channel, | | IRQ channel associated with OSAL interrupt manager. | | |
| **Range** | | None. |
| **Parameters (In-Out)** | Void\* irq\_arg | | User argument (control handle) specified when registered interrupt. | | |
| **Range** | Not NULL | |
| **Parameters (Out)** | N/A | | N/A | | |
| **Return Value** | N/A | | N/A | | |
| **Description** | Refer to “3 Activity Diagrams”. | | | | |
| **Preconditions** | N/A | | | | |
| **Remarks** | N/A | | | | |

#### impdrv\_osdep\_wait\_for\_req\_state

Table 2‑243: impdrv\_osdep\_wait\_for\_req\_state

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | UD\_PD\_UD02\_05\_0047  impdrv\_osdep\_wait\_for\_req\_state  [Covers: AD\_PD\_CAS2108, AD\_PD\_CAS2258, AD\_PD\_CAS2334, AD\_PD\_CAS2441, AD\_PD\_CAS2444, AD\_PD\_CAS2568, AD\_PD\_CAS2569, AD\_PD\_CAS2570] | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | IMPDRV\_STATIC  e\_impdrv\_errorcode\_t impdrv\_osdep\_wait\_for\_req\_state(  st\_impdrv\_device\_handle\_t \*const p\_device\_handle  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Reentrant | | | |
| **Interrupt State** |  | | | |
| **Parameters (In)** | st\_impdrv\_device\_handle\_t  \*const p\_device\_handle | | OSAL device handle | |
| **Range** | Not NULL |
| **Parameters (In-out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | e\_impdrv\_errorcode\_t | | IMPDRV\_EC\_OK  IMPDRV\_EC\_NG\_SEQSTATE  IMPDRV\_EC\_NG\_ARGNULL  IMPDRV\_EC\_NG\_PMSYSTEMERROR | |
| **Description** | Refer to “3 Activity Diagrams”. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

# Activity Diagrams

The activity diagrams are described in this eapx file.

![](data:image/x-emf;base64,AQAAAGwAAAAAAAAAAQAAAGUAAAA/AAAAAAAAAAAAAAByBgAAbAQAACBFTUYAAAEAlBYAABUAAAACAAAAAAAAAAAAAAAAAAAAgAcAADgEAAA1AQAArgAAAAAAAAAAAAAAAAAAAAi3BACwpwIAGAAAAAwAAAAAAAAAGQAAAAwAAAD///8AcgAAAKAQAAAjAAAAAQAAAEIAAAAgAAAAIwAAAAEAAAAgAAAAIAAAAACA/wEAAAAAAAAAAAAAgD8AAAAAAAAAAAAAgD8AAAAAAAAAAP///wAAAAAAbAAAADQAAACgAAAAABAAACAAAAAgAAAAKAAAACAAAAAgAAAAAQAgAAMAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAA/wAA/wAA/wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP+trf//hIX//4SF//+Ehf//hIX//4SF//+Ehf//hIX//4SF//+Ehf//hIX//4SF//+Ehf//hIX//4SF//+Ehf//hIX//4SF//+Ehf//hIX//4SF//+Ehf//hIX/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/62t///19f/88vL/9enp/+7h4f/p3Nz/6dra/+na2v/w3t7/+OTk//7o6P//5ub//+bm///k5P//4uL//+Li///g4P//4OD//97e///c3P//2tr//9ra//+Ehf8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD/ra3/8Onp/+TT0//WxcX/y7e3/8OsrP/Bqan/xKmp/86vr//cuLj/68TE//jMzP/+zMz//srK///IyP//xsb//8LC///AwP//vr7//7m5//+5uf//3Nz//4SF/wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP+trf/Subn/1nFx/+E8PP/uHh7/8xER/+wbG//ZOjr/wGxs/7ednf/Iqan/3Li4//LGxv/9zs7//szM///IyP//xsb//8LC///AwP//vr7//7m5///c3P//hIX/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/01N//AbG//5BQX//gAA//8AAP//AAD//wAA//4AAP/2CQn/3yws/7lzc/+7n5//2LW1//HIyP/+zs7//szM//7Kyv//xsb//8TE///Cwv//vr7//97e//+Ehf8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP8PD///AAD//xMT//9JSv//eHn//5eY//+hof//kpL//2lq//8qKv//AAD/+QUF/8FfX/+7n5//3Li4//HIyP/2ycn/+cjI//7Kyv//xsb//8TE///Cwv//4OD//4SF/wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/wAA//9yc//+6Oj//v7+//7+/v/+/v7///v8//7+/v/+/v7///z8//+bm///CQn/+QUF/7Z3d/+9oaH/zq+v/9Sxsf/jurr/8sbG//7Kyv//yMj//8bG///i4v//hIX/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD/AgL//7S1//7+/v/+/v7//rGx//9BQv//Gxv//yMk//9gYf//4OD//v7+//+nqP/+AAD/4icn/8FfX//NVlb/xW1t/8Wlpf/jurr//s7O//7MzP//yMj//+Tk//+Ehf8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/y4u//4AAP//lZX//v7+//+DhP//AAD//wAA//8AAP//AAD//wAA//8qKv//7Oz//v7+//9ERv/+AAD//wkJ//8AAP/2CQn/tYiI/9Sxsf//0tP//s7O//7MzP//5ub//4SF/wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP4AAP//ExP//4SF///k5P//5+j//0FC//8PD///AAD//wAA//8AAP//AAD//wAA//+mpv/+/v7//+rq///Q0P//4OD//3V2//8AAP/LUFD/xaWl///W1v//0tP//9DQ///m5v//hIX/AAAAAAAAAAAAAAAAAAAAAAAAAADsAAD/7h4e//TMzf/5////+f////z+///+/v7//+Pk//9aXP//AAD//wAA//8AAP//AAD//66v///y8v//tLX//v7+//7+/v//4OD//wkJ/+kdHv++pKT//9ra///W1v//1NT//ujo//+Ehf8AAAAAAAAAAAAAAAAAAAAAAAAAANYBAv/cpKX/4fDw/+S0tP/oTE3/6zo7/++MjP/z+Pn/9/r7//pGR//8AAD//gAA//9GR//++fn//9LT//8AAP//dXb//v7+//7+/v//Njb/+QUF/7qlpf//3Nz//9ra///W1v//6ur//4SF/wAAAAAAAAAAAAAAAAAAAADFCQn/wiss/8bOzv/KpaX/zgkK/9IAAP/WAAD/2gAA/99oav/h8PD/58XG/+kdHv/wbW7/9O7v//b////6Z2j//AAA//4AAP//tLX//v7+//9fX//+AAD/uqWl///g4P//3Nz//9ra///s7P//hIX/AAAAAAAAAAAAAAAAAAAAALEAAP+4UlP/wMzM/8RERf/FAAD/yQAA/8kAAP/JAAD/yQAA/82Wl//Q2Nj/1sXF/9rn5//f4OD/5HN0/+gAAP/sAAD/8QAA//RQUf/5////+3Jy//wAAP+6qan//+Tk///g4P//3t7//+7u//+Ehf8AAAAAAAAAAAAAAAAAAAAA9AAA//uLjP/8/Pz//TU1//wAAP/8AAD/+QAA//QAAP/xQUL/68LD/+Pr6//c39//0qGi/8wrLP/NAAD/0gAA/9YAAP/aAAD/4DY3/+Ty8v/oZ2j/7AAA/7utrf/+6Oj//+Tk///g4P//8PD//4SF/wAAAAAAAAAAAAAAAAAAAAD+Bgb//5WV//7+/v//TU3//gAA//8AAP//AgL//5GS//7+/v/+/v7//+3u//7+/v/+sbH/9AAA/+MAAP/SAAD/xQAA/8UAAP/LU1T/0N/f/9RJSf/aAAD/vrGx///q6v/+6Oj//+Tk///w8P//hIX/AAAAAAAAAAAAAAAAAAAAAP8bG///iYn//v7+//+ztP//CQn//wIC//97fP/+/v7//+/w//9oaf//Hx///+Dg//7+/v//b2///wAA//8AAP/xAAD/1xIT/76kpP+4urr/vxwc/8UJCf/Ivb3//+7u///s7P/+6Oj///Ly//+Ehf8AAAAAAAAAAAAAAAAAAAAA/zIy//9vb//+/v7//v7+//+Ehf//Hx///+Li///z9P//Rkf//wAA//8AAP//UlL//v7+//7+/v//kZL//0FC//9cXP//0dL/9v///9CIif+tAAD/ui8v/9rS0v//8vL//+7u///s7P//9fX//4SF/wAAAAAAAAAAAAAAAAAAAAAAAAAA/1JS///y8v/+/v7//v7+///Gxv/++fn//66v//8WFv//Gxv//xYW//8JCf//aGn//+Tk//7+/v/+/v7//v7+//7+/v//w8T//xYW/+MAAP/QnZ3/7+np///19f//8vL///Dw///19f//hIX/AAAAAAAAAAAAAAAAAAAAAAAAAAD/UlL//rGx//7o6P//2tr///Ly//7+/v//rq///yoq//8uLv//Kir//yYm//8WFv//Jib//1ZX///u7v//3Nz//3Jz//8MDf/+AAD/6nl5/+/u7v/++fn//vn5///19f//9fX//vn5//+Ehf8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD/YmL//2Ji//9SUv//kpL//v7+///u7v//YmL//zg4//84OP//MjL//yoq//8qKv//o6X//v7+//+Mjf/+Bgb/7TMz/+CcnP/z8/P//Pz8//Pz8//k4+P/4d3d/+LZ2f/k09P//4SF/wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP9pav//09T//v7+///q6v//lZX//2Zm//9fX///eHn//szM//7+/v/+/v7//rGx//knJ/+/qan/3N/f//3v7//25ub/79vb/+nNzf/twMD/86io//+Vlf/+WVn/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/29v//+Agf/+zMz//v7+//7+/v/+/v7//v7+//7+/v/+/v7//v7+//7o6P//jI3//zg4/9Kvr//t39///4SF//+Ehf//hIX//4SF//+Ehf//hIX//llZ/wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD/kJD//4CB//+Ehf//m5v//7S1///ExP//yMj//8DA//+trf//jI3//2Zm//9SUv/5WFj/6c3N//jp6f//hIX//8LC//+ur///m5v//4mJ//5ZWf8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP+trf//3Nz//6am//+Skv//iYn//4SF//+Agf//dXb//3Jz//9vb///gIH//6ur///u7v/+/v7//+zs//+Ehf//rq///5ub//+Jif/+WVn/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)

# Resource Usage

Refer to section “General Description” and “Usage Notes” of R-Car V3x IMP Driver Product Information .

# Data Design

## Data Type Definitions

### Typedef

#### API Layer

##### impdrv\_ctrl\_handle\_t

Table 5‑1: impdrv\_ctrl\_handle\_t

|  |  |
| --- | --- |
| **Format** | struct st\_impdrv\_ctl\_t;  typedef struct st\_impdrv\_ctl\_t\* impdrv\_ctrl\_handle\_t; |
| **Description** | Control handle definition for IMP driver.  Declare it as a pointer to the Abstract control structure. |
| **Remarks** | N/A |

##### p\_impdrv\_cbfunc\_t

Table 5‑2: p\_impdrv\_cbfunc\_t

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | p\_impdrv\_cbfunc\_t | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | typedef int32\_t (\*p\_impdrv\_cbfunc\_t)(  const st\_impdrv\_core\_info\_t \*const p\_core\_info,  const e\_impdrv\_cb\_ret\_t ercd,  const int32\_t code,  void \*const p\_callback\_args  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*p\_core\_info | | Core information | |
| **Range** | Must not be NULL. |
| Const e\_impdrv\_cb\_ret\_t ercd | | Return code of callback | |
| **Range** | Within the range of ENUM type. |
| Const int32\_t code | | TRAP or INT code (8 bit is set) | |
| **Range** | None. (Use the value read from hardware register) |
| void  \*const p\_callback\_args | | User argument | |
| **Range** | None. (Depends on the user implementation) |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | int32\_t | | 0 or non-zero | |
| **Description** | For the usage, refer to the “5.3.1 p\_impdrv\_cbfunc\_t” in [3]. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

##### p\_impdrv\_cbfunc\_fatal\_t

Table 5‑3: p\_impdrv\_cbfunc\_fatal\_t

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | p\_impdrv\_cbfunc\_fatal\_t | | | |
| **ASIL Level** | ASIL D | **Status** | New | |
| **Syntax** | typedef void (\*p\_impdrv\_cbfunc\_fatal\_t)(  const st\_impdrv\_core\_info\_t \*const p\_core\_info  const \_impdrv\_fatalcode\_t fc\_code,  const e\_impdrv\_errorcode\_t ercd,  void \*const p\_callback\_args  ); | | | |
| **Sync/Async** | Synchronous | | | |
| **Reentrancy** | Non-Reentrant | | | |
| **Interrupt State** | Can be called from OSAL Callback. | | | |
| **Parameters (In)** | const st\_impdrv\_core\_info\_t \*const p\_core\_info | | Core information | |
| **Range** | Not NULL. |
| Const e\_impdrv\_fatalcode\_t fc\_code | | Fatal callback result code | |
| **Range** | IMPDRV fatal error code.  Within the range of ENUM type. |
| Const e\_impdrv\_errorcode\_t ercd | | IMPDRV Return code | |
| **Range** | IMP Driver error code.  Within the range of ENUM type. |
| Void  \*const p\_callback\_args | | Callback function arguments | |
| **Range** | None. |
| **Parameters (In-Out)** | N/A | | N/A | |
| **Parameters (Out)** | N/A | | N/A | |
| **Return Value** | N/A | | N/A | |
| **Description** | For the usage, refer to the “ 4.4.6 st\_impdrv\_fatalcode\_t” in [3]. | | | |
| **Preconditions** | N/A | | | |
| **Remarks** | N/A | | | |

### Structure

#### API Layer

##### st\_impdrv\_initdata\_t

Table 5‑4: st\_impdrv\_initdata\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  void \*p\_work\_addr;  uint32\_t work\_size;  uint32\_t out\_work\_size;  e\_impdrv\_instance\_t instance\_num;  uint32\_t use\_core\_num;  st\_impdrv\_core\_info\_t core\_info[IMPDRV\_INNER\_FIXED\_VALUE];  p\_impdrv\_cbfunc\_fatal\_t callback\_func\_fatal;  void \*p\_cb\_args\_fatal;  st\_impdrv\_resource\_t osal\_resource;  } st\_impdrv\_initdata\_t; | | |
| **Description** | Data structure used for the R\_IMPDRV\_Init function. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| p\_work\_addr | In | Work area address  The lifetime of this parameter is the period from the R\_IMPDRV\_Init is executed until R\_IMPDRV\_Quit is executed. |
| Work\_size | In | Work area size |
| out\_work\_size | Out | Used memory size |
| instance\_num | In | Instance number |
| use\_core\_num | In | Number of core lists |
| core\_info | In | Core lists information |
| callback\_func\_fatal | In | Fatal callback function  The lifetime of this parameter is the period from the R\_IMPDRV\_Init is executed until R\_IMPDRV\_Quit is executed. |
| P\_cb\_args\_fatal | In | fatal callback args  The lifetime of this parameter is the period from the R\_IMPDRV\_Init is executed until R\_IMPDRV\_Quit is executed. |
| Osal\_resource | In | OSAL resources information |
| **Member**  **Valid value** | **Name** | **Value** | |
| p\_work\_addr | Refer to the “4.4.1 st\_impdrv\_initdata\_t” in [3]. | |
| Work\_size | Refer to the “4.4.1 st\_impdrv\_initdata\_t” in [3]. | |
| Out\_work\_size | Refer to the “4.4.1 st\_impdrv\_initdata\_t” in [3]. | |
| Instance\_num | Refer to the “4.4.1 st\_impdrv\_initdata\_t” in [3]. | |
| Use\_core\_num | Refer to the “4.4.1 st\_impdrv\_initdata\_t” in [3]. | |
| Core\_info | Refer to the “4.4.1 st\_impdrv\_initdata\_t” in [3]. | |
| Callback\_func\_fatal | Refer to the “4.4.1 st\_impdrv\_initdata\_t” in [3]. | |
| P\_cb\_args\_fatal | Refer to the “4.4.1 st\_impdrv\_initdata\_t” in [3]. | |
| Osal\_resource | Refer to the “4.4.1 st\_impdrv\_initdata\_t” in [3]. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_resource\_t

Table 5‑5: st\_impdrv\_resource\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  osal\_mutex\_id\_t mutex\_id;  osal\_milli\_sec\_t mutex\_time\_period;  osal\_mq\_id\_t mq\_id;  osal\_milli\_sec\_t mq\_time\_period;  e\_osal\_interrupt\_priority\_t irq\_priority;  } st\_impdrv\_resource\_t; | | |
| **Description** | Data structure used for the st\_impdrv\_initdata\_t internal structure. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| mutex\_id | In | Mutex ID used by IMP Driver |
| mutex\_time\_period | In | Millisecond order for the Timeout value of mutex |
| mq\_id | In | Message queue ID used by IMP Driver |
| mq\_time\_period | In | Millisecond order for the Timeout value of message queue |
| irq\_priority | In | Interrupt priority |
| **Member**  **Valid value** | **Name** | **Value** | |
| mutex\_id | Refer to the “ 4.4.4 st\_impdrv\_resource\_t” in [3]. | |
| Mutex\_time\_period | Refer to the “ 4.4.4 st\_impdrv\_resource\_t” in [3]. | |
| Mq\_id | Refer to the “ 4.4.4 st\_impdrv\_resource\_t” in [3]. | |
| Mq\_time\_period | Refer to the “ 4.4.4 st\_impdrv\_resource\_t” in [3]. | |
| Irq\_priority | Refer to the “ 4.4.4 st\_impdrv\_resource\_t” in [3]. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_core\_info\_t

Table 5‑6: st\_impdrv\_core\_info\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  e\_impdrv\_core\_type\_t core\_type;  uint32\_t core\_num;  } st\_impdrv\_core\_info\_t; | | |
| **Description** | IMP Driver determines the IMP core, selected by this value. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| core\_type | In | IMP Core type |
| core\_num | In | Core number in the core type |
| **Member**  **Valid value** | **Name** | **Value** | |
| core\_type | Refer to the “4.4.2 st\_impdrv\_core\_info\_t” in [3]. | |
| Core\_num | Refer to the “4.4.2 st\_impdrv\_core\_info\_t” in [3]. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_irq\_group\_t

Table 5‑7: st\_impdrv\_irq\_group\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  e\_impdrv\_irq\_group\_t irq\_group;  uint32\_t group\_core\_num;  st\_impdrv\_core\_info\_t group\_core\_info[IMPDRV\_IRQGROUP\_MAXID];  } st\_impdrv\_irq\_group\_t; | | |
| **Description** | IMP Driver determines the IMP core, selected by this value. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| irq\_group | In | Interrupt group number |
| group\_core\_num | In | Number of Group cores |
| group\_core\_info | In | Group core list |
| **Member**  **Valid value** | **Name** | **Value** | |
| irq\_group | Refer to the “ 4.4.7 st\_impdrv\_irq\_group\_t” in [3]. | |
| Group\_core\_num | Refer to the “ 4.4.7 st\_impdrv\_irq\_group\_t” in [3]. | |
| Group\_core\_info | Refer to the “ 4.4.7 st\_impdrv\_irq\_group\_t” in [3]. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_chk\_param\_t

Table 5‑8: st\_impdrv\_chk\_param\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  uintptr\_t offset;  uint32\_t data;  uint32\_t bit\_mask;  } st\_impdrv\_chk\_param\_t; | | |
| **Description** | OSAL resources in used by IMPDRV for bus interface check. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| offset | In | Offset address of hardware register |
| data | In | Expected check data |
| bit\_mask | In | Bitmask value for check data |
| **Member**  **Valid value** | **Name** | **Value** | |
| offset | Offset address of hardware register. | |
| Data | Expected data | |
| bit\_mask | Bitmask value | |
| **Remarks** | N/A | | |

##### st\_impdrv\_version\_t

Table 5‑9: st\_impdrv\_version\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  uint32\_t major;  uint32\_t minor;  uint32\_t patch;  } st\_impdrv\_version\_t; | | |
| **Description** | This function return driver version.  The version number returned is based on the IMPDRV\_VERSION\_MAJOR, IMPDRV\_VERSION\_MINOR, and IMPDRV\_VERSION\_PATCH definition. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| major | Out | Major version of IMP driver |
| minor | Out | Minor version of IMP driver |
| patch | Out | Patch version of IMP driver |
| **Member**  **Valid value** | **Name** | **Value** | |
| major | Refer to the “4.4.5 st\_impdrv\_version\_t” in [3]. | |
| Minor | Refer to the “4.4.5 st\_impdrv\_version\_t” in [3]. | |
| Patch | Refer to the “4.4.5 st\_impdrv\_version\_t” in [3]. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_reg\_info\_t

Table 5‑10: st\_impdrv\_reg\_info\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  uintptr\_t addr\_phys;  uint32\_t size;  } st\_impdrv\_reg\_info\_t; | | |
| **Description** | IMP Driver Hardware register area specification information. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| addr\_phys | Out | Top address of hardware register |
| size | Out | Area size of hardware register |
| **Member**  **Valid value** | **Name** | **Value** | |
| addr\_phys | Refer to the “ 4.4.7 st\_impdrv\_irq\_group\_t” in [3]. | |
| Size | Refer to the “ 4.4.7 st\_impdrv\_irq\_group\_t” in [3]. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_chk\_resource\_t

Table 5‑11: st\_impdrv\_chk\_resource\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  osal\_memory\_buffer\_handle\_t memory\_handle;  osal\_axi\_bus\_id\_t axi\_id;  osal\_mq\_id\_t mq\_id;  osal\_milli\_sec\_t mq\_time\_period;  } st\_impdrv\_chk\_resource\_t; | | |
| **Description** | OSAL resources in used by IMPDRV for bus interface check. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| memory\_handle | In | OSAL Memory manager handle |
| axi\_id | In | AXI bus ID |
| mq\_id | In | Queue ID used by IMP Driver |
| mq\_time\_period | In | Millisecond Order Timeout value |
| **Member**  **Valid value** | **Name** | **Value** | |
| memory\_handle | Handle type of a Buffer Object. | |
| Axi\_id | AXI Bus ID type that is assigned to a device. | |
| Mq\_id | uniquely identifies a message queue | |
| mq\_time\_period | time in milliseconds. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_dsp\_data\_t

Not use (Out of scope for xOS2.0)

Table 5‑12: st\_impdrv\_dsp\_data\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  uintptr\_t addr\_phys;  uint32\_t size;  } st\_impdrv\_dsp\_data\_t; | | |
| **Description** | - | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| addr\_phys | - | - |
| size | - | - |
| **Member**  **Valid value** | **Name** | **Value** | |
| addr\_phys | - | |
| size | - | |
| **Remarks** | N/A | | |

#### General Control

##### st\_impdrv\_ctl\_t

Table 5‑13: st\_impdrv\_ctl\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct st\_impdrv\_ctl  {  st\_impdrv\_coretypectl\_t coretype\_ctl[IMPDRV\_CORE\_TYPE\_MAX];  st\_impdrv\_commonctl\_t common\_ctl;  } st\_impdrv\_ctl\_t; | | |
| **Description** | Common control data structure used by general control subcomponents. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| coretype\_ctl | In/out | Core control structure data for each core type. |
| Common\_ctl | In/out | Common control structure data to all core. |
| **Member**  **Valid value** | **Name** | **Value** | |
| coretype\_ctl | Follows the st\_impdrv\_coretypectl\_t structure. | |
| Common\_ctl | Follows the st\_impdrv\_commonctl\_t structure. | |
| **Remarks** | N/A | | |

#### Common Control

##### st\_impdrv\_commonctl\_t

Table 5‑14: st\_impdrv\_commonctl\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  e\_impdrv\_instance\_t instance\_num;  uint32\_t use\_core\_ins ;  p\_impdrv\_cbfunc\_fatal\_t cbfunc\_fatal;  void \*p\_cb\_args\_fatal;  bool is\_mutex\_locked;  uint32\_t irq\_mask\_value;  [e\_impdrv\_protect\_mode\_t](#_e_impdrv_protect_mode_t) protect\_mode;  void \*p\_hwrsc\_def\_table;  void \*p\_hwrsc\_mng\_table;  } st\_impdrv\_commonctl\_t; | | |
| **Description** | Common resource data structure used by common control subcomponents. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| instance\_num | In/Out | Instance number. |
| Use\_core\_ins | In/Out | The current instance’s use core |
| cbfunc\_fatal | In/Out | Fatal callback function |
| p\_cb\_args\_fatal | In/Out | Fatal callback argument |
| is\_mutex\_locked | In/Out | Mutex locked state for Register access API |
| irq\_mask\_value | In/Out | Save data of IRQ mask register |
| protect\_mode | In/Out | Save data of memory protection mode |
| \*p\_hwrsc\_def\_table | In/Out | Extended information for debug interface |
| \*p\_hwrsc\_mng\_table | In/Out | Extended information for debug interface |
| **Member**  **Valid value** | **Name** | **Value** | |
| instance\_num | Follows the e\_impdrv\_instance\_t. enumeration. | |
| Use\_core\_ins | Bit position of core number | |
| cbfunc\_fatal | User-specified value of the Callback function address. | |
| P\_cb\_args\_fatal | User-specified value of the Callback function argument. | |
| Is\_mutex\_locked | true or false | |
| irq\_mask\_value | Not 0 | |
| protect\_mode | Follows the [e\_impdrv\_protect\_mode\_t](#_e_impdrv_protect_mode_t) enumeration. | |
| \*p\_hwrsc\_def\_table | Debug interface extended information address. | |
| \*p\_hwrsc\_mng\_table | Debug interface extended information address. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_cmn\_init\_data\_t

Table 5‑15: st\_impdrv\_cmn\_init\_data\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  e\_impdrv\_instance\_t instance\_num;  e\_osal\_interrupt\_priority\_t irq\_priority;  st\_impdrv\_core\_info\_t \*p\_core\_info;  uint32\_t use\_core\_num;  impdrv\_ctrl\_handle\_t osal\_cb\_args;  p\_impdrv\_cbfunc\_fatal\_t cbfunc\_fatal;  void \*p\_cb\_args\_fatal;  osal\_mutex\_id\_t mutex\_id;  osal\_milli\_sec\_t time\_period;  } st\_impdrv\_cmn\_init\_data\_t; | | |
| **Description** | IMPDRV structure of common control init data. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| instance\_num | In/Out | Instance number. |
| Irq\_priority | In/Out | Interrupt priority |
| \*p\_core\_info | In/Out | Related core number |
| use\_core\_num | In/Out | Related core information list |
| osal\_cb\_args | In/Out | OSAL callback argument |
| cbfunc\_fatal | In/Out | Fatal callback function |
| \*p\_cb\_args\_fatal | In/Out | Fatal callback argument |
| mutex\_id | In/Out | OSAL mutex id |
| time\_period | In/Out | Mutex timeout value by [msec]order |
| **Member**  **Valid value** | **Name** | **Value** | |
| instance\_num | Follows the e\_impdrv\_instance\_t. enumeration. | |
| Irq\_priority | Priority for interrupt. | |
| \*p\_core\_info | User-specified value of the Callback function address. | |
| Use\_core\_num | Core Number; | |
| osal\_cb\_args | Follows the impdrv\_ctrl\_handle\_t enumeration. | |
| Cbfunc\_fatal | Follows the p\_impdrv\_cbfunc\_fatal\_t enumeration. | |
| \*p\_cb\_args\_fatal | User-specified value of the Callback function argument. | |
| Mutex\_id | ID for mutex. | |
| Time\_period | Time in milliseconds. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_corectl\_func\_t

Table 5‑16: st\_impdrv\_corectl\_func\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  bool (\*p\_impdrvCorectlIsValidCore)(  const uint32\_t core\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlCheckState)(  const st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const e\_impdrv\_state\_t state  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSetState)(  st\_impdrv\_corectl\_t \* const p\_corectl,  const e\_impdrv\_state\_t state  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlInitStart)(  st\_impdrv\_coretypectl\_t \* const p\_coretypectl,  const uint32\_t core\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlInitEnd)(  st\_impdrv\_coretypectl\_t \* const p\_coretypectl,  const uint32\_t core\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlStart)(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl ,  const uint32\_t core\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlStop)(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlAttInit)(  st\_impdrv\_corectl\_t \* const p\_corectl,  const uint32\_t core\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSetMemInit)(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const e\_impdrv\_param\_t enable  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSetCoreMap)(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const uint8\_t syncc\_val[IMPDRV\_COREMAP\_MAXID]  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSetCl)(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const uint32\_t claddr\_phys  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSetIrqMask)(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const bool irq\_mask[IMPDRV\_IRQMASK\_MAX]  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlExecute)(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const p\_impdrv\_cbfunc\_t callback\_func,  void \*const p\_callback\_args  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlIntHandler)(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlResumeExe)(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlPmSetPolicy)(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  const e\_impdrv\_pm\_policy\_t policy  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlPmGetPolicy)(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  e\_impdrv\_pm\_policy\_t \*const p\_policy  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSetDsp)(  st\_impdrv\_corectl\_t \*p\_corectl,  const uint32\_t core\_num,  const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_app,  const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_fw,  const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_data,  const st\_impdrv\_dsp\_data\_t \*const p\_dsp\_dtcm  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlBusIfCheck)(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  const st\_impdrv\_chk\_resource\_t \*const p\_chk\_resource  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlConfRegCheck)(  const st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  const st\_impdrv\_chk\_param\_t \*const p\_chk\_param,  const uint32\_t param\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSetClBrkAddr)(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const uint32\_t cl\_brk\_addr  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSetGosubCond)(  st\_impdrv\_corectl\_t \*const p\_corectl,  const uint32\_t core\_num,  const e\_impdrv\_gosub\_cond\_t condition  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlPmGetState)(  st\_impdrv\_coretypectl\_t \*const p\_coretypectl,  const uint32\_t core\_num,  e\_impdrv\_pm\_state\_t \*const p\_pmstate  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlQuit)(  const uint32\_t core\_num  );  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSyncStart)(  st\_impdrv\_coretypectl\_t coretype\_ctl[IMPDRV\_CORE\_TYPE\_MAX],  const uint32\_t core\_num  ); /\*\*< Function table for distinguishing each core. Starts controlling the core in sync. \*/  e\_impdrv\_errorcode\_t (\*p\_impdrvCorectlSyncStop)(  st\_impdrv\_coretypectl\_t coretype\_ctl[IMPDRV\_CORE\_TYPE\_MAX],  const uint32\_t core\_num  ); /\*\*< Function table for distinguishing each core. Stop controlling the core in sync. \*/  } st\_impdrv\_corectl\_func\_t; | | |
| **Description** | Core control interface structure used by common control subcomponents.  This structure is used only with s\_corectl\_func\_tbl. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| p\_impdrvCorectlIsValidCore | In | Function table for distinguishing each core. Valid core. |
| P\_impdrvCorectlCheckState | In | Function table for distinguishing each core. Check state. |
| P\_impdrvCorectlSetState | In | Function table for distinguishing each core. Set state. |
| P\_impdrvCorectlInitStart | In | Function table for distinguishing each core. Init start. |
| P\_impdrvCorectlInitEnd | In | Function table for distinguishing each core. Init end. |
| P\_impdrvCorectlStart | In | Function table for distinguishing each core. Start core control. |
| P\_impdrvCorectlStop | In | Function table for distinguishing each core. Stop core control. |
| P\_impdrvCorectlAttInit | In | Function table for distinguishing each core. Attribute initialize. |
| P\_impdrvCorectlSetMemInit | In | Function table for distinguishing each core. Set core memory initialize. |
| P\_impdrvCorectlSetCoreMap | In | Function table for distinguishing each core. Set sync core map. |
| P\_impdrvCorectlSetCl | In | Function table for distinguishing each core. Set CL address. |
| P\_impdrvCorectlSetIrqMask | In | Function table for distinguishing each core. Set IRQ mask setting. |
| P\_impdrvCorectlExecute | In | Function table for distinguishing each core. Execute core control. |
| P\_impdrvCorectlIntHandler | In | Function table for distinguishing each core. Int handler imp control. |
| P\_impdrvCorectlResumeExe | In | Function table for distinguishing each core. Resume core control. |
| P\_impdrvCorectlPmSetPolicy | In | Function table for distinguishing each core. Pm set policy core control. |
| P\_impdrvCorectlPmGetPolicy | In | Function table for distinguishing each core. Pm get policy core control. |
| p\_impdrvCorectlSetDsp | In | Function table for distinguishing only DSP core. Attribute settings of DSP information. |
| P\_impdrvCorectlBusIfCheck | In | Function table for distinguishing each core. Interface bus check of core control. |
| P\_impdrvCorectlConfRegCheck | In | Function table for distinguishing each core. Configuration register check of core control. |
| p\_impdrvCorectlSetClBrkAddr | In | Function table for distinguishing each core. Set CL break address. |
| p\_impdrvCorectlSetGosubCond | In | Function table for distinguishing each core. Set Conditional GOSUB instruction attribute. |
| p\_impdrvCorectlPmGetState | In | Function table for distinguishing each core. Pm get state core control. |
| p\_impdrvCorectlQuit | In | Function table for distinguishing each core. Quit core control. |
| **Member**  **Valid value** | **Name** | **Value** | |
| p\_impdrvCorectlIsValidCore | Must be Not NULL, Set the address for interface function in each core control of sub component. | |
| P\_impdrvCorectlCheckState | Same as above. | |
| P\_impdrvCorectlSetState | Same as above. | |
| P\_impdrvCorectlInitStart | Same as above. | |
| P\_impdrvCorectlInitEnd | Same as above. | |
| P\_impdrvCorectlStart | Same as above. | |
| P\_impdrvCorectlStop | Same as above. | |
| P\_impdrvCorectlAttInit | Same as above. | |
| P\_impdrvCorectlSetMemInit | Same as above. | |
| P\_impdrvCorectlSetCoreMap | Same as above. | |
| P\_impdrvCorectlSetCl | Same as above. | |
| P\_impdrvCorectlSetIrqMask | Same as above. | |
| P\_impdrvCorectlExecute | Same as above. | |
| P\_impdrvCorectlIntHandler | Same as above. | |
| P\_impdrvCorectlResumeExe | Same as above. | |
| P\_impdrvCorectlPmSetPolicy | Same as above. | |
| P\_impdrvCorectlPmGetPolicy | Same as above. | |
| p\_impdrvCorectlSetDsp | Same as above. | |
| P\_impdrvCorectlBusIfCheck | Same as above. | |
| P\_impdrvCorectlConfRegCheck | Same as above. | |
| p\_impdrvCorectlSetClBrkAddr | Same as above. | |
| p\_impdrvCorectlSetGosubCond | Same as above. | |
| p\_impdrvCorectlPmGetState | Same as above. | |
| p\_impdrvCorectlQuit | Same as above. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_inten\_tbl\_t

Table 5‑17: st\_impdrv\_inten\_tbl\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct st\_impdrv\_inten\_tbl  {  e\_impdrv\_core\_type\_t core\_type;  uint32\_t core\_num;  uint32\_t bit;  } st\_impdrv\_inten\_tbl\_t; | | |
| **Description** | Definition for bit allocation conversion of the Interrupt enable register | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| core\_type | In | IMP Core type |
| core\_num | In | Core number in the core type |
| bit | In | Bit value to convert |
| **Member**  **Valid value** | **Name** | **Value** | |
| core\_type | Follows the e\_impdrv\_core\_type\_t enumeration. | |
| Core\_num | Less than maximum number of the Cores for each types. | |
| Bit | Bit assignment value of the Interrupt enable register. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_group\_tbl\_t

Table 5‑18: st\_impdrv\_group\_tbl\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct st\_impdrv\_group\_tbl  {  uint32\_t group\_bit;  uint32\_t group\_reg;  } st\_impdrv\_group\_tbl\_t; | | |
| **Description** | Definition for bit allocation conversion of the Interrupt group register | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| group\_bit | In | Bit value to convert |
| group\_reg | In | Offset address value to convert |
| **Member**  **Valid value** | **Name** | **Value** | |
| group\_bit | Bit assignment value of interrupt enable register. | |
| Group\_reg | Offset address of interrupt select register. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_syncc\_table\_t

Table 5‑19: st\_impdrv\_syncc\_table\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  e\_impdrv\_core\_type\_t core\_type;  uint32\_t core\_num;  uint8\_t syncc\_val;  } st\_impdrv\_syncc\_table\_t; | | |
| **Description** | Definition for conversion of the syncc value | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| core\_type | In | IMP Core type |
| core\_num | In | Core number in the core type |
| syncc\_val | In | Syncc value to convert |
| **Member**  **Valid value** | **Name** | **Value** | |
| core\_type | Follows the e\_impdrv\_core\_type\_t enumeration. | |
| Core\_num | Less than maximum number of the Cores for each types. | |
| Syncc\_val | Value of syncc register | |
| **Remarks** | N/A | | |

##### st\_impdrv\_inten\_reg\_tbl\_t

Table 5‑20: st\_impdrv\_inten\_reg\_tbl\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  const st\_impdrv\_group\_tbl\_t \*p\_inten\_group\_table;  const st\_impdrv\_inten\_tbl\_t \*p\_inten\_cnv\_table;  uint32\_t cnv\_table\_num;  } st\_impdrv\_inten\_reg\_tbl\_t; | | |
| **Description** | Definition for conversion of register table | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| \*p\_inten\_group\_table | In | Convert Int group register table |
| \*p\_inten\_cnv\_table | In | Convert Int enable register table |
| cnv\_table\_num | In | Number of convert Int enable register table |
| **Member**  **Valid value** | **Name** | **Value** | |
| \*p\_inten\_group\_table | Follows the st\_impdrv\_group\_tbl\_t structure. | |
| \*p\_inten\_cnv\_table | Follows the st\_impdrv\_inten\_tbl\_t structure. | |
| Cnv\_table\_num | Maximum number of cores for the Interrupt group. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_hwrsc\_def\_t

Table 5‑21: st\_impdrv\_hwrsc\_def\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  const char \*name;  uintptr\_t addr\_phys;  uint32\_t size;  bool read\_only;  bool internal;  } st\_impdrv\_hwrsc\_def\_t;; | | |
| **Description** | Hardware resource definition table. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| \*name | In/out | Resource Name(Key) |
| addr\_phys | In/out | Physical address |
| size | In/out | Area size |
| read\_only | In/out | Read only attribute |
| internal | In/out | Internal resource attribute |
| **Member**  **Valid value** | **Name** | **Value** | |
| \*name | Hardware resource name | |
| addr\_phys | Top address of hardware register | |
| size | Area size of hardware register | |
| read\_only | true or false | |
| internal | true or false | |
| **Remarks** | N/A | | |

##### st\_impdrv\_hwrsc\_mng\_t

Table 5‑22: st\_impdrv\_hwrsc\_mng\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  uint32\_t resource\_used;  uint32\_t memory\_initialized;  uint32\_t in\_use[IMPDRV\_HWRSC\_TABLE\_NUM];  st\_impdrv\_device\_handle\_t handle[IMPDRV\_HWRSC\_TABLE\_NUM];  } st\_impdrv\_hwrsc\_mng\_t; | | |
| **Description** | Common control global area. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| resource\_used | In/out | Resource used state |
| memory\_initialized | In/out | Memory initialized state |
| in\_use[IMPDRV\_HWRSC\_TABLE\_NUM] | In/out | In-use status management |
| handle[IMPDRV\_HWRSC\_TABLE\_NUM] | In/out | IMPDRV device handle |
| **Member**  **Valid value** | **Name** | **Value** | |
| resource\_used | IMPDRV\_HWRSC\_UNUSED or follows the s\_impdrv\_used\_instance | |
| memory\_initialized | IMPDRV\_HWRSC\_UNUSED or follows the s\_impdrv\_used\_instance | |
| in\_use | Follows the s\_impdrv\_used\_instance | |
| handle | Follows the st\_impdrv\_device\_handle\_t structure. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_hwrsc\_def\_t

Table 5‑23: st\_impdrv\_hwrsc\_def\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  const char \*name;  uintptr\_t addr\_phys;  uint32\_t size;  bool read\_only;  bool internal;  } st\_impdrv\_hwrsc\_def\_t; | | |
| **Description** | Hardware resource definition table. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| \*name | In/out | Resource Name(Key) |
| addr\_phys | In/out | Physical address |
| size | In/out | Area size |
| read\_only | In/out | Read only attribute |
| internal | In/out | Internal resource attribute |
| **Member**  **Valid value** | **Name** | **Value** | |
| \*name | Hardware resource name | |
| addr\_phys | Top address of hardware register | |
| size | Area size of hardware register | |
| read\_only | true or false | |
| internal | true or false | |
| **Remarks** | N/A | | |

##### st\_impdrv\_commonctl\_ins\_t

Table 5‑24: st\_impdrv\_commonctl\_ins\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  st\_impdrv\_device\_handle\_t device\_io\_imptop;  st\_impdrv\_mutex\_handle\_t mutex\_handle;  osal\_mutex\_id\_t mutex\_id;  osal\_milli\_sec\_t mutex\_time\_period;  st\_impdrv\_device\_handle\_t device\_io\_dta;  st\_impdrv\_commonctl\_t \*p\_commonctl[IMPDRV\_INSTANCETABLE\_NUM];  } st\_impdrv\_commonctl\_ins\_t; | | |
| **Description** | Hardware resource definition table. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| device\_io\_imptop | In/out | OSAL device handle (IMP TOP). |
| Mutex\_handle | In/out | OSAL mutex handle |
| mutex\_id | In/out | OSAL mutex id |
| mutex\_time\_period | In/out | Millisecond Order Mutex Timeout value |
| device\_io\_dta | In/out | OSAL device handle (DTA Core). |
| \*p\_commonctl | In/out | Address of the commonctl. |
| **Member**  **Valid value** | **Name** | **Value** | |
| device\_io\_imptop | Follows the st\_impdrv\_device\_handle\_t structure. | |
| Mutex\_handle | Follows the st\_impdrv\_mutex\_handle\_t structure. | |
| Mutex\_id | ID for mutex. | |
| Mutex\_time\_period | Time in milliseconds. | |
| Device\_io\_dta | Follows the st\_impdrv\_device\_handle\_t structure. | |
| \*p\_commonctl | Follows the st\_impdrv\_commonctl\_t structure. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_commonctl\_chk\_t

Table 5‑25: st\_impdrv\_commonctl\_chk\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  uint32\_t checksum;  st\_impdrv\_device\_handle\_t device\_io\_imptop;  } st\_impdrv\_commonctl\_chk\_t | | |
| **Description** | Common control global check area. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| checksum | In/out | Checksum value of Global variable. |
| Device\_io\_imptop | In/out | Backup of OSAL device handle(IMP TOP). |
| **Member**  **Valid value** | **Name** | **Value** | |
| checksum | Checksum value of Global variable. | |
| Device\_io\_imptop | Follows the st\_impdrv\_device\_handle\_t structure. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_hwrsc\_chk\_t

Table 5‑26: st\_impdrv\_hwrsc\_chk\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  uint32\_t checksum;  } st\_impdrv\_hwrsc\_chk\_t | | |
| **Description** | Common control global check area. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| checksum | In/out | Checksum value of Global variable. |
| **Member**  **Valid value** | **Name** | **Value** | |
| checksum | Checksum value of Global variable. | |
| **Remarks** | N/A | | |

#### Core Control

##### st\_impdrv\_coretypectl\_t

Table 5‑27: st\_impdrv\_coretypectl\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct{  st\_impdrv\_corectl\_t core\_ctl[IMPDRV\_CORE\_NUM\_MAX];  } st\_impdrv\_coretypectl\_t; | | |
| **Description** | Each core control data structure used by core control subcomponents. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| core\_ctl | In/Out | Array of The Core Control handles. |
| **Member**  **Valid value** | **Name** | **Value** | |
| core\_ctl | Follows the st\_impdrv\_corectl\_t structure. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_corectl\_t

Table 5‑28: st\_impdrv\_corectl\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  st\_impdrv\_device\_handle\_t device\_io;  st\_impdrv\_queue\_handle\_t queue\_handle;  st\_impdrv\_cbinfo\_t cbinfo;  e\_impdrv\_state\_t core\_state;  e\_impdrv\_param\_t core\_mem\_init\_enable;  uint32\_t claddr\_phys;  uint8\_t cur\_core\_map[IMPDRV\_COREMAP\_MAXID];  bool irq\_mask[IMPDRV\_IRQMASK\_MAX];  bool is\_progress\_bus\_if\_check;  uint8\_t reserve[IMPDRV\_RESERVE\_NUM];  uint32\_t param[IMPDRV\_EXEPARAM\_MAX];  } st\_impdrv\_corectl\_t; | | |
| **Description** | Each core control data structure used by core control subcomponents. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| device\_io | In/Out | Device handle |
| queue\_handle | In/Out | Message queue handle |
| cbinfo | In/Out | Callback function information |
| core\_state | In/Out | IMP Driver state |
| core\_mem\_init\_enable | In/Out | memory initialization possible flag |
| claddr\_phys | In/Out | CL Physical address |
| cur\_core\_map | In/Out | Current core map |
| irq\_mask | In/Out | Mask of IRQ Grouping |
| is\_progress\_bus\_if\_check | In/Out | Bus interface check in progress |
| reserve | In/Out | Unused area |
| param | In/Out | Execution parameters |
| **Member**  **Valid value** | **Name** | **Value** | |
| device\_io | Follows the st\_impdrv\_device\_handle\_t structure. | |
| Queue\_handle | Follows the st\_impdrv\_queue\_handle\_t structure. | |
| Cbinfo | Follows the st\_impdrv\_cbinfo\_t structure. | |
| Core\_state | Follows the e\_impdrv\_state\_t enumeration. | |
| Core\_mem\_init\_enable | Disable (0u) or Enable (1u). | |
| claddr\_phys | 32-bit physical memory address. | |
| Cur\_core\_map | Valid values of the SYNCC register. | |
| Irq\_mask | Valid values of the Interrupt mask register for each cores. | |
| Is\_progress\_bus\_if\_check | Disable (0u) or Enable (1u). | |
| reserve | N/A | |
| param | Parameter arrays of disable (0u) or enable (1u). | |
| **Remarks** | N/A | | |

##### st\_impdrv\_cbinfo\_t

Table 5‑29: st\_impdrv\_cbinfo\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  p\_impdrv\_cbfunc\_t cbfunc;  void \*p\_cbarg;  } st\_impdrv\_cbinfo\_t; | | |
| **Description** |  | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| cbfunc | In/Out | Callback function address |
| p\_cbarg | In/Out | Address of the callback function argument. |
| **Member**  **Valid value** | **Name** | **Value** | |
| cbfunc | User-specified value of the Callback function address. | |
| P\_cbarg | User-specified value of the Callback function argument. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_dma\_write\_info\_t

Table 5‑30: st\_impdrv\_dma\_write\_info\_t

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| **Format** | typedef struct  {  st\_impdrv\_device\_handle\_t \*p\_device\_handle;  uint32\_t offset;  uint32\_t val;  bool is\_sub\_thread;  bool read\_back;  uint32\_t chk\_val;  } st\_impdrv\_dma\_write\_info\_t; | | | | | | | |
| **Description** | Write register information. | | | | | | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** | | | | | |
| \*p\_device\_handle | In | OSAL device handle. | | | | | |
| Offset | In | Offset to set to register. | | | | | |
| **Range** | Less than IMPDRV\_REG\_OFFSET\_MAX and 4 byte alignment. | | | | |
| Val | In | Write values to registers. | | | | | |
| **Range** | | None. | | | |
| Is\_sub\_thread | In | Select for DMAC Internal thread. | | | | | |
| **Range** | | | true or false. | | |
| Read\_back; | In | Whether to read back. | | | | | |
| **Range** | | | | true or false. | |
| Chk\_val | In | Value to read back register. | | | | | |
| **Range** | | | | | None. |
| **Member**  **Valid value** | **Name** | **Value** | | | | | | |
| \*p\_device\_handle | Follows the st\_impdrv\_device\_handle\_t structure. | | | | | | |
| Offset | Offset address of hardware register. | | | | | | |
| Val | Valid value to set to register. | | | | | | |
| Is\_sub\_thread | true or false. | | | | | | |
| Read\_back | true or false. | | | | | | |
| Chk\_val | Valid value to read back register. | | | | | | |
| **Remarks** | N/A | | | | | | | |

##### st\_impdrv\_dma\_write\_info\_tbl\_t

Table 5‑31: st\_impdrv\_dma\_write\_info\_tbl\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  uint32\_t offset;  uint32\_t val;  bool read\_back;  uint32\_t chk\_val;  } st\_impdrv\_dma\_write\_info\_tbl\_t; | | |
| **Description** | Multi-bank memory initialization information | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| offset | In | Offset to get to register |
| val | In | Write values to registers |
| read\_back | In | Whether to read back |
| chk\_val | In | Value to read back register |
| **Member**  **Valid value** | **Name** | **Value** | |
| offset | Offset address of hardware register. | |
| Val | Valid value to set to register. | |
| Read\_back | true or false. | |
| Chk\_val | Valid value to read back register. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_imp\_write\_info\_tbl\_t

Table 5‑32: st\_impdrv\_imp\_write\_info\_tbl\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  uint32\_t offset;  uint32\_t val;  bool read\_back;  uint32\_t chk\_val;  } st\_impdrv\_imp\_write\_info\_tbl\_t; | | |
| **Description** | Multi-bank memory initialization information | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| offset | In | Offset to get to register |
| val | In | Write values to registers |
| read\_back | In | Whether to read back |
| chk\_val | In | Value to read back register |
| **Member**  **Valid value** | **Name** | **Value** | |
| offset | Offset address of hardware register. | |
| Val | Valid value to set to register. | |
| Read\_back | true or false. | |
| Chk\_val | Valid value to read back register. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_dsp\_info\_t

(Out of scope for xOS2.0)

Table 5‑33: st\_impdrv\_dsp\_info\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  st\_impdrv\_dsp\_data\_t dsp\_app;  st\_impdrv\_dsp\_data\_t dsp\_fw;  st\_impdrv\_dsp\_data\_t dsp\_data;  bool is\_updated;  bool is\_loaded;  } st\_impdrv\_dsp\_info\_t; | | |
| **Description** | - | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| st\_impdrv\_dsp\_data\_t | - | - |
| st\_impdrv\_dsp\_data\_t | - | - |
| st\_impdrv\_dsp\_data\_t | - | - |
| bool | - | - |
| bool | - | - |
| **Member**  **Valid value** | **Name** | **Value** | |
| st\_impdrv\_dsp\_data\_t | - | |
| st\_impdrv\_dsp\_data\_t | - | |
| st\_impdrv\_dsp\_data\_t | - | |
| bool | - | |
| bool | - | |
| **Remarks** | N/A | | |

#### OS Dependence Layer

##### st\_impdrv\_device\_handle\_t

Table 5‑34: st\_impdrv\_device\_handle\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  osal\_device\_handle\_t handle;  } st\_impdrv\_device\_handle\_t; | | |
| **Description** | OSAL device handle.  When NULL, the device is not open, and when it is not NULL, the device is open.  IMP Driver checks the above state and detects sequence errors. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| handle | In/Out | OSAL device handle |
| **Member**  **Valid value** | **Name** | **Value** | |
| handle | Valid value of the handle numbered by OSAL. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_mutex\_handle\_t

Table 5‑35: st\_impdrv\_mutex\_handle\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  osal\_mutex\_handle\_t handle;  } st\_impdrv\_mutex\_handle\_t; | | |
| **Description** | OSAL mutex handle.  When NULL, the mutex is not create, and when it is not NULL, the mutex is create.  IMP Driver checks the above state and detects sequence errors. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| handle | In/Out | OSAL mutex handle |
| **Member**  **Valid value** | **Name** | **Value** | |
| handle | Valid value of the handle numbered by OSAL. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_queue\_handle\_t

Table 5‑36: st\_impdrv\_queue\_handle\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  osal\_mq\_handle\_t handle;  } st\_impdrv\_queue\_handle\_t; | | |
| **Description** | OSAL message queue handle.  When NULL, the message queue is not create, and when it is not NULL, the message queue is create. IMP Driver checks the above state and detects sequence errors. | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| handle | In/Out | OSAL message queue handle |
| **Member**  **Valid value** | **Name** | **Value** | |
| handle | Valid value of the handle numbered by OSAL. | |
| **Remarks** | N/A | | |

##### st\_impdrv\_memory\_handle\_t

Table 5‑37: st\_impdrv\_memory\_handle\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef struct  {  osal\_memory\_buffer\_handle\_t handle;  } st\_impdrv\_memory\_handle\_t; | | |
| **Description** | OSAL memory buffer handle . | | |
| **Member**  **Description** | **Name** | **In/out** | **Description** |
| handle | In/Out | OSAL memory buffer handle |
| **Member**  **Valid value** | **Name** | **Value** | |
| handle | Valid value of the handle numbered by OSAL. | |
| **Remarks** | N/A | | |

## Global Pointer Variables

Not use.

## Global Variables

### API Layer

None.

### General Control

None.

### Common Control

#### g\_impdrv\_cmn\_ctl\_ins

Table 5‑38: g\_impdrv\_cmn\_ctl\_ins

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  st\_impdrv\_commonctl\_ins\_t g\_impdrv\_cmn\_ctl\_ins =  {  { NULL }, /\*\*< device\_io\_imptop \*/  { NULL }, /\*\*< mutex\_handle \*/  0U, /\*\*< mutex\_id \*/  0, /\*\*< mutex\_time\_period \*/  { NULL }, /\*\*< device\_io\_dta \*/  { NULL, NULL, NULL, NULL, NULL, NULL }  /\*\*< \*p\_commonctl[IMPDRV\_INSTANCETABLE\_NUM] \*/  }; |
| **Description** | IMP Driver determines conversion of Instance table by this table.  Follows the st\_impdrv\_commonctl\_ins\_t structure. |
| **Remarks** | This variable is used only by its own sub-component. |

#### g\_hwrsc\_mng\_table

Table 5‑39: g\_hwrsc\_mng\_table

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  [st\_impdrv\_hwrsc\_mng\_t](#_st_impdrv_hwrsc_mng_t) g\_hwrsc\_mng\_table =  {  IMPDRV\_HWRSC\_UNUSED, /\*\*< Resource used state \*/  IMPDRV\_HWRSC\_UNUSED, /\*\*< Memory initialized state \*/  {  IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED,  IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED,  IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED,  IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED, IMPDRV\_HWRSC\_UNUSED  }, /\*\*< In-use status management \*/  {  { NULL }, { NULL }, { NULL }, { NULL },  { NULL }, { NULL }, { NULL }, { NULL },  { NULL }, { NULL }, { NULL }, { NULL },  { NULL }, { NULL }, { NULL }, { NULL }  } /\*\*< IMPDRV device handle \*/  }; |
| **Description** | IMP Driver determines conversion of register table by this table.  Follows the [st\_impdrv\_hwrsc\_mng\_t](#_st_impdrv_hwrsc_mng_t) structure. |
| **Remarks** | This variable is used only by its own sub-component. |

#### g\_impdrv\_cmn\_ctl\_chk

Table 5‑40: g\_impdrv\_cmn\_ctl\_chk

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  st\_impdrv\_commonctl\_chk\_t g\_impdrv\_cmn\_ctl\_chk =  {  0U, /\*\*< Checksum data for g\_impdrv\_cmn\_ctl\_ins \*/  { NULL }, /\*\*< Backup data of device\_io\_imptop \*/  }; |
| **Description** | Common control global check area.  Follows the st\_impdrv\_commonctl\_chk\_t structure. |
| **Remarks** | This variable is used only by its own sub-component. |

#### g\_hwrsc\_chk\_table

Table 5‑41: g\_hwrsc\_chk\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  st\_impdrv\_hwrsc\_chk\_t g\_hwrsc\_chk\_table =  {  0U, /\*\*< Checksum data for g\_hwrsc\_mng\_table \*/  }; |
| **Description** | Common control global check area.  Follows the st\_impdrv\_hwrsc\_chk\_t structure. |
| **Remarks** | This variable is used only by its own sub-component. |

### Core Control

None.

### OS Dependence Layer

None.

## Constants

### Definition

#### API Layer

Table 5‑42: Definition Values (API Layer)

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_CHK\_WORK\_ADDR\_ALIGN | (7U) | The work area address alignment check definition |
| IMPDRV\_COREMAP\_MAXID | (16U) | Number of elements in the core map array |
| IMPDRV\_IRQGROUP\_MAXID | (22U) | Core specification limits for IRQ groups |
| IMPDRV\_IRQMASK\_MAX | (9U) | Number of elements in the IRQ mask array |
| IMPDRV\_INNER\_FIXED\_VALUE | (22U) | Definition values for internal management |
| IMPDRV\_CLBRK\_ADDR\_INVALID | (0xFFFFFFFFU) | Invalid value of CL break address data |
| IMPDRV\_VDSP\_INT\_PROG\_MEM\_SIZE | (0x2000U) | Maximum size of the dsp\_fw |
| IMPDRV\_VDSP\_DTCM\_MEM\_SIZE | (0x40000U) | Maximum size of the dsp\_dtcm |
| IMPDRV\_VERSION\_MAJOR | - | Major version number of IMP driver  Refer to r\_impdrv\_version.h for the major version value. |
| IMPDRV\_VERSION\_MINOR | - | Minor version number of IMP driver  Refer to r\_impdrv\_version.h for the minor version value. |
| IMPDRV\_VERSION\_PATCH | - | Patch version number of IMP driver  Refer to r\_impdrv\_version.h for the patch version value. |
| IMPDRV\_HANDLE\_INVALID | ((impdrv\_ctrl\_handle\_t)NULL) | Invalid control handle value |

#### Common definition (All sub components)

Table 5‑43: Definition Values (Common definition)

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_STATIC | static | Static declaration of IMP driver for Normal build |
| IMPDRV\_UNUSED\_ARGS(a) | ((void)(a)) | Workaround for warning fix.  This is used in the developing. Will be removed eventually. |
| IMPDRV\_CHK\_MEM\_ALIGN | (3U) | Memory alignment check definition |
| IMPDRV\_CHK\_REG\_ALIGN | (3U) | Register alignment check definition |
| IMPDRV\_CHK\_CL\_MEM\_ALIGN | (3U) | CL Memory alignment check definition |
| IMPDRV\_CHK\_CACHE\_ALIGN | (63U) | Memory cache alignment check definition |
| IMPDRV\_CORE\_TYPE\_MAX | (11U) | Maximum value of Core type definition |
| IMPDRV\_DSP\_DEV\_NUM\_MAX | (8U) | num of max sub device for DSP core |

#### General Control

None.

#### Common Control

Table 5‑44: Definition Values (Common Control)

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_REG\_INTEN00 | (0x0020U) | Offset address of hardware register for INTEN00. |
| IMPDRV\_REG\_INTEN01 | (0x0024U) | Offset address of hardware register for INTEN01. |
| IMPDRV\_REG\_INTEN02 | (0x0028U) | Offset address of hardware register for INTEN02. |
| IMPDRV\_REG\_G00INTSEL | (0x0030U) | Offset address of hardware register for G00INTSEL. |
| IMPDRV\_REG\_G01INTSEL | (0x0034U) | Offset address of hardware register for G01INTSEL. |
| IMPDRV\_REG\_G02INTSEL | (0x0038U) | Offset address of hardware register for G02INTSEL. |
| IMPDRV\_REG\_INTEN10 | (0x0040U) | Offset address of hardware register for INTEN10. |
| IMPDRV\_REG\_INTEN11 | (0x0044U) | Offset address of hardware register for INTEN11. |
| IMPDRV\_REG\_INTEN12 | (0x0048U) | Offset address of hardware register for INTEN12. |
| IMPDRV\_REG\_G10INTSEL | (0x0050U) | Offset address of hardware register for G10INTSEL. |
| IMPDRV\_REG\_G11INTSEL | (0x0054U) | Offset address of hardware register for G11INTSEL. |
| IMPDRV\_REG\_G12INTSEL | (0x0058U) | Offset address of hardware register for G12INTSEL. |
| IMPDRV\_REG\_MINTEN | (0x00B0U) | Offset address of hardware register for MINTEN. |
| IMPDRV\_REG\_MG0INTSEL | (0x00B4U) | Offset address of hardware register for MG0INTSEL. |
| IMPDRV\_REG\_MG1INTSEL | (0x00B8U) | Offset address of hardware register for MG1INTSEL. |
| IMPDRV\_REG\_MG2INTSEL | (0x00BCU) | Offset address of hardware register for MG2INTSEL. |
| IMPDRV\_REG\_INTEN\_INIT\_VAL | (0x00000000U) | Initial value of interrupt enable register. |
| IMPDRV\_INTEN0\_CORE\_MAX | (11U) | Maximum number of cores for the Interrupt group 1. |
| IMPDRV\_INTEN1\_CORE\_MAX | (10U) | Maximum number of cores for the Interrupt group 2. |
| IMPDRV\_MINTEN\_CORE\_MAX | (21U) | Maximum number of cores for the Merge interrupt group. |
| IMPDRV\_GROUP\_MAX | (3U) | Maximum number of interrupt groups. |
| IMPDRV\_INSTANCETABLE\_NUM | (8U) | Maximum number of Instance number table |
| IMPDRV\_IRQCHTABLE\_NUM | (7U) | Maximum number of IRQ Channel table. |
| IMPDRV\_SYNCCTABLE\_NUM | (23U) | Num of SYNCC table |
| IMPDRV\_INTSTS\_BITNUM | (32U) | Bit width of Interrupt status register |
| IMPDRV\_REG\_INTSTS0 | (0x0010U) | Offset address of hardware register for IMPDRV\_REG\_INTSTS0 |
| IMPDRV\_REG\_INTSTS1 | (0x0014U) | Offset address of hardware register for IMPDRV\_REG\_INTSTS1 |
| IMPDRV\_REG\_INTSTS2 | (0x0018U) | Offset address of hardware register for IMPDRV\_REG\_INTSTS2 |

Table 5‑45: Definition Values (Common Control) [R-CarV3M / V3H / V3H\_2]

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_INTSTS\_BITNUM | (32U) | Bit width of Interrupt status register. |
| IMPDRV\_HWRSC\_TABLE\_NUM | (16U) | Maximum number of Resource tables. |
| IMPDRV\_REG\_ISR | (0x0100U) | Offset address of hardware register for ISR. |
| IMPDRV\_REG\_IMR | (0x010CU) | Offset address of hardware register for IMR. |
| IMPDRV\_REG\_G0INTSEL | (0x0110U) | Offset address of hardware register for G0INTSEL. |
| IMPDRV\_REG\_G1INTSEL | (0x0114U) | Offset address of hardware register for G1INTSEL. |
| IMPDRV\_REG\_G2INTSEL | (0x0118U) | Offset address of hardware register for G2INTSEL. |
| IMPDRV\_REG\_IMR1 | (0x0140U) | Offset address of hardware register for IMR1. |
| IMPDRV\_REG\_IMR2 | (0x0144U) | Offset address of hardware register for IMR2. |
| IMPDRV\_REG\_IMR3 | (0x0148U) | Offset address of hardware register for IMR3. |
| IMPDRV\_REG\_IMR4 | (0x014CU) | Offset address of hardware register for IMR4. |
| IMPDRV\_INSTANCETABLE\_NUM | (6U) | Maximum number of Instance number table. |
| IMPDRV\_IRQCHTABLE\_NUM | (5U) | Maximum number of IRQ Channel table. |
| IMPDRV\_HWRSC\_UNUSED | (0U) | Unused resources state. |
| IMPDRV\_HWRSC\_NAME\_MAX | (32U) | Maximum length of hardware resource name. |
| IMPDRV\_HWRSC\_INDEX\_IMP\_TOP | (0U) | Index number of IMP top resource. |
| IMPDRV\_REG\_WPR | (0x8000U) | Offset address of hardware register for WPR. |
| IMPDRV\_REG\_RAMTSTR | (0x8120U) | Offset address of hardware register for RAMTSTR. |
| IMPDRV\_MASK\_L16BIT | (0x0000FFFFU) | Bit mask for Lower 16 bits |
| IMPDRV\_REG\_PROTECT\_MASK | (0x80000000U) | Bitmask for Memory protection mode. |
| IMPDRV\_REG\_GROUP\_INIT\_VAL | (0x00000000U) | Initial value of group interrupt select register. |
| IMPDRV\_REG\_RAMTSTR | (0x8120U) | Offset address of hardware register for RAMTSTR. |
| IMPDRV\_REG\_WPR | (0x8000U) | Offset address of hardware register for WPR. |

Table 5‑46: Definition Values (Common Control) [R-CarV3M]

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_REG\_IMR\_INIT\_VAL | (0xE00003FFU) | Initial value of interrupt mask register. |
| IMPDRV\_INTEN\_CORE\_MAX | (10U) | Maximum number of cores for the Interrupt. |
| IMPDRV\_SYNCCTABLE\_NUM | (16U) | Maximum number of SYNCC table. |
| IMPDRV\_REG\_MB\_MEM\_INIT\_ODD | (0x0000002A) | Multi-Bank memory odd initialization value. |
| IMPDRV\_REG\_MB\_MEM\_INIT\_EVEN | (0x00000055) | Multi-Bank memory even initialization value. |
| IMPDRV\_GROUP\_MAX | (5U) | Maximum number of interrupt groups. |

Table 5‑47: Definition Values (Common Control) [R-CarV3H]

|  |  |  |
| --- | --- | --- |
|  |  |  |
| IMPDRV\_REG\_IMR\_INIT\_VAL | (0xE003FFFFU) | Initial value of interrupt mask register. |
| IMPDRV\_INTEN\_CORE\_MAX | (18U) | Maximum number of cores for the Interrupt. |
| IMPDRV\_SYNCCTABLE\_NUM | (30U) | Maximum number of SYNCC table. |
| IMPDRV\_REG\_MB\_MEM\_INIT\_ODD | (0x0000AAAAU) | Multi-Bank memory odd initialization value. |
| IMPDRV\_REG\_MB\_MEM\_INIT\_EVEN | (0x00005555U) | Multi-Bank memory even initialization value. |
| IMPDRV\_GROUP\_MAX | (5U) | Maximum number of interrupt groups. |

Table 5‑48: Definition Values (Common Control) [R-CarV3H\_2]

|  |  |  |
| --- | --- | --- |
|  |  |  |
| IMPDRV\_REG\_IMR\_INIT\_VAL | (0xE007FFFFU) | Initial value of interrupt mask register. |
| IMPDRV\_INTEN\_CORE\_MAX | (19U) | Maximum number of cores for the Interrupt. |
| IMPDRV\_SYNCCTABLE\_NUM | (27U) | Maximum number of SYNCC table. |
| IMPDRV\_REG\_MB\_MEM\_INIT\_ODD | (0x0000AAAAU) | Multi-Bank memory odd initialization value. |
| IMPDRV\_REG\_MB\_MEM\_INIT\_EVEN | (0x00005555U) | Multi-Bank memory even initialization value. |
| IMPDRV\_REG\_SRAMFMR | (0x0314U) | Offset address of hardware register for SRAMFMR. |
| IMPDRV\_REG\_PROTECT\_EDC | (0x00000000U) | EDC mode register value. |
| IMPDRV\_REG\_PROTECT\_ECC | (0x80000000U) | ECC mode register value. |
| IMPDRV\_GROUP\_MAX | (5U) | Maximum number of interrupt groups. |
| IMPDRV\_DUMMY\_UINT32 | (0xFFFFFFFFU) | Uint32\_t dummy value |

Table 5-49 Definition values (Common Control) [R-CarV4H]

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_INTSTS\_BITNUM | (32U) | Bit width of Interrupt status register |
| IMPDRV\_HWRSC\_TABLE\_NUM | (16U) | Maximum number of Resource tables |
| IMPDRV\_REG\_INTEN00 | (0x0020U) | Offset address of hardware register for INTEN00 |
| IMPDRV\_REG\_INTEN01 | (0x0024U) | Offset address of hardware register for INTEN01 |
| IMPDRV\_REG\_INTEN02 | (0x0028U) | Offset address of hardware register for INTEN02 |
| IMPDRV\_REG\_G00INTSEL | (0x0030U) | Offset address of hardware register for G00INTSEL |
| IMPDRV\_REG\_G01INTSEL | (0x0034U) | Offset address of hardware register for G01INTSEL |
| IMPDRV\_REG\_G02INTSEL | (0x0038U) | Offset address of hardware register for G02INTSEL |
| IMPDRV\_REG\_INTSTS0 | (0x0010U) | Offset address of hardware register for IMPDRV\_REG\_INTSTS0 |
| IMPDRV\_REG\_INTEN\_INIT\_VAL | (0x00000000U) | Initial value of interrupt enable register |
| IMPDRV\_INTEN\_CORE\_MAX | (18U) | Maximum number of cores for the Interrupt. |
| IMPDRV\_GROUP\_MAX | (5U) | Maximum number of interrupt groups. |
| IMPDRV\_INSTANCETABLE\_NUM | (4U) | Maximum number of Instance number table |
| IMPDRV\_IRQCHTABLE\_NUM | (3U) | Maximum number of IRQ Channel table |
| IMPDRV\_SYNCCTABLE\_NUM | (29U) | Maximum number of SYNCC table |
| IMPDRV\_DUMMY\_UINT32 | (0xFFFFFFFFU) | Uint32\_t dummy value |
| IMPDRV\_REG\_DSP0CT | (0x00004010U) | Offset address of hardware register for DSP0CT |
| IMPDRV\_REG\_DSP1CT | (0x00004020U) | Offset address of hardware register for DSP1CT |
| IMPDRV\_REG\_DSP2CT | (0x00004030U) | Offset address of hardware register for DSP2CT |
| IMPDRV\_REG\_DSP3CT | (0x00004040U) | Offset address of hardware register for DSP3CT |
| IMPDRV\_DSPCORE\_NUM | (4U) | Maximum number of DSP cores |
| IMPDRV\_REG\_DSPNCT\_VAL | (0x0003FFF3U) | The setting value of DSPnCT (V4M) |
| IMPDRV\_REG\_DSPNCT\_VAL | (0x0003FFFFU) | The setting value of DSPnCT (V4H) |
| IMPDRV\_DSP\_CORE\_NUM | (4U) | Maximum number of SYNCC table |
| IMPDRV\_DSP\_SUB\_DEV\_NUM\_MAX | (8U) | Maximum number of SUB DEV table |
| IMPDRV\_HWRSC\_UNUSED | (0U) | Unused resources state |
| IMPDRV\_HWRSC\_NAME\_MAX | (32U) | Maximum length of hardware resource name |
| IMPDRV\_HWRSC\_INDEX\_IMP\_TOP | (0U) | Index number of IMP top resource |
| IMPDRV\_HWRSC\_INIT\_SPMC0\_IDX | (1U) | SPMC0 index number of the init table. |
| IMPDRV\_HWRSC\_INIT\_SPMI0\_IDX | (0U) | SPMI0 index number of the init table. |
| IMPDRV\_HWRSC\_SPM\_INIT\_TBL\_MAX | (2U) | Maximum index number of the init table. |
| IMPDRV\_HWRSC\_SPM\_PSET\_TBL\_MAX | (5U) | Maximum index number of the preset table. |
| IMPDRV\_HWRSC\_INIT\_SPMC0\_IDX | (1U) | SPMC0 index number of the init table. |

#### Core Control

Table 5‑49: Definition Values (Core Control) [R-CarV3M / V3H / V3H\_2]

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_MASK\_U8BIT | (0xFF000000U) | Bit mask for Upper 8 bits |
| IMPDRV\_MASK\_U9\_16BIT | (0x00FF0000U) | Bit mask for Upper 9-16 bits |
| IMPDRV\_MASK\_U16BIT | (0xFFFF0000U) | Bit mask for Upper 16 bits |
| IMPDRV\_MASK\_L8BIT | (0x000000FFU) | Bit mask for Lower 8 bits |
| IMPDRV\_MASK\_BIT15 | (0x00008000U) | Bit mask for Only 15 bit |
| IMPDRV\_INIT\_CL\_ADDR | (0xFFFFFFFFU) | Initial value of CL address data |
| IMPDRV\_CALLBACK\_CODE\_DEF | (-1) | Callback code default value |
| IMPDRV\_EXEPARAM\_MAX | (3U) | Number of extended parameter arrays |
| IMPDRV\_CORE\_NUM\_MAX | (8U) | Maximum value of Core number definition |
| IMPDRV\_CB\_RET\_MAX | (18U) | Maximum value of Call back reason |
| IMPDRV\_OFFSET\_4BYTE | (4U) | For 4 byte offset calculation |
| IMPDRV\_SHIFT\_8BIT | (8U) | For 8 bit shift calculation |
| IMPDRV\_SHIFT\_16BIT | (16U) | For 16 bit shift calculation |
| IMPDRV\_SHIFT\_24BIT | (24U) | For 24 bit shift calculation |
| IMPDRV\_SYNCC\_REGNUM | (4U) | Array size for SYNCC register |
| IMPDRV\_IMP\_MEM\_ALIGN\_BUSCHK | (127U) | Memory alignment for Bus interface check. |
| IMPDRV\_IMP\_MEM\_ALIGN\_BUSCHK | (127U) | Memory alignment for Bus interface check. |

Table 5‑50: Definition Values (Core Control)

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_MASK\_U8BIT | (0xFF000000U) | Bit mask for Upper 8 bits. |
| IMPDRV\_MASK\_U9\_16BIT | (0x00FF0000U) | Bit mask for Upper 9-16 bits. |
| IMPDRV\_MASK\_U16BIT | (0xFFFF0000U) | Mask to extract the upper 16 bits. |
| IMPDRV\_MASK\_L8BIT | (0x000000FFU) | Bit mask for Lower 8 bits. |
| IMPDRV\_MASK\_BIT15 | (0x00008000U) | Bit mask for Only 15 bit. |
| IMPDRV\_INIT\_CL\_ADDR | (0xFFFFFFFFU) | Initial value of CL address data. |
| IMPDRV\_CALLBACK\_CODE\_DEF | (-1) | Callback code default value. |
| IMPDRV\_EXEPARAM\_MAX | (3U) | Maximum number of execution parameters. |
| IMPDRV\_CORE\_NUM\_MAX | (8U) | Maximum value of Core number definition |
| IMPDRV\_CB\_RET\_MAX | (16U) | Maximum value of Call back reason |
| IMPDRV\_OFFSET\_4BYTE | (4U) | For 4 byte offset calculation |
| IMPDRV\_SHIFT\_8BIT | (8U) | For 8 bit shift calculation |
| IMPDRV\_SHIFT\_16BIT | (16U) | For 16 bit shift calculation |
| IMPDRV\_SHIFT\_24BIT | (24U) | For 24 bit shift calculation |
| IMPDRV\_SYNCC\_REGNUM | (4U) | Array size for SYNCC register. |
| IMPDRV\_IMP\_CORENUM\_VAL | (4U) | Maximum number of cores for IMP. |
| IMPDRV\_REG\_IMP\_VCR | (0x0004U) | Offset address of VCR register for IMP. |
| IMPDRV\_REG\_IMP\_CNF | (0x0008U) | Offset address of CNF register for IMP. |
| IMPDRV\_REG\_IMP\_IFCFG | (0x0018U) | Offset address of CNFG register for IMP. |
| IMPDRV\_REG\_IMP\_IFCTL | (0x001CU) | Offset address of IFCTL register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR0 | (0x0040U) | Offset address of SYNCCR0 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR1 | (0x0044U) | Offset address of SYNCCR1 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR2 | (0x0048U) | Offset address of SYNCCR2 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR3 | (0x004CU) | Offset address of SYNCCR03 register for IMP. |
| IMPDRV\_REG\_IMP\_INTSTS | (0x0010U) | Offset address of INTSTS register for IMP. |
| IMPDRV\_REG\_IMP\_INTEN | (0x0014U) | Offset address of INTEN register for IMP. |
| IMPDRV\_REG\_IMP\_PSA | (0x0020U) | Offset address of PSA register for IMP. |
| IMPDRV\_REG\_IMP\_HMPTR | (0x0514U) | Offset address of HMPTR register for IMP. |
| IMPDRV\_REG\_IMP\_HMDATA | (0x0518U) | Offset address of HMDATA register for IMP. |
| IMPDRV\_REG\_IMP\_HM1PTR | (0x0594U) | Offset address of HM1PTR register for IMP. |
| IMPDRV\_REG\_IMP\_HM1DATA | (0x0598U) | Offset address of HM1DATA register for IMP. |
| IMPDRV\_REG\_IMP\_MEM\_FUNC\_SA | (0x0B78U) | Offset address of SA register for IMP. |
| IMPDRV\_IMP\_VCR | (0x00700000U) | Hardware version value for IMP. |
| IMPDRV\_IMP\_CNF\_VAL | (0x00000001U) | CNF\_VAL register value for IMP. |
| IMPDRV\_IMP\_CNF\_SWRST | (0x80000000U) | CNF\_SWRST register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_EXE | (0x00000001U) | EXE register value for IMP. |
| IMPDRV\_IMP\_IFCFG\_VAL | (0x010000CCU) | IFCFG\_VAL register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_ENDIAN | (0x22020200U) | ENDIAN register value for IMP. |
| IMPDRV\_IMP\_INTSTS\_CLR | (IMPDRV\_IMP\_INTSTS\_TRAP | IMPDRV\_IMP\_INTSTS\_IER | IMPDRV\_IMP\_INTSTS\_INT | IMPDRV\_IMP\_INTSTS\_WUP | IMPDRV\_IMP\_INTSTS\_HPINT | IMPDRV\_IMP\_INTSTS\_APIPINT) | CLR register value for IMP. |
| IMPDRV\_IMP\_HMPTR\_VAL | (0x87FFU) | HMPTR\_VAL register value for IMP. |
| IMPDRV\_IMP\_HMDATA\_VAL | (0x0000U) | HMDATA\_VAL register value for IMP. |
| IMPDRV\_IMP\_MEM\_FUNC\_SA\_VAL | (0x00FFU) | SA\_VAL register value for IMP. |
| IMPDRV\_IMP\_INTSTS\_MASKCPU | (0x10000000U) | MASKCPU interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_APIPINT | (0x00000001U) | APIPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_HPINT | (0x00000002U) | HPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_WUP | (0x04000000U) | WUP interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_INT | (0x00000020U) | INT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_IER | (0x00000080U) | IER interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_TRAP | (0x00000040U) | TRAP interrupt enable registration. |
| IMPDRV\_OCV\_CORENUM\_VAL | (8U) | Maximum number of cores for OCV. |
| IMPDRV\_REG\_OCV\_VCR0 | (0x0000U) | Offset address of VCR register for OCV. |
| IMPDRV\_REG\_OCV\_RSTR | (0x0008U) | Offset address of RSTR register for OCV. |
| IMPDRV\_REG\_OCV\_CR | (0x000CU) | Offset address of CR register for OCV. |
| IMPDRV\_REG\_OCV\_SR0 | (0x0010U) | Offset address of SR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SR1 | (0x0014U) | Offset address of SR1 register for OCV. |
| IMPDRV\_REG\_OCV\_SCR1 | (0x0018U) | Offset address of SCR1 register for OCV. |
| IMPDRV\_REG\_OCV\_ICR1 | (0x001CU) | Offset address of ICR1 register for OCV. |
| IMPDRV\_REG\_OCV\_IMR1 | (0x0020U) | Offset address of IMR1 register for OCV. |
| IMPDRV\_REG\_OCV\_MCR0 | (0x0040U) | Offset address of MCR0 register for OCV. |
| IMPDRV\_REG\_OCV\_DLSAR | (0x0180U) | Offset address of DLSAR register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR0 | (0x04C0U) | Offset address of SYNCCR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR1 | (0x04C4U) | Offset address of SYNCCR1 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR2 | (0x04C8U) | Offset address of SYNCCR2 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR3 | (0x04CCU) | Offset address of SYNCCR3 register for OCV. |
| IMPDRV\_REG\_OCV\_MEMINITR | (0x00F8U) | Offset address of MEMINITR register for OCV. |
| IMPDRV\_REG\_OCV\_LWM | (0x021CU) | Offset address of LWM register for OCV. |
| IMPDRV\_OCV\_VCR | (0x00000005U) | Hardware version value for OCV. |
| IMPDRV\_OCV\_RESET\_STATUS\_VAL | (0x00F10000U) | RESET\_STATUS value for OCV. |
| IMPDRV\_OCV\_WM\_INIT\_VAL | (0x00F1U) | Working Memory init value for OCV. |
| IMPDRV\_OCV\_8KBSTART\_VAL | (0x0000U) | 8KBSTART value for OCV. |
| IMPDRV\_OCV\_8KBNEXT\_VAL | (0x2000U) | 8KBNEXT value for OCV. |
| IMPDRV\_OCV\_OFST\_START\_VAL | (0xC000U) | OFST\_START value for OCV. |
| IMPDRV\_OCV\_OFST\_END\_VAL | (0xE000U) | OFST\_END value for OCV. |
| IMPDRV\_OCV\_1KB\_VAL | (0x80064100U) | 1KB value for OCV. |
| IMPDRV\_OCV\_MCR0\_INIT\_VAL | (0x01000000U) | MCR0 value for OCV. |
| IMPDRV\_OCV\_CR\_PS | (0x00000001U) | PS register value for OCV. |
| IMPDRV\_OCV\_RSTR\_SWRST | (0x00000001U) | SWRST register value for OCV. |
| IMPDRV\_OCV\_RSTR\_CLR | (0x00000000U) | CLR register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL0 | (0x00040000U) | DCBANKSEL0 register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL1 | (0x05000000U) | DCBANKSEL1 register value for OCV. |
| IMPDRV\_OCV\_SR1\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_PBCOVF | (0x00000008U) | PBCOVF interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_SBO0ME | (0x00000010U) | SBO0ME interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_USIER | (0x00001000U) | USIER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_USINT | (0x00002000U) | USINT interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_WUPCOVF | (0x00004000U) | WUPCOVF interrupt enable registration. |
| IMPDRV\_OCV\_OFFSET\_32B | (32U) | Offset 32byte for OCV. |
| IMPDRV\_DMA\_CORENUM\_VAL | (4U) | Maximum number of cores for DMA. |
| IMPDRV\_DMA\_CORENUM0MAIN | (0U) | DMA Core0 Main thread identification value. |
| IMPDRV\_DMA\_CORENUM0SUB | (1U) | DMA Core0 Sub thread identification value. |
| IMPDRV\_DMA\_CORENUM1MAIN | (2U) | DMA Core1 Main thread identification value. |
| IMPDRV\_DMA\_CORENUM1SUB | (3U) | DMA Core1 Sub thread identification value. |
| IMPDRV\_REG\_DMA\_VCR | (0x0000U) | Offset address of VCR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR | (0x0004U) | Offset address of SCTLR register for DMA. |
| IMPDRV\_REG\_DMA\_SR | (0x0008U) | Offset address of SR register for DMA. |
| IMPDRV\_REG\_DMA\_SCR | (0x000CU) | Offset address of SCR register for DMA. |
| IMPDRV\_REG\_DMA\_SER | (0x0010U) | Offset address of VCR register for DMA. |
| IMPDRV\_REG\_DMA\_IMR | (0x0014U) | Offset address of IMR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for DMA. |
| IMPDRV\_REG\_DMA\_CLSAR | (0x0028U) | Offset address of CLSAR register for DMA. |
| IMPDRV\_REG\_DMA\_SR1 | (0x0030U) | Offset address of SR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR0 | (0x00E8U) | Offset address of SYNCCR0 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR1 | (0x00ECU) | Offset address of SYNCCR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR2 | (0x00F0U) | Offset address of SYNCCR2 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR3 | (0x00F4U) | Offset address of SYNCCR3 register for DMA. |
| IMPDRV\_DMA\_VCR | (0x18071916U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_SWRST | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_CLR | (0x00000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR1\_PS | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_REG\_DMA\_THREAD\_OFFSET | (0x00001000U) | H/W Register offset for DMA sub-thread. |
| IMPDRV\_DMA\_SR\_TEND | (0x00000001U) | SA\_TEND interrupt enable registration. |
| IMPDRV\_DMA\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_DMA\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_DMA\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_DMA\_SR\_WUP | (0x00000080U) | WUP interrupt enable registration. |
| IMPDRV\_DMA\_RAMTSTR | (0x00D0U) | Offset address of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_MASK | (0x8000U) | Bitmask of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_LOOPTIME\_VAL | (8U) | Read count for register. |
| IMPDRV\_PSC\_CORENUM\_VAL | (2U) | Maximum number of cores for PSC. |
| IMPDRV\_REG\_PSC\_VCR | (0x0000U) | Offset address of VCR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR0 | (0x0004U) | Offset address of CTLR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SR | (0x0008U) | Offset address of SR register for PSC. |
| IMPDRV\_REG\_PSC\_SCR | (0x000CU) | Offset address of SCR register for PSC. |
| IMPDRV\_REG\_PSC\_SER | (0x0010U) | Offset address of SER register for PSC. |
| IMPDRV\_REG\_PSC\_IMR | (0x0014U) | Offset address of IMR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SR1 | (0x003CU) | Offset address of SR1 register for PSC. |
| IMPDRV\_REG\_PSC\_CLSAR | (0x0038U) | Offset address of CLSAR register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR0 | (0x0058U) | Offset address of SYNCCR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR1 | (0x0060U) | Offset address of SYNCCR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR2 | (0x0064U) | Offset address of SYNCCR2 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR3 | (0x0068U) | Offset address of SYNCCR3 register for PSC. |
| IMPDRV\_PSC\_VCR | (0x18082420U) | Hardware version value for PSC. |
| IMPDRV\_PSC\_SCTLR0\_SWRST | (0x80000000U) | SWRST register value for IMP. |
| IMPDRV\_PSC\_SCTLR0\_CLR | (0x00000000U) | CLR register value for IMP. |
| IMPDRV\_PSC\_SCTLR1\_CLE | (0x00000001U) | CLE register value for IMP. |
| IMPDRV\_PSC\_SR\_TEND | (0x00000001U) | TEND interrupt enable registration. |
| IMPDRV\_PSC\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_PSC\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_PSC\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_PSC\_SR\_WUP | (0x00010000U) | WUP interrupt enable registration. |
| IMPDRV\_CNN\_CORENUM\_VAL | (3U) | Maximum number of cores for CNN. |
| IMPDRV\_REG\_CNN\_VCR | (0x0000U) | Offset address of VCR register for CNN. |
| IMPDRV\_CNN\_VCR | (0x00030200U) | Hardware version value for CNN. |
| IMPDRV\_REG\_CNN\_SWRST | (0x0008U) | Offset address of hardware register for SWRST. |
| IMPDRV\_REG\_CNN\_SR | (0x0010U) | Offset address of hardware register for SR. |
| IMPDRV\_REG\_CNN\_SRE | (0x0014U) | Offset address of hardware register for SRE. |
| IMPDRV\_REG\_CNN\_SRC | (0x0018U) | Offset address of hardware register for SRC. |
| IMPDRV\_REG\_CNN\_SRM | (0x001CU) | Offset address of hardware register for SRM. |
| IMPDRV\_REG\_CNN\_SACL | (0x0104U) | Offset address of hardware register for SACL. |
| IMPDRV\_REG\_CNN\_SCLP | (0x0108U) | Offset address of hardware register for SCLP. |
| IMPDRV\_REG\_CNN\_SYNCCR0 | (0x0900U) | Offset address of hardware register for SYNCCR0. |
| IMPDRV\_REG\_CNN\_SYNCCR1 | (0x0904U) | Offset address of hardware register for SYNCCR1. |
| IMPDRV\_REG\_CNN\_SYNCCR2 | (0x0908U) | Offset address of hardware register for S  SYNCCR2. |
| IMPDRV\_REG\_CNN\_SYNCCR3 | (0x090CU) | Offset address of hardware register for SYNCCR3. |
| IMPDRV\_CNN\_CNF\_SWRST | (0x00000001U) | SWRST register value for CNN. |
| IMPDRV\_CNN\_CNF\_CLR | (0x00000000U) | CLR register value for CNN. |
| IMPDRV\_CNN\_SR\_CLBUSY | (0x00004000U) | CLBSY register value for CNN. |
| IMPDRV\_CNN\_SR\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_CNN\_SR\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_CNN\_SR\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_CNN\_SR\_MSCO | (0x00000008U) | MSCO interrupt enable registration. |
| IMPDRV\_CNN\_SR\_WUPCOVF | (0x00000010U) | WUPCOVF interrupt enable registration. |
| IMPDRV\_CNN\_SCLP\_START | (0x00000001U) | CNN\_SCLP\_START register value for CNN. |
| IMPDRV\_SYNCC\_REGNUM | (4U) | Array size for SYNCC register. |
| IMPDRV\_EXEPARAM\_OFF | (1U) | OFF value for Extended parameter |
| IMPDRV\_EXEPARAM\_ON | (2U) | ON value for Extended parameter |

Table 5‑51: Definition Values (Core Control) [R-CarV3M]

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_IMP\_CORENUM\_VAL | (4U) | Maximum number of cores for IMP. |
| IMPDRV\_REG\_IMP\_VCR | (0x0004U) | Offset address of VCR register for IMP. |
| IMPDRV\_REG\_IMP\_CNF | (0x0008U) | Offset address of CNF register for IMP. |
| IMPDRV\_REG\_IMP\_IFCFG | (0x0018U) | Offset address of CNFG register for IMP. |
| IMPDRV\_REG\_IMP\_IFCTL | (0x001CU) | Offset address of IFCTL register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR0 | (0x0040U) | Offset address of SYNCCR0 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR1 | (0x0044U) | Offset address of SYNCCR1 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR2 | (0x0048U) | Offset address of SYNCCR2 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR3 | (0x004CU) | Offset address of SYNCCR03 register for IMP. |
| IMPDRV\_REG\_IMP\_INTSTS | (0x0010U) | Offset address of INTSTS register for IMP. |
| IMPDRV\_REG\_IMP\_INTEN | (0x0014U) | Offset address of INTEN register for IMP. |
| IMPDRV\_REG\_IMP\_PSA | (0x0020U) | Offset address of PSA register for IMP. |
| IMPDRV\_REG\_IMP\_HMPTR | (0x0514U) | Offset address of HMPTR register for IMP. |
| IMPDRV\_REG\_IMP\_HMDATA | (0x0518U) | Offset address of HMDATA register for IMP. |
| IMPDRV\_REG\_IMP\_HM1PTR | (0x0594U) | Offset address of HM1PTR register for IMP. |
| IMPDRV\_REG\_IMP\_HM1DATA | (0x0598U) | Offset address of HM1DATA register for IMP. |
| IMPDRV\_REG\_IMP\_MEM\_FUNC\_SA | (0x0B78U) | Offset address of SA register for IMP. |
| IMPDRV\_REG\_IMP\_APSASP | (0x0100U) | Offset address of APSASP register for IMP |
| IMPDRV\_REG\_IMP\_APSBSP | (0x0104U) | Offset address of APSBSP register for IMP |
| IMPDRV\_REG\_IMP\_APDSP | (0x0108U) | Offset address of APSBSP register for IMP |
| IMPDRV\_REG\_IMP\_APLNG | (0x010CU) | Offset address of APLNG register for IMP |
| IMPDRV\_REG\_IMP\_APDLY | (0x0110U) | Offset address of APDLY register for IMP |
| IMPDRV\_REG\_IMP\_APMAG | (0x0114U) | Offset address of APMAG register for IMP |
| IMPDRV\_REG\_IMP\_APSIZE\_SA | (0x0118U) | Offset address of APSIZE\_SA register for IMP |
| IMPDRV\_REG\_IMP\_APSIZE\_SB | (0x011CU) | Offset address of APSIZE\_SB register for IMP |
| IMPDRV\_REG\_IMP\_APSIZE\_DST | (0x0120U) | Offset address of APSIZE\_DST register for IMP |
| IMPDRV\_REG\_IMP\_APCMD | (0x0128U) | Offset address of APCMD register for IMP |
| IMPDRV\_REG\_IMP\_APCLPX | (0x012CU) | Offset address of APCLPX register for IMP |
| IMPDRV\_REG\_IMP\_APCFG | (0x013CU) | Offset address of APCFG register for IMP |
| IMPDRV\_REG\_IMP\_IPFUN | (0x0800U) | Offset address of IPFUN register for IMP |
| IMPDRV\_REG\_IMP\_IPFUN2 | (0x0804U) | Offset address of IPFUN2 register for IMP |
| IMPDRV\_REG\_IMP\_IPFORM | (0x0808U) | Offset address of IPFORM register for IMP |
| IMPDRV\_REG\_IMP\_CNST | (0x0814U) | Offset address of CNST register for IMP |
| IMPDRV\_REG\_IMP\_BINTHR | (0x0818U) | Offset address of BINTHR register for IMP |
| IMPDRV\_REG\_IMP\_BINTHR2 | (0x081CU) | Offset address of BINTHR2 register for IMP |
| IMPDRV\_REG\_IMP\_KNLMSK | (0x0820U) | Offset address of KNLMSK register for IMP |
| IMPDRV\_REG\_IMP\_KNLMSK2 | (0x0824U) | Offset address of KNLMSK2 register for IMP |
| IMPDRV\_REG\_IMP\_LMCTL | (0x0828U) | Offset address of LMCTL register for IMP |
| IMPDRV\_REG\_IMP\_LABCNT | (0x082CU) | Offset address of LABCNT register for IMP |
| IMPDRV\_REG\_IMP\_COEFF02 | (0x0830U) | Offset address of COEFF02 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF35 | (0x0834U) | Offset address of COEFF35 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF68 | (0x0838U) | Offset address of COEFF68 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF911 | (0x083CU) | Offset address of COEFF911 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1214 | (0x0840U) | Offset address of COEFF1214 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF15 | (0x0844U) | Offset address of COEFF15 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1820 | (0x0848U) | Offset address of COEFF1820 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF2123 | (0x084CU) | Offset address of COEFF2123 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF24 | (0x0850U) | Offset address of COEFF24 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF02H | (0x0854U) | Offset address of COEFF02H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF35H | (0x0858U) | Offset address of COEFF35H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF68H | (0x085CU) | Offset address of COEFF68H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF911H | (0x0860U) | Offset address of COEFF911H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1214H | (0x0864U) | Offset address of COEFF1214H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1517H | (0x0868U) | Offset address of COEFF1517H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1820H | (0x086CU) | Offset address of COEFF1820H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF2123H | (0x0870U) | Offset address of COEFF2123H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF24H | (0x0874U) | Offset address of COEFF24H register for IMP |
| IMPDRV\_REG\_IMP\_PFFTASEL1 | (0x0A80U) | Offset address of PFFTASEL1 register for IMP |
| IMPDRV\_REG\_IMP\_PFFTAMSK | (0x0A88U) | Offset address of PFFTAMSK register for IMP |
| IMPDRV\_REG\_IMP\_PFFTBMSK | (0x0A94U) | Offset address of PFFTBMSK register for IMP |
| IMPDRV\_IMP\_VCR | (0x00600000U) | Hardware version value for IMP. |
| IMPDRV\_IMP\_CNF\_VAL | (0x00000001U) | CNF\_VAL register value for IMP. |
| IMPDRV\_IMP\_CNF\_SWRST | (0x80000000U) | CNF\_SWRST register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_EXE | (0x00000001U) | EXE register value for IMP. |
| IMPDRV\_IMP\_IFCFG\_VAL | (0x010010CCU) | IFCFG\_VAL register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_ENDIAN | (0x22020200U) | ENDIAN register value for IMP. |
| IMPDRV\_IMP\_HMPTR\_VAL | (0x87FFU) | HMPTR\_VAL register value for IMP. |
| IMPDRV\_IMP\_HMDATA\_VAL | (0x0000U) | HMDATA\_VAL register value for IMP. |
| IMPDRV\_IMP\_MEM\_FUNC\_SA\_VAL | (0x00FFU) | SA\_VAL register value for IMP. |
| IMPDRV\_IMP\_INTSTS\_MASKCPU | (0x10000000U) | MASKCPU interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_APIPINT | (0x00000001U) | APIPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_HPINT | (0x00000002U) | HPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_INT | (0x00000020U) | INT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_IER | (0x00000080U) | IER interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_TRAP | (0x00000040U) | TRAP interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_CLR | IMPDRV\_IMP\_INTSTS\_TRAP|IMPDRV\_IMP\_INTSTS\_IER|IMPDRV\_IMP\_INTSTS\_INT|IMPDRV\_IMP\_INTSTS\_HPINT|IMPDRV\_IMP\_INTSTS\_APIPINT) | CLR register value for IMP. |
| IMPDRV\_IMP\_APCMD\_EX | (0x80000000U) | EX bit in APCMD Register |
| IMPDRV\_IMP\_APCMD\_ACSCNT\_SA | (0x00080000U) | ACSCNT\_SA bit in APCMD Register |
| IMPDRV\_IMP\_APCMD\_ACSCNT\_DS | (0x00010000U) | ACSCNT\_DS bit in APCMD Register |
| IMPDRV\_IMP\_MEM\_SIZE\_BUSCHK | (512U) | Memory size for Bus interface check |
| IMPDRV\_IMP\_MEM\_ALIGN\_BUSCHK | (127U) | Memory alignment for Bus interface check |
| IMPDRV\_IMP\_MEM\_MAX\_ADRS\_BUSCHK | (0xFFFFFFFFU) | Maximum memory address for Bus interface check |
| IMPDRV\_IMP\_SEND\_TIMEOUT\_BUSCHK | (0U) | Timeout period for send queue of bus interface check |
| IMPDRV\_IMP\_REG\_MAX\_ADRS\_CNFCHK | (0x0001FFFFU) | End of offset address for ConfRegCheck of IMP |
| IMPDRV\_CNN\_CORENUM\_VAL | (1U) | Maximum number of cores for CNN. |
| IMPDRV\_REG\_CNN\_VCR | (0x0000U) | Offset address of VCR register for CNN. |
| IMPDRV\_CNN\_VCR | (0x00030101U) | Hardware version value for CNN. |
| IMPDRV\_REG\_CNN\_SWRST | (0x0008U) | Offset address of hardware register for SWRST. |
| IMPDRV\_REG\_CNN\_SR | (0x0010U) | Offset address of hardware register for SR. |
| IMPDRV\_REG\_CNN\_SRE | (0x0014U) | Offset address of hardware register for SRE. |
| IMPDRV\_REG\_CNN\_SRC | (0x0018U) | Offset address of hardware register for SRC. |
| IMPDRV\_REG\_CNN\_SRM | (0x001CU) | Offset address of hardware register for SRM. |
| IMPDRV\_REG\_CNN\_CLSAR | (0x0080U) | Offset address of hardware register for CLSAR. |
| IMPDRV\_REG\_CNN\_SCLP | (0x0084U) | Offset address of hardware register for SCLP. |
| IMPDRV\_REG\_CNN\_SYNCCR0 | (0x0900U) | Offset address of hardware register for SYNCCR0. |
| IMPDRV\_REG\_CNN\_SYNCCR1 | (0x0904U) | Offset address of hardware register for SYNCCR1. |
| IMPDRV\_REG\_CNN\_SYNCCR2 | (0x0908U) | Offset address of hardware register for YNCCR2. |
| IMPDRV\_REG\_CNN\_SYNCCR3 | (0x090CU) | Offset address of hardware register for MG2ISYNCCR3NTSEL |
| IMPDRV\_CNN\_CNF\_SWRST | (0x00000001U) | SWRST register value for CNN. |
| IMPDRV\_CNN\_CNF\_CLR | (0x00000000U) | CLR register value for CNN. |
| IMPDRV\_CNN\_SR\_CLBUSY | (0x00002000U) | CLBSY register value for CNN. |
| IMPDRV\_CNN\_SR\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_CNN\_SR\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_CNN\_SR\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_CNN\_SR\_MSCO | (0x00000008U) | MSCO interrupt enable registration. |
| IMPDRV\_CNN\_SCLP\_START | (0x00000001U) | CNN\_SCLP\_START register value for CNN. |
| IMPDRV\_CNN\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of CNN. |
| IMPDRV\_DMA\_CORENUM\_VAL | (2U) | Maximum number of cores for DMA. |
| IMPDRV\_DMA\_CORENUM0MAIN | (0U) | DMA Core 0 Main thread identification value. |
| IMPDRV\_DMA\_CORENUM0SUB | (1U) | DMA Core 0 Sub thread identification value. |
| IMPDRV\_REG\_DMA\_VCR | (0x0000U) | Offset address of VCR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR | (0x0004U) | Offset address of SCTLR register for DMA. |
| IMPDRV\_REG\_DMA\_SR | (0x0008U) | Offset address of SR register for DMA. |
| IMPDRV\_REG\_DMA\_SCR | (0x000CU) | Offset address of SCR register for DMA. |
| IMPDRV\_REG\_DMA\_SER | (0x0010U) | Offset address of VCR register for DMA. |
| IMPDRV\_REG\_DMA\_IMR | (0x0014U) | Offset address of IMR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for DMA. |
| IMPDRV\_REG\_DMA\_CLSAR | (0x0028U) | Offset address of CLSAR register for DMA. |
| IMPDRV\_REG\_DMA\_SR1 | (0x0030U) | Offset address of SR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR0 | (0x00E8U) | Offset address of SYNCCR0 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR1 | (0x00ECU) | Offset address of SYNCCR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR2 | (0x00F0U) | Offset address of SYNCCR2 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR3 | (0x00F4U) | Offset address of SYNCCR3 register for DMA. |
| IMPDRV\_DMA\_VCR | (0x17021420U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_SWRST | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_CLR | (0x00000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR1\_PS | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_REG\_DMA\_THREAD\_OFFSET | (0x00000800U) | H/W Register offset for DMA sub-thread. |
| IMPDRV\_DMA\_SR\_TEND | (0x00000001U) | /\*\*<SA\_TEND interrupt enable registration. |
| IMPDRV\_DMA\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_DMA\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_DMA\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_DMA\_SER\_FIX | (0x0000F380U) | Status Enable Registers that are always bit 1. |
| IMPDRV\_DMA\_RAMTSTR | (0x00D0U) | Offset address of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_MASK | (0x8000U) | Bit mask of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_LOOPTIME\_VAL | (8U) | read count for register. |
| IMPDRV\_DMA\_MB\_INFO\_SIZE1 | (3U) | Mult-Bank memory init register info1. |
| IMPDRV\_DMA\_MB\_INFO\_SIZE2 | (7U) | Mult-Bank memory init register info2. |
| IMPDRV\_DMA\_MB\_INFO\_SIZE3 | (5U) | Mult-Bank memory init register info3. |
| IMPDRV\_DMA\_MB\_WRITE\_NUM\_ODD | (3U) | Odd mult-Bank memory init register write number of times. |
| IMPDRV\_DMA\_MB\_WRITE\_NUM\_EVEN | (4U) | Even mult-Bank memory init register write number of times. |
| IMPDRV\_REG\_DMA\_IMGSIZER | (0x0094U) | Offset address of IMGSIZER register for DMA. |
| IMPDRV\_DMA\_IMGSIZER\_VAL | (0x00800001U) | IMGSIZER register value for DMA. |
| IMPDRV\_REG\_DMA\_FCR0 | (0x00A0U) | Offset address of FCR0 register for DMA. |
| IMPDRV\_DMA\_FCR0\_VAL | (0x000000CCU) | FCR0 register value for DMA. |
| IMPDRV\_REG\_DMA\_FCR1 | (0x00ACU) | Offset address of FCR1 register for DMA. |
| IMPDRV\_DMA\_FCR1\_VAL | (0x90000000U) | FCR1 register value for DMA. |
| IMPDRV\_REG\_DMA\_S0SAR | (0x0040U) | Offset address of S0SAR register for DMA. |
| IMPDRV\_DMA\_S0SAR\_ODD\_BASE\_ADDR | (0xED020000U) | S0SAR register value for DMA odd bank. |
| IMPDRV\_DMA\_S0SAR\_EVEN\_BASE\_ADDR | (0xED000000U) | S0SAR register value for DMA even bank. |
| IMPDRV\_DMA\_S0SAR\_OFFSET | (0x00040000U) | S0SAR register offset for DMA even bank. |
| IMPDRV\_REG\_DMA\_S0STR | (0x0044U) | Offset address of S0STR register for DMA. |
| IMPDRV\_DMA\_S0STR\_VAL | (0x00000020U) | S0STR register value for DMA. |
| IMPDRV\_REG\_DMA\_S0DATAR | (0x004CU) | Offset address of S0DATAR register for DMA. |
| IMPDRV\_DMA\_S0DATAR\_VAL | (0x00000000U) | S0DATAR register value for DMA. |
| IMPDRV\_REG\_DMA\_S0CR | (0x0050U) | Offset address of S0CR register for DMA. |
| IMPDRV\_DMA\_S0CR\_VAL | (0x80000003U) | S0CR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1SAR | (0x0060U) | Offset address of S1SAR register for DMA. |
| IMPDRV\_DMA\_S1SAR\_VAL | (0x00000000U) | S1SAR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1STR | (0x0064U) | Offset address of S1STR register for DMA. |
| IMPDRV\_DMA\_S1STR\_VAL | (0x00000020U) | S1STR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1DATAR | (0x006CU) | Offset address of S1DATAR register for DMA. |
| IMPDRV\_DMA\_S1DATAR\_VAL | (0x00000000U) | S1DATAR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1CR | (0x0070U) | Offset address of S1CR register for DMA. |
| IMPDRV\_DMA\_S1CR\_VAL | (0x00000003U) | S1CR register value for DMA. |
| IMPDRV\_REG\_DMA\_D0SAR | (0x0080U) | Offset address of D0SAR register for DMA. |
| IMPDRV\_REG\_DMA\_D0STR | (0x0084U) | Offset address of D0STR register for DMA. |
| IMPDRV\_DMA\_D0STR\_VAL | (0x00000020U) | D0STR register value for DMA. |
| IMPDRV\_REG\_DMA\_D0CR | (0x0090U) | Offset address of D0CR register for DMA. |
| IMPDRV\_DMA\_D0CR\_VAL | (0x00000003U) | D0CR register value for DMA. |
| IMPDRV\_REG\_DMA\_DSWPR | (0x0038U) | Offset address of DSWPR register for DMA. |
| IMPDRV\_DMA\_DSWPR\_VAL | (0x00000000U) | DSWPR register value for DMA. |
| IMPDRV\_REG\_DMA\_TSCR | (0x0020U) | Offset address of TSCR register for DMA. |
| IMPDRV\_DMA\_TSCR\_VAL | (0x00330003U) | TSCR register value for DMA. |
| IMPDRV\_DMA\_SCTLR0\_MB\_VAL | (0x00000001U) | SCTLR0 multi-bank register value for DMA. |
| IMPDRV\_DMA\_MEM\_SIZE\_BUSCHK | (512U) | Memory size for Bus interface check. |
| IMPDRV\_DMA\_MEM\_ALIGN\_BUSCHK | (127U) | Memory alignment for Bus interface check. |
| IMPDRV\_DMA\_MEM\_MAX\_ADRS\_BUSCHK | (0xFFFFFFFFU) | Maximum memory address for Bus interface check. |
| IMPDRV\_DMA\_SEND\_TIMEOUT\_BUSCHK | (0U) | Timeout period for send queue of bus interface check. |
| IMPDRV\_DMA\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of DMA. |
| IMPDRV\_OCV\_CORENUM\_VAL | (2U) | Maximum number of cores for OCV. |
| IMPDRV\_OCV\_OFFSET\_32B | (32U) | Offset 32byte for OCV. |
| IMPDRV\_REG\_OCV\_VCR0 | (0x0000U) | Offset address of VCR register for OCV. |
| IMPDRV\_REG\_OCV\_RSTR | (0x0008U) | Offset address of RSTR register for OCV. |
| IMPDRV\_REG\_OCV\_CR | (0x000CU) | Offset address of CR register for OCV. |
| IMPDRV\_REG\_OCV\_SR0 | (0x0010U) | Offset address of SR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SR1 | (0x0014U) | Offset address of SR1 register for OCV. |
| IMPDRV\_REG\_OCV\_SCR1 | (0x0018U) | Offset address of SCR1 register for OCV. |
| IMPDRV\_REG\_OCV\_ICR1 | (0x001CU) | Offset address of ICR1 register for OCV. |
| IMPDRV\_REG\_OCV\_IMR1 | (0x0020U) | Offset address of IMR1 register for OCV. |
| IMPDRV\_REG\_OCV\_MCR0 | (0x0040U) | Offset address of MCR0 register for OCV. |
| IMPDRV\_REG\_OCV\_DLSAR | (0x0180U) | Offset address of DLSAR register for OCV |
| IMPDRV\_REG\_OCV\_SYNCCR0 | (0x04C0U) | Offset address of SYNCCR0 register for O |
| IMPDRV\_REG\_OCV\_SYNCCR1 | (0x04C4U) | Offset address of SYNCCR1 register for O |
| IMPDRV\_REG\_OCV\_SYNCCR2 | (0x04C8U) | Offset address of SYNCCR2 register for O |
| IMPDRV\_REG\_OCV\_SYNCCR3 | (0x04CCU) | Offset address of SYNCCR3 register for O |
| IMPDRV\_REG\_OCV\_MEMINITR | (0x00F8U) | Offset address of MEMINITR register for |
| IMPDRV\_REG\_OCV\_LWM | (0x021CU) | Offset address of LWM register for OCV. |
| IMPDRV\_OCV\_VCR | (0x00000004U) | Hardware version value for OCV. |
| IMPDRV\_OCV\_RESET\_STATUS\_VAL | (0x10000U) | RESET\_STATUS value for OCV. |
| IMPDRV\_OCV\_0X001\_VAL | (0x0001U) | 0X001 value for OCV. |
| IMPDRV\_OCV\_8KBSTART\_VAL | (0x0000U) | 8KBSTART value for OCV. |
| IMPDRV\_OCV\_8KBNEXT\_VAL | (0x2000U) | 8KBNEXT value for OCV. |
| IMPDRV\_OCV\_OFST\_START\_VAL | (0xC000U) | OFST\_START value for OCV. |
| IMPDRV\_OCV\_OFST\_END\_VAL | (0xE000U) | OFST\_END value for OCV. |
| IMPDRV\_OCV\_1KB\_VAL | (0x80064100U) | 1KB value for OCV. |
| IMPDRV\_OCV\_MCR0\_INIT\_VAL | (0x01000000U) | MCR0 value for OCV. |
| IMPDRV\_OCV\_CR\_PS | (0x00000001U) | PS register value for OCV. |
| IMPDRV\_OCV\_RSTR\_SWRST | (0x00000001U) | SWRST register value for OCV. |
| IMPDRV\_OCV\_RSTR\_CLR | (0x00000000U) | CLR register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL0 | (0x00040000U) | DCBANKSEL0register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL1 | (0x05000000U) | DCBANKSEL1 register value for OCV. |
| IMPDRV\_OCV\_SR1\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_PBCOVF | (0x00000008U) | PBCOVF interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_SBO0ME | (0x00000010U) | SBO0ME interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_USIER | (0x00001000U) | USIER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_USINT | (0x00002000U) | USINT interrupt enable registration. |
| IMPDRV\_PSC\_CORENUM\_VAL | (1U) | Maximum number of cores for PSC. |
| IMPDRV\_REG\_OCV\_SR2 | (0x0024U) | Offset address of SR2 register for OCV |
| IMPDRV\_REG\_OCV\_SCR2 | (0x0028U) | Offset address of SCR2 register for OCV. |
| IMPDRV\_REG\_OCV\_ICR2 | (0x002CU) | Offset address of ICR2 register for OCV |
| IMPDRV\_OCV\_SR1\_UDIPSBRK | (0x10000000U) | UDIPSBRK interrupt enable registration |
| IMPDRV\_OCV\_SR1\_UDIVSBRK | (0x20000000U) | UDIVSBRK interrupt enable registration. |
| IMPDRV\_OCV\_SR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in SR2 register. |
| IMPDRV\_OCV\_SCR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in SCR2 register |
| IMPDRV\_OCV\_ICR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in ICR2 register |
| IMPDRV\_OCV\_REG\_MAX\_ADRS\_CNFCHK | 0x0000FFFFU | End of offset address for ConfRegCheck of OCV. |
| IMPDRV\_REG\_PSC\_VCR | (0x0000U) | Offset address of VCR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR0 | (0x0004U) | Offset address of CTLR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SR | (0x0008U) | Offset address of SR register for PSC. |
| IMPDRV\_REG\_PSC\_SCR | (0x000CU) | Offset address of SCR register for PSC. |
| IMPDRV\_REG\_PSC\_SER | (0x0010U) | Offset address of SER register for PSC. |
| IMPDRV\_REG\_PSC\_IMR | (0x0014U) | Offset address of IMR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SR1 | (0x003CU) | Offset address of SR1 register for PSC. |
| IMPDRV\_REG\_PSC\_CLSAR | (0x0038U) | Offset address of CLSAR register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR0 | (0x0058U) | Offset address of SYNCCR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR1 | (0x0060U) | Offset address of SYNCCR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR2 | (0x0064U) | Offset address of SYNCCR2 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR3 | (0x0068U) | Offset address of SYNCCR3 register for PSC. |
| IMPDRV\_PSC\_VCR | (0x17020121U) | Hardware version value for PSC. |
| IMPDRV\_PSC\_SCTLR0\_SWRST | (0x80000000U) | SWRST register value for IMP. |
| IMPDRV\_PSC\_SCTLR0\_CLR | (0x00000000U) | CLR register value for IMP. |
| IMPDRV\_PSC\_SCTLR1\_CLE | (0x00000001U) | CLE register value for IMP. |
| IMPDRV\_PSC\_SR\_TEND | (0x00000001U) | TEND interrupt enable registration. |
| IMPDRV\_PSC\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_PSC\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_PSC\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_PSC\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of PSC. |
| IMPDRV\_EXEPARAM\_INVALID | (0U) | Invalid value for Extended parameter |

Table 5‑52: Definition Values (Core Control) [R-CarV3H]

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_IMP\_CORENUM\_VAL | (5U) | Maximum number of cores for IMP. |
| IMPDRV\_REG\_IMP\_VCR | (0x0004U) | Offset address of VCR register for IMP. |
| IMPDRV\_REG\_IMP\_CNF | (0x0008U) | Offset address of CNF register for IMP. |
| IMPDRV\_REG\_IMP\_IFCFG | (0x0018U) | Offset address of CNFG register for IMP. |
| IMPDRV\_REG\_IMP\_IFCTL | (0x001CU) | Offset address of IFCTL register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR0 | (0x0040U) | Offset address of SYNCCR0 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR1 | (0x0044U) | Offset address of SYNCCR1 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR2 | (0x0048U) | Offset address of SYNCCR2 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR3 | (0x004CU) | Offset address of SYNCCR03 register for IMP. |
| IMPDRV\_REG\_IMP\_INTSTS | (0x0010U) | Offset address of INTSTS register for IMP. |
| IMPDRV\_REG\_IMP\_INTEN | (0x0014U) | Offset address of INTEN register for IMP. |
| IMPDRV\_REG\_IMP\_PSA | (0x0020U) | Offset address of PSA register for IMP. |
| IMPDRV\_REG\_IMP\_HMPTR | (0x0514U) | Offset address of HMPTR register for IMP. |
| IMPDRV\_REG\_IMP\_HMDATA | (0x0518U) | Offset address of HMDATA register for IMP. |
| IMPDRV\_REG\_IMP\_HM1PTR | (0x0594U) | Offset address of HM1PTR register for IMP. |
| IMPDRV\_REG\_IMP\_HM1DATA | (0x0598U) | Offset address of HM1DATA register for IMP. |
| IMPDRV\_REG\_IMP\_MEM\_FUNC\_SA | (0x0B78U) | Offset address of SA register for IMP. |
| IMPDRV\_REG\_IMP\_APSASP | (0x0100U) | Offset address of APSASP register for IMP |
| IMPDRV\_REG\_IMP\_APSBSP | (0x0104U) | Offset address of APSBSP register for IMP |
| IMPDRV\_REG\_IMP\_APDSP | (0x0108U) | Offset address of APSBSP register for IMP |
| IMPDRV\_REG\_IMP\_APLNG | (0x010CU) | Offset address of APLNG register for IMP |
| IMPDRV\_REG\_IMP\_APDLY | (0x0110U) | Offset address of APDLY register for IMP |
| IMPDRV\_REG\_IMP\_APMAG | (0x0114U) | Offset address of APMAG register for IMP |
| IMPDRV\_REG\_IMP\_APSIZE\_SA | (0x0118U) | Offset address of APSIZE\_SA register for IMP |
| IMPDRV\_REG\_IMP\_APSIZE\_SB | (0x011CU) | Offset address of APSIZE\_SB register for IMP |
| IMPDRV\_REG\_IMP\_APSIZE\_DST | (0x0120U) | Offset address of APSIZE\_DST register for IMP |
| IMPDRV\_REG\_IMP\_APCMD | (0x0128U) | Offset address of APCMD register for IMP |
| IMPDRV\_REG\_IMP\_APCLPX | (0x012CU) | Offset address of APCLPX register for IMP |
| IMPDRV\_REG\_IMP\_APCFG | (0x013CU) | Offset address of APCFG register for IMP |
| IMPDRV\_REG\_IMP\_IPFUN | (0x0800U) | Offset address of IPFUN register for IMP |
| IMPDRV\_REG\_IMP\_IPFUN2 | (0x0804U) | Offset address of IPFUN2 register for IMP |
| IMPDRV\_REG\_IMP\_IPFORM | (0x0808U) | Offset address of IPFORM register for IMP |
| IMPDRV\_REG\_IMP\_CNST | (0x0814U) | Offset address of CNST register for IMP |
| IMPDRV\_REG\_IMP\_BINTHR | (0x0818U) | Offset address of BINTHR register for IMP |
| IMPDRV\_REG\_IMP\_BINTHR2 | (0x081CU) | Offset address of BINTHR2 register for IMP |
| IMPDRV\_REG\_IMP\_KNLMSK | (0x0820U) | Offset address of KNLMSK register for IMP |
| IMPDRV\_REG\_IMP\_KNLMSK2 | (0x0824U) | Offset address of KNLMSK2 register for IMP |
| IMPDRV\_REG\_IMP\_LMCTL | (0x0828U) | Offset address of LMCTL register for IMP |
| IMPDRV\_REG\_IMP\_LABCNT | (0x082CU) | Offset address of LABCNT register for IMP |
| IMPDRV\_REG\_IMP\_COEFF02 | (0x0830U) | Offset address of COEFF02 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF35 | (0x0834U) | Offset address of COEFF35 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF68 | (0x0838U) | Offset address of COEFF68 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF911 | (0x083CU) | Offset address of COEFF911 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1214 | (0x0840U) | Offset address of COEFF1214 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF15 | (0x0844U) | Offset address of COEFF15 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1820 | (0x0848U) | Offset address of COEFF1820 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF2123 | (0x084CU) | Offset address of COEFF2123 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF24 | (0x0850U) | Offset address of COEFF24 register for IMP |
| IMPDRV\_REG\_IMP\_COEFF02H | (0x0854U) | Offset address of COEFF02H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF35H | (0x0858U) | Offset address of COEFF35H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF68H | (0x085CU) | Offset address of COEFF68H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF911H | (0x0860U) | Offset address of COEFF911H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1214H | (0x0864U) | Offset address of COEFF1214H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1517H | (0x0868U) | Offset address of COEFF1517H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF1820H | (0x086CU) | Offset address of COEFF1820H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF2123H | (0x0870U) | Offset address of COEFF2123H register for IMP |
| IMPDRV\_REG\_IMP\_COEFF24H | (0x0874U) | Offset address of COEFF24H register for IMP |
| IMPDRV\_REG\_IMP\_PFFTASEL1 | (0x0A80U) | Offset address of PFFTASEL1 register for IMP |
| IMPDRV\_REG\_IMP\_PFFTAMSK | (0x0A88U) | Offset address of PFFTAMSK register for IMP |
| IMPDRV\_REG\_IMP\_PFFTBMSK | (0x0A94U) | Offset address of PFFTBMSK register for IMP |
| IMPDRV\_IMP\_VCR | (0x00600000U) | Hardware version value for IMP. |
| IMPDRV\_IMP\_CNF\_VAL | (0x00000001U) | CNF\_VAL register value for IMP. |
| IMPDRV\_IMP\_CNF\_SWRST | (0x80000000U) | CNF\_SWRST register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_EXE | (0x00000001U) | EXE register value for IMP. |
| IMPDRV\_IMP\_IFCFG\_VAL | (0x010010CCU) | IFCFG\_VAL register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_ENDIAN | (0x22020200U) | ENDIAN register value for IMP. |
| IMPDRV\_IMP\_HMPTR\_VAL | (0x87FFU) | HMPTR\_VAL register value for IMP |
| IMPDRV\_IMP\_HMDATA\_VAL | (0x0000U) | HMDATA\_VAL register value for IMP. |
| IMPDRV\_IMP\_MEM\_FUNC\_SA\_VAL | (0x00FFU) | SA\_VAL register value for IMP. |
| IMPDRV\_IMP\_INTSTS\_MASKCPU | (0x10000000U) | MASKCPU interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_APIPINT | (0x00000001U) | APIPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_HPINT | (0x00000002U) | HPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_WUP | (0x04000000U) | WUP interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_INT | (0x00000020U) | INT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_IER | (0x00000080U) | IER interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_TRAP | (0x00000040U) | TRAP interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_CLR | (IMPDRV\_IMP\_INTSTS\_TRAP | IMPDRV\_IMP\_INTSTS\_IER | IMPDRV\_IMP\_INTSTS\_INT | IMPDRV\_IMP\_INTSTS\_WUP | IMPDRV\_IMP\_INTSTS\_HPINT | IMPDRV\_IMP\_INTSTS\_APIPINT) | CLR register value for IMP. |
| IMPDRV\_IMP\_APCMD\_EX | (0x80000000U) | EX bit in APCMD Register |
| IMPDRV\_IMP\_APCMD\_ACSCNT\_SA | (0x00080000U) | ACSCNT\_SA bit in APCMD Register |
| IMPDRV\_IMP\_APCMD\_ACSCNT\_DS | (0x00010000U) | ACSCNT\_DS bit in APCMD Register |
| IMPDRV\_IMP\_MEM\_SIZE\_BUSCHK | (512U) | Memory size for Bus interface check |
| IMPDRV\_IMP\_MEM\_ALIGN\_BUSCHK (127U) | Memory alignment for Bus interface check |  |
| IMPDRV\_IMP\_MEM\_MAX\_ADRS\_BUSCHK | (0xFFFFFFFFU) | Maximum memory address for Bus interface check |
| IMPDRV\_IMP\_SEND\_TIMEOUT\_BUSCHK | (0U) | Timeout period for send queue of bus interface check |
| IMPDRV\_IMP\_REG\_MAX\_ADRS\_CNFCHK | (0x0001FFFFU) | End of offset address for ConfRegCheck of IMP |
| IMPDRV\_CNN\_CORENUM\_VAL | (1U) | Maximum number of cores for CNN. |
| IMPDRV\_REG\_CNN\_VCR | (0x0000U) | Offset address of VCR register for CNN. |
| IMPDRV\_CNN\_VCR | (0x00030000U) | Hardware version value for CNN. |
| IMPDRV\_REG\_CNN\_SWRST | (0x0008U) | Offset address of hardware register for SWRST. |
| IMPDRV\_REG\_CNN\_SR | (0x0010U) | Offset address of hardware register for SR. |
| IMPDRV\_REG\_CNN\_SRE | (0x0014U) | Offset address of hardware register for SRE. |
| IMPDRV\_REG\_CNN\_SRC | (0x0018U) | Offset address of hardware register for SRC. |
| IMPDRV\_REG\_CNN\_SRM | (0x001CU) | Offset address of hardware register for SRM. |
| IMPDRV\_REG\_CNN\_CLSAR | (0x0080U) | Offset address of hardware register for CLSAR. |
| IMPDRV\_REG\_CNN\_SCLP | (0x0084U) | Offset address of hardware register for SCLP. |
| IMPDRV\_REG\_CNN\_SYNCCR0 | (0x0900U) | Offset address of hardware register for SYNCCR0. |
| IMPDRV\_REG\_CNN\_SYNCCR1 | (0x0904U) | Offset address of hardware register for SYNCCR1. |
| IMPDRV\_REG\_CNN\_SYNCCR2 | (0x0908U) | Offset address of hardware register for YNCCR2. |
| IMPDRV\_REG\_CNN\_SYNCCR3 | (0x090CU) | Offset address of hardware register for MG2ISYNCCR3NTSEL. |
| IMPDRV\_CNN\_CNF\_SWRST | (0x00000001U) | SWRST register value for CNN. |
| IMPDRV\_CNN\_CNF\_CLR | (0x00000000U) | CLR register value for CNN. |
| IMPDRV\_CNN\_SR\_CLBUSY | (0x00002000U) | CLBSY register value for CNN. |
| IMPDRV\_CNN\_SR\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_CNN\_SR\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_CNN\_SR\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_CNN\_SR\_MSCO | (0x00000008U) | MSCO interrupt enable registration. |
| IMPDRV\_CNN\_SR\_WUPCOVF | (0x00004000U) | WUPCOVF interrupt enable registration. |
| IMPDRV\_CNN\_SCLP\_START | (0x00000001U) | CNN\_SCLP\_START register value for CNN. |
| IMPDRV\_CNN\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of CNN. |
| IMPDRV\_DMA\_CORENUM\_VAL | (4U) | Maximum number of cores for DMA. |
| IMPDRV\_DMA\_CORENUM0MAIN | (0U) | DMA Core 0 Main thread identification value. |
| IMPDRV\_DMA\_CORENUM0SUB | (1U) | DMA Core 0 Sub thread identification value. |
| IMPDRV\_DMA\_CORENUM1MAIN | (2U) | Offset address of VCR register for DMA. |
| IMPDRV\_DMA\_CORENUM1SUB | (3U) | DMA Core 1 Sub thread identification value. |
| IMPDRV\_REG\_DMA\_VCR | (0x0000U) | Offset address of VCR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR | (0x0004U) | Offset address of SCTLR register for DMA. |
| IMPDRV\_REG\_DMA\_SR | (0x0008U) | Offset address of SR register for DMA. |
| IMPDRV\_REG\_DMA\_SCR | (0x000CU) | Offset address of SCR register for DMA. |
| IMPDRV\_REG\_DMA\_SER | (0x0010U) | Offset address of SER register for DMA. |
| IMPDRV\_REG\_DMA\_IMR | (0x0014U) | Offset address of IMR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for DMA. |
| IMPDRV\_REG\_DMA\_CLSAR | (0x0028U) | Offset address of CLSAR register for DMA. |
| IMPDRV\_REG\_DMA\_SR1 | (0x0030U) | Offset address of SR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR0 | (0x00E8U) | Offset address of SYNCCR0 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR1 | (0x00ECU) | Offset address of SYNCCR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR2 | (0x00F0U) | Offset address of SYNCCR2 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR3 | (0x00F4U) | Offset address of SYNCCR3 register for DMA. |
| IMPDRV\_DMA\_VCR | (0x17021420U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_SWRST | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_CLR | (0x00000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR1\_PS | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_REG\_DMA\_THREAD\_OFFSET | (0x00000800U) | H/W Register offset for DMA sub-thread. |
| IMPDRV\_DMA\_SR\_TEND | (0x00000001U) | SA\_TEND interrupt enable registration. |
| IMPDRV\_DMA\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_DMA\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_DMA\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_DMA\_SR\_WUP | (0x00000080U) | WUP interrupt enable registration. |
| IMPDRV\_DMA\_SER\_FIX | (0x0000F300U) | Status Enable Registers that are always bit 1. |
| IMPDRV\_DMA\_RAMTSTR | (0x00D0U) | Offset address of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_MASK | (0x8000U) | Bit mask of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_LOOPTIME\_VAL | (8U) | read count for register. |
| IMPDRV\_DMA\_MB\_INFO\_SIZE1 | (3U) | Mult-Bank memory init register info1. |
| IMPDRV\_DMA\_MB\_INFO\_SIZE2 | (7U) | Mult-Bank memory init register info2. |
| IMPDRV\_DMA\_MB\_INFO\_SIZE3 | (5U) | Mult-Bank memory init register info3. |
| IMPDRV\_DMA\_MB\_WRITE\_NUM\_ODD | (8U) | Odd mult-Bank memory init register write number of times. |
| IMPDRV\_DMA\_MB\_WRITE\_NUM\_EVEN | (8U) | Even mult-Bank memory init register write number of times. |
| IMPDRV\_REG\_DMA\_IMGSIZER | (0x0094U) | Offset address of IMGSIZER register for DMA. |
| IMPDRV\_DMA\_IMGSIZER\_VAL | (0x00800001U) | IMGSIZER register value for DMA. |
| IMPDRV\_REG\_DMA\_FCR0 | (0x00A0U) | Offset address of FCR0 register for DMA. |
| IMPDRV\_DMA\_FCR0\_VAL | (0x000000CCU) | FCR0 register value for DMA. |
| IMPDRV\_REG\_DMA\_FCR1 | (0x00ACU) | Offset address of FCR1 register for DMA. |
| IMPDRV\_DMA\_FCR1\_VAL | (0x90000000U) | FCR1 register value for DMA. |
| IMPDRV\_REG\_DMA\_S0SAR | (0x0040U) | Offset address of S0SAR register for DMA. |
| IMPDRV\_DMA\_S0SAR\_ODD\_BASE\_ADDR | (0xED020000U) | S0SAR register value for DMA odd bank. |
| IMPDRV\_DMA\_S0SAR\_EVEN\_BASE\_ADDR | (0xED000000U) | S0SAR register value for DMA even bank. |
| IMPDRV\_DMA\_S0SAR\_OFFSET | (0x00040000U) | S0SAR register offset for DMA even bank. |
| IMPDRV\_REG\_DMA\_S0STR | (0x0044U) | Offset address of S0STR register for DMA. |
| IMPDRV\_DMA\_S0STR\_VAL | (0x00000020U) | S0STR register value for DMA. |
| IMPDRV\_REG\_DMA\_S0DATAR | (0x004CU) | Offset address of S0DATAR register for DMA. |
| IMPDRV\_DMA\_S0DATAR\_VAL | (0x00000000U) | S0DATAR register value for DMA. |
| IMPDRV\_REG\_DMA\_S0CR | (0x0050U) | Offset address of S0CR register for DMA. |
| IMPDRV\_DMA\_S0CR\_VAL | (0x80000003U) | S0CR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1SAR | (0x0060U) | Offset address of S1SAR register for DMA. |
| IMPDRV\_DMA\_S1SAR\_VAL | (0x00000000U) | S1SAR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1STR | (0x0064U) | Offset address of S1STR register for DMA. |
| IMPDRV\_DMA\_S1STR\_VAL | (0x00000020U) | S1STR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1DATAR | (0x006CU) | Offset address of S1DATAR register for DMA. |
| IMPDRV\_DMA\_S1DATAR\_VAL | (0x00000000U) | S1DATAR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1CR | (0x0070U) | Offset address of S1CR register for DMA. |
| IMPDRV\_DMA\_S1CR\_VAL | (0x00000003U) | S1CR register value for DMA. |
| IMPDRV\_REG\_DMA\_D0SAR | (0x0080U) | Offset address of D0SAR register for DMA. |
| IMPDRV\_REG\_DMA\_D0STR | (0x0084U) | Offset address of D0STR register for DMA. |
| IMPDRV\_DMA\_D0STR\_VAL | (0x00000020U) | D0STR register value for DMA. |
| IMPDRV\_REG\_DMA\_D0CR | (0x0090U) | Offset address of D0CR register for DMA. |
| IMPDRV\_DMA\_D0CR\_VAL | (0x00000003U) | D0CR register value for DMA. |
| IMPDRV\_REG\_DMA\_DSWPR | (0x0038U) | Offset address of DSWPR register for DMA. |
| IMPDRV\_DMA\_DSWPR\_VAL | (0x00000000U) | DSWPR register value for DMA. |
| IMPDRV\_REG\_DMA\_TSCR | (0x0020U) | Offset address of TSCR register for DMA. |
| IMPDRV\_DMA\_TSCR\_VAL | (0x00330003U) | TSCR register value for DMA. |
| IMPDRV\_DMA\_SCTLR0\_MB\_VAL | (0x00000001U) | SCTLR0 multi-bank register value for DMA. |
| IMPDRV\_DMA\_MEM\_SIZE\_BUSCHK | (512U) | Memory size for Bus interface check. |
| IMPDRV\_DMA\_MEM\_ALIGN\_BUSCHK | (127U) | Memory alignment for Bus interface check. |
| IMPDRV\_DMA\_MEM\_MAX\_ADRS\_BUSCHK | (0xFFFFFFFFU) | Maximum memory address for Bus interface check. |
| IMPDRV\_DMA\_SEND\_TIMEOUT\_BUSCHK | (0U) | Timeout period for send queue of bus interface check. |
| IMPDRV\_DMA\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of DMA. |
| IMPDRV\_OCV\_CORENUM\_VAL | (5U) | Maximum number of cores for OCV. |
| IMPDRV\_OCV\_OFFSET\_32B | (32U) | Offset 32byte for OCV. |
| IMPDRV\_REG\_OCV\_VCR0 | (0x0000U) | Offset address of VCR register for OCV. |
| IMPDRV\_REG\_OCV\_RSTR | (0x0008U) | Offset address of RSTR register for OCV. |
| IMPDRV\_REG\_OCV\_CR | (0x000CU) | Offset address of CR register for OCV. |
| IMPDRV\_REG\_OCV\_SR0 | (0x0010U) | Offset address of SR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SR1 | (0x0014U) | Offset address of SR1 register for OCV. |
| IMPDRV\_REG\_OCV\_SCR1 | (0x0018U) | Offset address of SCR1 register for OCV. |
| IMPDRV\_REG\_OCV\_ICR1 | (0x001CU) | Offset address of ICR1 register for OCV. |
| IMPDRV\_REG\_OCV\_IMR1 | (0x0020U) | Offset address of IMR1 register for OCV. |
| IMPDRV\_REG\_OCV\_MCR0 | (0x0040U) | Offset address of MCR0 register for OCV. |
| IMPDRV\_REG\_OCV\_DLSAR | (0x0180U) | Offset address of DLSAR register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR0 | (0x04C0U) | Offset address of SYNCCR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR1 | (0x04C4U) | Offset address of SYNCCR1 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR2 | (0x04C8U) | Offset address of SYNCCR2 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR3 | (0x04CCU) | Offset address of SYNCCR3 register for OCV. |
| IMPDRV\_REG\_OCV\_MEMINITR | (0x00F8U) | Offset address of MEMINITR register for OCV. |
| IMPDRV\_REG\_OCV\_LWM | (0x021CU) | Offset address of LWM register for OCV. |
| IMPDRV\_OCV\_VCR | (0x00000004U) | Hardware version value for OCV. |
| IMPDRV\_OCV\_RESET\_STATUS\_VAL | (0x10000U) | RESET\_STATUS value for OCV. |
| IMPDRV\_OCV\_0X001\_VAL | (0x0001U) | 0X001 value for OCV. |
| IMPDRV\_OCV\_8KBSTART\_VAL | (0x0000U) | 8KBSTART value for OCV. |
| IMPDRV\_OCV\_8KBNEXT\_VAL | (0x2000U) | 8KBNEXT value for OCV. |
| IMPDRV\_OCV\_OFST\_START\_VAL | (0xC000U) | OFST\_START value for OCV. |
| IMPDRV\_OCV\_OFST\_END\_VAL | (0xE000U) | OFST\_END value for OCV. |
| IMPDRV\_OCV\_1KB\_VAL | (0x80064100U) | 1KB value for OCV. |
| IMPDRV\_OCV\_MCR0\_INIT\_VAL | (0x01000000U) | MCR0 value for OCV. |
| IMPDRV\_OCV\_CR\_PS | (0x00000001U) | PS register value for OCV. |
| IMPDRV\_OCV\_RSTR\_SWRST | (0x00000001U) | SWRST register value for OCV. |
| IMPDRV\_OCV\_RSTR\_CLR | (0x00000000U) | CLR register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL0 | (0x00040000U) | DCBANKSEL0register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL1 | (0x05000000U) | DCBANKSEL1 register value for OCV. |
| IMPDRV\_OCV\_SR1\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_PBCOVF | (0x00000008U) | PBCOVF interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_SBO0ME | (0x00000010U) | SBO0ME interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_USIER | (0x00001000U) | USIER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_USINT | (0x00002000U) | USINT interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_WUPCOVF | (0x00004000U) | WUPCOVF interrupt enable registration. |
| IMPDRV\_REG\_OCV\_SR2 | (0x0024U) | Offset address of SR2 register for OCV |
| IMPDRV\_REG\_OCV\_SCR2 | (0x0028U) | Offset address of SCR2 register for OCV. |
| IMPDRV\_REG\_OCV\_ICR2 | (0x002CU) | Offset address of ICR2 register for OCV |
| IMPDRV\_OCV\_REG\_MAX\_ADRS\_CNFCHK | 0x0000FFFFU | End of offset address for ConfRegCheck of OCV. |
| IMPDRV\_OCV\_SR1\_UDIPSBRK | (0x10000000U) | UDIPSBRK interrupt enable registration |
| IMPDRV\_OCV\_SR1\_UDIVSBRK | (0x20000000U) | UDIVSBRK interrupt enable registration. |
| IMPDRV\_OCV\_SR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in SR2 register. |
| IMPDRV\_OCV\_SCR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in SCR2 register |
| IMPDRV\_OCV\_ICR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in ICR2 register |
| IMPDRV\_PSC\_CORENUM\_VAL | (2U) | Maximum number of cores for PSC. |
| IMPDRV\_REG\_PSC\_VCR | (0x0000U) | Offset address of VCR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR0 | (0x0004U) | Offset address of CTLR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SR | (0x0008U) | Offset address of SR register for PSC. |
| IMPDRV\_REG\_PSC\_SCR | (0x000CU) | Offset address of SCR register for PSC. |
| IMPDRV\_REG\_PSC\_SER | (0x0010U) | Offset address of SER register for PSC. |
| IMPDRV\_REG\_PSC\_IMR | (0x0014U) | Offset address of IMR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SR1 | (0x003CU) | Offset address of SR1 register for PSC. |
| IMPDRV\_REG\_PSC\_CLSAR | (0x0038U) | Offset address of CLSAR register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR0 | (0x0058U) | Offset address of SYNCCR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR1 | (0x0060U) | Offset address of SYNCCR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR2 | (0x0064U) | Offset address of SYNCCR2 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR3 | (0x0068U) | Offset address of SYNCCR3 register for PSC. |
| IMPDRV\_PSC\_VCR | (0x17020121U) | Hardware version value for PSC. |
| IMPDRV\_PSC\_SCTLR0\_SWRST | (0x80000000U) | SWRST register value for IMP. |
| IMPDRV\_PSC\_SCTLR0\_CLR | (0x00000000U) | CLR register value for IMP. |
| IMPDRV\_PSC\_SCTLR1\_CLE | (0x00000001U) | CLE register value for IMP. |
| IMPDRV\_PSC\_SR\_TEND | (0x00000001U) | TEND interrupt enable registration. |
| IMPDRV\_PSC\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_PSC\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_PSC\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_PSC\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of PSC. |
| IMPDRV\_IMPS\_CORENUM\_VAL | (1U) | Maximum number of cores for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_VCR | (0x0004U) | Offset address of VCR register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_CNF | (0x0008U) | Offset address of CNF register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IFCFG | (0x0018U) | Offset address of CNFG register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IFCTL | (0x001CU) | Offset address of IFCTL register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_SYNCCR0 | (0x0040U) | Offset address of SYNCCR0 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_SYNCCR1 | (0x0044U) | Offset address of SYNCCR1 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_SYNCCR2 | (0x0048U) | Offset address of SYNCCR2 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_SYNCCR3 | (0x004CU) | Offset address of SYNCCR03 register for Slim-IMP |
| IMPDRV\_REG\_IMPS\_INTSTS | (0x0010U) | Offset address of INTSTS register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_INTEN | (0x0014U) | Offset address of INTEN register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_PSA | (0x0020U) | Offset address of PSA register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_MEM\_FUNC\_SA | (0x0B78U) | Offset address of SA register for Slim-IMP. |
| IMPDRV\_IMPS\_VCR | (0x00600000U) | Hardware version value for Slim-IMP. |
| IMPDRV\_IMPS\_CNF\_VAL | (0x00000001U) | CNF\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_CNF\_SWRST | (0x80000000U) | CNF\_SWRST register value for Slim-IMP. |
| IMPDRV\_IMPS\_IFCTL\_EXE | (0x00000001U) | EXE register value for Slim-IMP. |
| IMPDRV\_IMPS\_IFCFG\_VAL | (0x010010CCU) | IFCFG\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_IFCTL\_ENDIAN | (0x22020200U) | ENDIAN register value for Slim-IMP. |
| IMPDRV\_IMPS\_HMPTR\_VAL | (0x87FFU) | HMPTR\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_HMDATA\_VAL | (0x0000U) | HMDATA\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_MEM\_FUNC\_SA\_VAL | (0x0030U) | SA\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_INTSTS\_MASKCPU | (0x10000000U) | MASKCPU interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_APIPINT | (0x00000001U) | APIPINT interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_HPINT | (0x00000002U) | HPINT interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_INT | (0x00000020U) | INT interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_WUP | (0x04000000U) | WUP interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_IER | (0x00000080U) | IER interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_TRAP | (0x00000040U) | TRAP interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_CLR | (IMPDRV\_IMPS\_INTSTS\_TRAP | IMPDRV\_IMPS\_INTSTS\_IER | IMPDRV\_IMPS\_INTSTS\_INT | IMPDRV\_IMPS\_INTSTS\_WUP |IMPDRV\_IMPS\_INTSTS\_HPINT | IMPDRV\_IMPS\_INTSTS\_APIPINT) | CLR register value for Slim-IMP. |
| IMPDRV\_IMPS\_APCMD\_ACSCNT\_DS | (0x00010000U) | ACSCNT\_DS bit in APCMD Register. |
| IMPDRV\_IMPS\_APCMD\_ACSCNT\_SA | (0x00080000U) | ACSCNT\_SA bit in APCMD Register. |
| IMPDRV\_IMPS\_APCMD\_EX | (0x80000000U) | EX bit in APCMD Register. |
| IMPDRV\_IMPS\_MEM\_ALIGN\_BUSCHK | (127U) | Memory alignment for Bus interface check. |
| IMPDRV\_IMPS\_MEM\_MAX\_ADRS\_BUSCHK | (0xFFFFFFFFU) | Maximum memory address for Bus interface check. |
| IMPDRV\_IMPS\_MEM\_SIZE\_BUSCHK | (512U) | Memory size for Bus interface check. |
| IMPDRV\_IMPS\_REG\_MAX\_ADRS\_CNFCHK | (0x0001FFFFU) | End of offset address for ConfRegCheck of Slim-IMP. |
| IMPDRV\_IMPS\_SEND\_TIMEOUT\_BUSCHK | (0U) | Timeout period for send queue of bus interface check. |
| IMPDRV\_REG\_IMPS\_APCFG | (0x013CU) | Offset address of APCFG register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APCLPX | (0x012CU) | Offset address of APCLPX register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APCMD | (0x0128U) | Offset address of APCMD register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APDLY | (0x0110U) | Offset address of APDLY register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APDSP | (0x0108U) | Offset address of APSBSP register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APLNG | (0x010CU) | Offset address of APLNG register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APMAG | (0x0114U) | Offset address of APMAG register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APSASP | (0x0100U) | Offset address of APSASP register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APSBSP | (0x0104U) | Offset address of APSBSP register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APSIZE\_DST | (0x0120U) | Offset address of APSIZE\_DST register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APSIZE\_SA | (0x0118U) | Offset address of APSIZE\_SA register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APSIZE\_SB | (0x011CU) | Offset address of APSIZE\_SB register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_BINTHR | (0x0818U) | Offset address of BINTHR register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_BINTHR2 | (0x081CU) | Offset address of BINTHR2 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_CNST | (0x0814U) | Offset address of CNST register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF02 | (0x0830U) | Offset address of COEFF02 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF02H | (0x0854U) | Offset address of COEFF02H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1214 | (0x0840U) | Offset address of COEFF1214 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1214H | (0x0864U) | Offset address of COEFF1214H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF15 | (0x0844U) | Offset address of COEFF15 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1517H | (0x0868U) | Offset address of COEFF1517H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1820 | (0x0848U) | Offset address of COEFF1820 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1820H | (0x086CU) | Offset address of COEFF1820H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF2123 | (0x084CU) | Offset address of COEFF2123 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF2123H | (0x0870U) | Offset address of COEFF2123H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF24 | (0x0850U) | Offset address of COEFF24 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF24H | (0x0874U) | Offset address of COEFF24H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF35 | (0x0834U) | Offset address of COEFF35 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF35H | (0x0858U) | Offset address of COEFF35H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF68 | (0x0838U) | Offset address of COEFF68 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF68H | (0x085CU) | Offset address of COEFF68H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF911 | (0x083CU) | Offset address of COEFF911 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF911H | (0x0860U) | Offset address of COEFF911H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IPFORM | (0x0808U) | Offset address of IPFORM register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IPFUN | (0x0800U) | Offset address of IPFUN register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IPFUN2 | (0x0804U) | Offset address of IPFUN2 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_KNLMSK | (0x0820U) | Offset address of KNLMSK register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_KNLMSK2 | (0x0824U) | Offset address of KNLMSK2 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_LABCNT | (0x082CU) | Offset address of LABCNT register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_LMCTL | (0x0828U) | Offset address of LMCTL register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_PFFTAMSK | (0x0A88U) | Offset address of PFFTAMSK register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_PFFTASEL1 | (0x0A80U) | Offset address of PFFTASEL1 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_PFFTBMSK | (0x0A94U) | Offset address of PFFTBMSK register for Slim-IMP. |

Table 5‑53: Definition Values (Core Control) [R-CarV3H\_2]

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_IMP\_CORENUM\_VAL | (5U) | Maximum number of cores for IMP. |
| IMPDRV\_REG\_IMP\_VCR | (0x0004U) | Offset address of VCR register for IMP. |
| IMPDRV\_REG\_IMP\_CNF | (0x0008U) | Offset address of CNF register for IMP. |
| IMPDRV\_REG\_IMP\_IFCFG | (0x0018U) | Offset address of CNFG register for IMP. |
| IMPDRV\_REG\_IMP\_IFCTL | (0x001CU) | Offset address of IFCTL register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR0 | (0x0040U) | Offset address of SYNCCR0 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR1 | (0x0044U) | Offset address of SYNCCR1 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR2 | (0x0048U) | Offset address of SYNCCR2 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR3 | (0x004CU) | Offset address of SYNCCR03 register for IMP. |
| IMPDRV\_REG\_IMP\_INTSTS | (0x0010U) | Offset address of INTSTS register for IMP. |
| IMPDRV\_REG\_IMP\_INTEN | (0x0014U) | Offset address of INTEN register for IMP. |
| IMPDRV\_REG\_IMP\_PSA | (0x0020U) | Offset address of PSA register for IMP. |
| IMPDRV\_REG\_IMP\_HMPTR | (0x0514U) | Offset address of HMPTR register for IMP. |
| IMPDRV\_REG\_IMP\_HMDATA | (0x0518U) | Offset address of HMDATA register for IMP. |
| IMPDRV\_REG\_IMP\_HM1PTR | (0x0594U) | Offset address of HM1PTR register for IMP. |
| IMPDRV\_REG\_IMP\_HM1DATA | (0x0598U) | Offset address of HM1DATA register for IMP. |
| IMPDRV\_REG\_IMP\_MEM\_FUNC\_SA | (0x0B78U) | Offset address of SA register for IMP. |
| IMPDRV\_IMP\_VCR | (0x00610000U) | Hardware version value for IMP. |
| IMPDRV\_IMP\_CNF\_VAL | (0x00000001U) | CNF\_VAL register value for IMP. |
| IMPDRV\_IMP\_CNF\_SWRST | (0x80000000U) | CNF\_SWRST register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_EXE | (0x00000001U) | EXE register value for IMP. |
| IMPDRV\_IMP\_IFCFG\_VAL | (0x010010CCU) | IFCFG\_VAL register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_ENDIAN | (0x22020200U) | ENDIAN register value for IMP. |
| IMPDRV\_IMP\_HMPTR\_VAL | (0x87FFU) | HMPTR\_VAL register value for IMP. |
| IMPDRV\_IMP\_HMDATA\_VAL | (0x0000U) | HMDATA\_VAL register value for IMP. |
| IMPDRV\_IMP\_MEM\_FUNC\_SA\_VAL | (0x00FFU) | SA\_VAL register value for IMP. |
| IMPDRV\_IMP\_INTSTS\_MASKCPU | (0x10000000U) | MASKCPU interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_APIPINT | (0x00000001U) | APIPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_HPINT | (0x00000002U) | HPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_WUP | (0x04000000U) | WUP interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_INT | (0x00000020U) | INT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_IER | (0x00000080U) | IER interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_TRAP | (0x00000040U) | TRAP interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_CLR | (IMPDRV\_IMP\_INTSTS\_TRAP|IMPDRV\_IMP\_INTSTS\_IER|IMPDRV\_IMP\_INTSTS\_INT|IMPDRV\_IMP\_INTSTS\_WUP|IMPDRV\_IMP\_INTSTS\_HPINT|IMPDRV\_IMP\_INTSTS\_APIPINT) | CLR register value for IMP. |
| IMPDRV\_CNN\_CORENUM\_VAL | (1U) | Maximum number of cores for CNN. |
| IMPDRV\_REG\_CNN\_VCR | (0x0000U) | Offset address of VCR register for CNN. |
| IMPDRV\_CNN\_VCR | (0x00030001U) | Hardware version value for CNN. |
| IMPDRV\_REG\_CNN\_SWRST | (0x0008U) | Offset address of hardware register for SWRST. |
| IMPDRV\_REG\_CNN\_SR | (0x0010U) | Offset address of hardware register for SR. |
| IMPDRV\_REG\_CNN\_SRE | (0x0014U) | Offset address of hardware register for SRE. |
| IMPDRV\_REG\_CNN\_SRC | (0x0018U) | Offset address of hardware register for SRC. |
| IMPDRV\_REG\_CNN\_SRM | (0x001CU) | Offset address of hardware register for SRM. |
| IMPDRV\_REG\_CNN\_SACL | (0x0104U) | Offset address of hardware register for SACL |
| IMPDRV\_REG\_CNN\_SCLP | (0x0108U) | Offset address of hardware register for SCLP. |
| IMPDRV\_REG\_CNN\_SYNCCR0 | (0x0900U) | Offset address of hardware register for SYNCCR0. |
| IMPDRV\_REG\_CNN\_SYNCCR1 | (0x0904U) | Offset address of hardware register for SYNCCR1. |
| IMPDRV\_REG\_CNN\_SYNCCR2 | (0x0908U) | Offset address of hardware register for YNCCR2. |
| IMPDRV\_REG\_CNN\_SYNCCR3 | (0x090CU) | Offset address of hardware register for MG2ISYNCCR3NTSEL |
| IMPDRV\_CNN\_CNF\_SWRST | (0x00000001U) | SWRST register value for CNN. |
| IMPDRV\_CNN\_CNF\_CLR | (0x00000000U) | CLR register value for CNN. |
| IMPDRV\_CNN\_SR\_CLBUSY | (0x00004000U) | CLBSY register value for CNN. |
| IMPDRV\_CNN\_SR\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_CNN\_SR\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_CNN\_SR\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_CNN\_SR\_MSCO | (0x00000008U) | MSCO interrupt enable registration. |
| IMPDRV\_CNN\_SR\_WUPCOVF | (0x00000010U) | WUPCOVF interrupt enable registration. |
| IMPDRV\_CNN\_SCLP\_START | (0x00000001U) | CNN\_SCLP\_START register value for CNN. |
| IMPDRV\_CNN\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of CNN. |
| IMPDRV\_DMA\_CORENUM\_VAL | (4U) | Maximum number of cores for DMA. |
| IMPDRV\_DMA\_CORENUM0MAIN | (0U) | DMA Core 0 Main thread identification value. |
| IMPDRV\_DMA\_CORENUM0SUB | (1U) | DMA Core 0 Sub thread identification value. |
| IMPDRV\_DMA\_CORENUM1MAIN | (2U) | DMA Core 1 Main thread identification value. |
| IMPDRV\_DMA\_CORENUM1SUB | (3U) | DMA Core 1 Sub thread identification value. |
| IMPDRV\_REG\_DMA\_VCR | (0x0000U) | Offset address of VCR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR | (0x0004U) | Offset address of SCTLR register for DMA. |
| IMPDRV\_REG\_DMA\_SR | (0x0008U) | Offset address of SR register for DMA. |
| IMPDRV\_REG\_DMA\_SCR | (0x000CU) | Offset address of SCR register for DMA. |
| IMPDRV\_REG\_DMA\_SER | (0x0010U) | Offset address of VCR register for DMA. |
| IMPDRV\_REG\_DMA\_IMR | (0x0014U) | Offset address of IMR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for DMA. |
| IMPDRV\_REG\_DMA\_CLSAR | (0x0028U) | Offset address of CLSAR register for DMA. |
| IMPDRV\_REG\_DMA\_SR1 | (0x0030U) | Offset address of SR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR0 | (0x00E8U) | Offset address of SYNCCR0 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR1 | (0x00ECU) | Offset address of SYNCCR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR2 | (0x00F0U) | Offset address of SYNCCR2 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR3 | (0x00F4U) | Offset address of SYNCCR3 register for DMA. |
| IMPDRV\_DMA\_VCR | (0x19102516U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_SWRST | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_CLR | (0x00000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR1\_PS | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_REG\_DMA\_THREAD\_OFFSET | (0x00000800U) | H/W Register offset for DMA sub-thread. |
| IMPDRV\_DMA\_SR\_TEND | (0x00000001U) | /\*\*<SA\_TEND interrupt enable registration. |
| IMPDRV\_DMA\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_DMA\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_DMA\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_DMA\_SR\_WUP | (0x00000080U) | WUP interrupt enable registration. |
| IMPDRV\_DMA\_SER\_FIX | (0x0000F300U) | Status Enable Registers that are always bit 1. |
| IMPDRV\_DMA\_RAMTSTR | (0x00D0U) | Offset address of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_MASK | (0x8000U) | Bit mask of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_LOOPTIME\_VAL | (8U) | read count for register. |
| IMPDRV\_DMA\_MB\_INFO\_SIZE1 | (3U) | Mult-Bank memory init register info1. |
| IMPDRV\_DMA\_MB\_INFO\_SIZE2 | (7U) | Mult-Bank memory init register info2. |
| IMPDRV\_DMA\_MB\_INFO\_SIZE3 | (5U) | Mult-Bank memory init register info3. |
| IMPDRV\_DMA\_MB\_WRITE\_NUM\_ODD | (8U) | Odd mult-Bank memory init register write number of times. |
| IMPDRV\_DMA\_MB\_WRITE\_NUM\_EVEN | (8U) | Even mult-Bank memory init register write number of times. |
| IMPDRV\_REG\_DMA\_IMGSIZER | (0x0094U) | Offset address of IMGSIZER register for DMA. |
| IMPDRV\_DMA\_IMGSIZER\_VAL | (0x00800001U) | IMGSIZER register value for DMA. |
| IMPDRV\_REG\_DMA\_FCR0 | (0x00A0U) | Offset address of FCR0 register for DMA. |
| IMPDRV\_DMA\_FCR0\_VAL | (0x000000CCU) | FCR0 register value for DMA. |
| IMPDRV\_REG\_DMA\_FCR1 | (0x00ACU) | Offset address of FCR1 register for DMA. |
| IMPDRV\_DMA\_FCR1\_VAL | (0x90000000U) | FCR1 register value for DMA. |
| IMPDRV\_REG\_DMA\_S0SAR | (0x0040U) | Offset address of S0SAR register for DMA. |
| IMPDRV\_DMA\_S0SAR\_ODD\_BASE\_ADDR | (0xED020000U) | S0SAR register value for DMA odd bank. |
| IMPDRV\_DMA\_S0SAR\_EVEN\_BASE\_ADDR | (0xED000000U) | S0SAR register value for DMA even bank. |
| IMPDRV\_DMA\_S0SAR\_OFFSET | (0x00040000U) | S0SAR register offset for DMA even bank. |
| IMPDRV\_REG\_DMA\_S0STR | (0x0044U) | Offset address of S0STR register for DMA. |
| IMPDRV\_DMA\_S0STR\_VAL | (0x00000020U) | S0STR register value for DMA. |
| IMPDRV\_REG\_DMA\_S0DATAR | (0x004CU) | Offset address of S0DATAR register for DMA. |
| IMPDRV\_DMA\_S0DATAR\_VAL | (0x00000000U) | S0DATAR register value for DMA. |
| IMPDRV\_REG\_DMA\_S0CR | (0x0050U) | Offset address of S0CR register for DMA. |
| IMPDRV\_DMA\_S0CR\_VAL | (0x80000003U) | S0CR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1SAR | (0x0060U) | Offset address of S1SAR register for DMA. |
| IMPDRV\_DMA\_S1SAR\_VAL | (0x00000000U) | S1SAR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1STR | (0x0064U) | Offset address of S1STR register for DMA. |
| IMPDRV\_DMA\_S1STR\_VAL | (0x00000020U) | S1STR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1DATAR | (0x006CU) | Offset address of S1DATAR register for DMA. |
| IMPDRV\_DMA\_S1DATAR\_VAL | (0x00000000U) | S1DATAR register value for DMA. |
| IMPDRV\_REG\_DMA\_S1CR | (0x0070U) | Offset address of S1CR register for DMA. |
| IMPDRV\_DMA\_S1CR\_VAL | (0x00000003U) | S1CR register value for DMA. |
| IMPDRV\_REG\_DMA\_D0SAR | (0x0080U) | Offset address of D0SAR register for DMA. |
| IMPDRV\_REG\_DMA\_D0STR | (0x0084U) | Offset address of D0STR register for DMA. |
| IMPDRV\_DMA\_D0STR\_VAL | (0x00000020U) | D0STR register value for DMA. |
| IMPDRV\_REG\_DMA\_D0CR | (0x0090U) | Offset address of D0CR register for DMA. |
| IMPDRV\_DMA\_D0CR\_VAL | (0x00000003U) | D0CR register value for DMA. |
| IMPDRV\_REG\_DMA\_DSWPR | (0x0038U) | Offset address of DSWPR register for DMA. |
| IMPDRV\_DMA\_DSWPR\_VAL | (0x00000000U) | DSWPR register value for DMA. |
| IMPDRV\_REG\_DMA\_TSCR | (0x0020U) | Offset address of TSCR register for DMA. |
| IMPDRV\_DMA\_TSCR\_VAL | (0x00330003U) | TSCR register value for DMA. |
| IMPDRV\_DMA\_SCTLR0\_MB\_VAL | (0x00000001U) | SCTLR0 multi-bank register value for DMA. |
| IMPDRV\_DMA\_SCTLR0\_MB\_VAL | (0x00000001U) | SCTLR0 multi-bank register value for DMA. |
| IMPDRV\_DMA\_MEM\_SIZE\_BUSCHK | (512U) | Memory size for Bus interface check. |
| IMPDRV\_DMA\_MEM\_ALIGN\_BUSCHK | (127U) | Memory alignment for Bus interface check. |
| IMPDRV\_DMA\_MEM\_MAX\_ADRS\_BUSCHK | (0xFFFFFFFFU) | Maximum memory address for Bus interface check. |
| IMPDRV\_DMA\_SEND\_TIMEOUT\_BUSCHK | (0U) | Timeout period for send queue of bus interface check. |
| IMPDRV\_OCV\_CORENUM\_VAL | (5U) | Maximum number of cores for OCV. |
| IMPDRV\_OCV\_OFFSET\_32B | (32U) | Offset 32byte for OCV. |
| IMPDRV\_REG\_OCV\_VCR0 | (0x0000U) | Offset address of VCR register for OCV. |
| IMPDRV\_REG\_OCV\_RSTR | (0x0008U) | Offset address of RSTR register for OCV. |
| IMPDRV\_REG\_OCV\_CR | (0x000CU) | Offset address of CR register for OCV. |
| IMPDRV\_REG\_OCV\_SR0 | (0x0010U) | Offset address of SR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SR1 | (0x0014U) | Offset address of SR1 register for OCV. |
| IMPDRV\_REG\_OCV\_SCR1 | (0x0018U) | Offset address of SCR1 register for OCV. |
| IMPDRV\_REG\_OCV\_ICR1 | (0x001CU) | Offset address of ICR1 register for OCV. |
| IMPDRV\_REG\_OCV\_IMR1 | (0x0020U) | Offset address of IMR1 register for OCV. |
| IMPDRV\_REG\_OCV\_MCR0 | (0x0040U) | Offset address of MCR0 register for OCV. |
| IMPDRV\_REG\_OCV\_DLSAR | (0x0180U) | Offset address of DLSAR register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR0 | (0x04C0U) | Offset address of SYNCCR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR1 | (0x04C4U) | Offset address of SYNCCR1 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR2 | (0x04C8U) | Offset address of SYNCCR2 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR3 | (0x04CCU) | Offset address of SYNCCR3 register for OCV. |
| IMPDRV\_REG\_OCV\_MEMINITR | (0x00F8U) | Offset address of MEMINITR register for OCV. |
| IMPDRV\_OCV\_VCR | (0x00000014U) | Hardware version value for OCV. |
| IMPDRV\_OCV\_RESET\_STATUS\_VAL | (0x00F10000U) | RESET\_STATUS value for OCV. |
| IMPDRV\_OCV\_WM\_INIT\_VAL | (0x00F1U) | Working Memory init value for OCV. |
| IMPDRV\_OCV\_OFST\_START\_VAL | (0xC000U) | OFST\_START value for OCV. |
| IMPDRV\_OCV\_OFST\_END\_VAL | (0xE000U) | OFST\_END value for OCV. |
| IMPDRV\_OCV\_1KB\_VAL | (0x80064100U) | 1KB value for OCV. |
| IMPDRV\_OCV\_MCR0\_INIT\_VAL | (0x01000000U) | MCR0 value for OCV. |
| IMPDRV\_OCV\_CR\_PS | (0x00000001U) | PS register value for OCV. |
| IMPDRV\_OCV\_RSTR\_SWRST | (0x00000001U) | SWRST register value for OCV. |
| IMPDRV\_OCV\_RSTR\_CLR | (0x00000000U) | CLR register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL0 | (0x00040000U) | DCBANKSEL0register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL1 | (0x05000000U) | DCBANKSEL1 register value for OCV. |
| IMPDRV\_OCV\_SR1\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_PBCOVF | (0x00000008U) | PBCOVF interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_SBO0ME | (0x00000010U) | SBO0ME interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_USIER | (0x00001000U) | USIER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_USINT | (0x00002000U) | USINT interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_WUPCOVF | (0x00004000U) | WUPCOVF interrupt enable registration. |
| IMPDRV\_REG\_OCV\_SR2 | (0x0024U) | Offset address of SR2 register for OCV |
| IMPDRV\_REG\_OCV\_SCR2 | (0x0028U) | Offset address of SCR2 register for OCV. |
| IMPDRV\_REG\_OCV\_ICR2 | (0x002CU) | Offset address of ICR2 register for OCV |
| IMPDRV\_OCV\_SR1\_UDIPSBRK | (0x10000000U) | UDIPSBRK interrupt enable registration |
| IMPDRV\_OCV\_SR1\_UDIVSBRK | (0x20000000U) | UDIVSBRK interrupt enable registration. |
| IMPDRV\_OCV\_SR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in SR2 register. |
| IMPDRV\_OCV\_SCR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in SCR2 register |
| IMPDRV\_OCV\_ICR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in ICR2 register |
| IMPDRV\_PSC\_CORENUM\_VAL | (1U) | Maximum number of cores for PSC. |
| IMPDRV\_REG\_PSC\_VCR | (0x0000U) | Offset address of VCR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR0 | (0x0004U) | Offset address of CTLR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SR | (0x0008U) | Offset address of SR register for PSC. |
| IMPDRV\_REG\_PSC\_SCR | (0x000CU) | Offset address of SCR register for PSC. |
| IMPDRV\_REG\_PSC\_SER | (0x0010U) | Offset address of SER register for PSC. |
| IMPDRV\_REG\_PSC\_IMR | (0x0014U) | Offset address of IMR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SR1 | (0x003CU) | Offset address of SR1 register for PSC. |
| IMPDRV\_REG\_PSC\_CLSAR | (0x0038U) | Offset address of CLSAR register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR0 | (0x0058U) | Offset address of SYNCCR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR1 | (0x0060U) | Offset address of SYNCCR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR2 | (0x0064U) | Offset address of SYNCCR2 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR3 | (0x0068U) | Offset address of SYNCCR3 register for PSC. |
| IMPDRV\_PSC\_VCR | (0x17020121U) | Hardware version value for PSC. |
| IMPDRV\_PSC\_SCTLR0\_SWRST | (0x80000000U) | SWRST register value for IMP. |
| IMPDRV\_PSC\_SCTLR0\_CLR | (0x00000000U) | CLR register value for IMP. |
| IMPDRV\_PSC\_SCTLR1\_CLE | (0x00000001U) | CLE register value for IMP. |
| IMPDRV\_PSC\_SR\_TEND | (0x00000001U) | TEND interrupt enable registration. |
| IMPDRV\_PSC\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_PSC\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_PSC\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_PSC\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of PSC. |
| IMPDRV\_PSC\_SR\_WUP | (0x00010000U) | WUP interrupt enable registration. |
| IMPDRV\_IMPS\_CORENUM\_VAL | (1U) | Maximum number of cores for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_VCR | (0x0004U) | Offset address of VCR register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_CNF | (0x0008U) | Offset address of CNF register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IFCFG | (0x0018U) | Offset address of CNFG register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IFCTL | (0x001CU) | Offset address of IFCTL register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_SYNCCR0 | (0x0040U) | Offset address of SYNCCR0 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_SYNCCR1 | (0x0044U) | Offset address of SYNCCR1 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_SYNCCR2 | (0x0048U) | Offset address of SYNCCR2 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_SYNCCR3 | (0x004CU) | Offset address of SYNCCR03 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_INTSTS | (0x0010U) | Offset address of INTSTS register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_INTEN | (0x0014U) | Offset address of INTEN register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_PSA | (0x0020U) | Offset address of PSA register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_HMPTR | (0x0514U) | Offset address of HMPTR register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_HMDATA | (0x0518U) | Offset address of HMDATA register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_HM1PTR | (0x0594U) | Offset address of HM1PTR register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_HM1DATA | (0x0598U) | Offset address of HM1DATA register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_MEM\_FUNC\_SA | (0x0B78U) | Offset address of SA register for Slim-IMP. |
| IMPDRV\_IMPS\_VCR | (0x00610000U) | Hardware version value for Slim-IMP. |
| IMPDRV\_IMPS\_CNF\_VAL | (0x00000001U) | CNF\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_CNF\_SWRST | (0x80000000U) | CNF\_SWRST register value for Slim-IMP. |
| IMPDRV\_IMPS\_IFCTL\_EXE | (0x00000001U) | EXE register value for Slim-IMP. |
| IMPDRV\_IMPS\_IFCFG\_VAL | (0x010010CCU) | IFCFG\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_IFCTL\_ENDIAN | (0x22020200U) | ENDIAN register value for Slim-IMP. |
| IMPDRV\_IMPS\_HMPTR\_VAL | (0x87FFU) | HMPTR\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_HMDATA\_VAL | (0x0000U) | HMDATA\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_MEM\_FUNC\_SA\_VAL | (0x0030U) | SA\_VAL register value for Slim-IMP. |
| IMPDRV\_IMPS\_INTSTS\_MASKCPU | (0x10000000U) | MASKCPU interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_APIPINT | (0x00000001U) | APIPINT interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_HPINT | (0x00000002U) | HPINT interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_WUP | (0x04000000U) | WUP interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_INT | (0x00000020U) | INT interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_IER | (0x00000080U) | IER interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_TRAP | (0x00000040U) | TRAP interrupt enable registration. |
| IMPDRV\_IMPS\_INTSTS\_CLR | (IMPDRV\_IMPS\_INTSTS\_TRAP|IMPDRV\_IMPS\_INTSTS\_IER|IMPDRV\_IMPS\_INTSTS\_INT|IMPDRV\_IMPS\_INTSTS\_WUP|IMPDRV\_IMPS\_INTSTS\_HPINT|IMPDRV\_IMPS\_INTSTS\_APIPINT) | CLR register value for Slim-IMP. |
| IMPDRV\_DMAS\_CORENUM\_VAL | (2U) | Maximum number of cores for DMAS. |
| IMPDRV\_DMAS\_CORENUM0MAIN | (0U) | DMAS Core 0 Main thread identification value. |
| IMPDRV\_DMAS\_CORENUM0SUB | (1U) | DMAS Core 0 Sub thread identification value. |
| IMPDRV\_REG\_DMAS\_VCR | (0x0000U) | Offset address of VCR register for DMAS. |
| IMPDRV\_REG\_DMAS\_SCTLR | (0x0004U) | Offset address of SCTLR register for DMAS. |
| IMPDRV\_REG\_DMAS\_SR | (0x0008U) | Offset address of SR register for DMAS. |
| IMPDRV\_REG\_DMAS\_SCR | (0x000CU) | Offset address of SCR register for DMAS. |
| IMPDRV\_REG\_DMAS\_SER | (0x0010U) | Offset address of VCR register for DMAS. |
| IMPDRV\_REG\_DMAS\_IMR | (0x0014U) | Offset address of IMR register for DMAS. |
| IMPDRV\_REG\_DMAS\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for DMAS. |
| IMPDRV\_REG\_DMAS\_CLSAR | (0x0028U) | Offset address of CLSAR register for DMAS. |
| IMPDRV\_REG\_DMAS\_SR1 | (0x0030U) | Offset address of SR1 register for DMAS. |
| IMPDRV\_REG\_DMAS\_SYNCCR0 | (0x00E8U) | Offset address of SYNCCR0 register for DMAS. |
| IMPDRV\_REG\_DMAS\_SYNCCR1 | (0x00ECU) | Offset address of SYNCCR1 register for DMAS. |
| IMPDRV\_REG\_DMAS\_SYNCCR2 | (0x00F0U) | Offset address of SYNCCR2 register for DMAS. |
| IMPDRV\_REG\_DMAS\_SYNCCR3 | (0x00F4U) | Offset address of SYNCCR3 register for DMAS. |
| IMPDRV\_DMAS\_VCR | (0x19082120U) | Hardware version value for DMAS. |
| IMPDRV\_DMAS\_SCTLR\_SWRST | (0x80000000U) | Hardware version value for DMAS. |
| IMPDRV\_DMAS\_SCTLR\_CLR | (0x00000000U) | Hardware version value for DMAS. |
| IMPDRV\_DMAS\_SCTLR1\_PS | (0x80000000U) | Hardware version value for DMAS. |
| IMPDRV\_REG\_DMAS\_THREAD\_OFFSET | (0x00000800U) | H/W Register offset for DMAS sub-thread. |
| IMPDRV\_DMAS\_SR\_TEND | (0x00000001U) | /\*\*<SA\_TEND interrupt enable registration. |
| IMPDRV\_DMAS\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_DMAS\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_DMAS\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_DMAS\_SR\_WUP | (0x00000080U) | WUP interrupt enable registration. |
| IMPDRV\_DMAS\_SER\_FIX | (0x0000F300U) | Status Enable Registers that are always bit 1. |
| IMPDRV\_DMAS\_RAMTSTR | (0x00D0U) | Offset address of RAMTSTR register for DMAS. |
| IMPDRV\_DMAS\_MASK | (0x8000U) | Bit mask of RAMTSTR register for DMAS. |
| IMPDRV\_DMAS\_LOOPTIME\_VAL | (8U) | read count for register. |
| IMPDRV\_DMAS\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of Slim-DMA |
| IMPDRV\_IMPS\_APCMD\_ACSCNT\_DS | (0x00010000U) | ACSCNT\_DS bit in APCMD Register. |
| IMPDRV\_IMPS\_APCMD\_ACSCNT\_SA | (0x00080000U) | ACSCNT\_SA bit in APCMD Register. |
| IMPDRV\_IMPS\_APCMD\_EX | (0x80000000U) | EX bit in APCMD Register. |
| IMPDRV\_IMPS\_MEM\_ALIGN\_BUSCHK | (127U) | Memory alignment for Bus interface check. |
| IMPDRV\_IMPS\_MEM\_MAX\_ADRS\_BUSCHK | (0xFFFFFFFFU) | Maximum memory address for Bus interface check. |
| IMPDRV\_IMPS\_MEM\_SIZE\_BUSCHK | (512U) | Memory size for Bus interface check. |
| IMPDRV\_IMPS\_REG\_MAX\_ADRS\_CNFCHK | (0x0001FFFFU) | End of offset address for ConfRegCheck of Slim-IMP. |
| IMPDRV\_IMPS\_SEND\_TIMEOUT\_BUSCHK | (0U) | Timeout period for send queue of bus interface check. |
| IMPDRV\_REG\_IMPS\_APCFG | (0x013CU) | Offset address of APCFG register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APCLPX | (0x012CU) | Offset address of APCLPX register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APCMD | (0x0128U) | Offset address of APCMD register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APDLY | (0x0110U) | Offset address of APDLY register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APDSP | (0x0108U) | Offset address of APSBSP register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APLNG | (0x010CU) | Offset address of APLNG register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APMAG | (0x0114U) | sliのため対象外 |
| IMPDRV\_REG\_IMPS\_APSASP | (0x0100U) | sliのため対象外 |
| IMPDRV\_REG\_IMPS\_APSBSP | (0x0104U) | Offset address of APSBSP register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APSIZE\_DST | (0x0120U) | Offset address of APSIZE\_DST register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APSIZE\_SA | (0x0118U) | Offset address of APSIZE\_SA register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_APSIZE\_SB | (0x011CU) | Offset address of APSIZE\_SB register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_BINTHR | (0x0818U) | Offset address of BINTHR register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_BINTHR2 | (0x081CU) | Offset address of BINTHR2 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_CNST | (0x0814U) | Offset address of CNST register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF02 | (0x0830U) | Offset address of COEFF02 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF02H | (0x0854U) | Offset address of COEFF02H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1214 | (0x0840U) | Offset address of COEFF1214 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1214H | (0x0864U) | Offset address of COEFF1214H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF15 | (0x0844U) | Offset address of COEFF15 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1517H | (0x0868U) | Offset address of COEFF1517H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1820 | (0x0848U) | Offset address of COEFF1820 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF1820H | (0x086CU) | Offset address of COEFF1820H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF2123 | (0x084CU) | Offset address of COEFF2123 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF2123H | (0x0870U) | Offset address of COEFF2123H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF24 | (0x0850U) | Offset address of COEFF24 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF24H | (0x0874U) | Offset address of COEFF24H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF35 | (0x0834U) | Offset address of COEFF35 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF35H | (0x0858U) | Offset address of COEFF35H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF68 | (0x0838U) | Offset address of COEFF68 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF68H | (0x085CU) | Offset address of COEFF68H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF911 | (0x083CU) | Offset address of COEFF911 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_COEFF911H | (0x0860U) | Offset address of COEFF911H register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IPFORM | (0x0808U) | Offset address of IPFORM register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IPFUN | (0x0800U) | Offset address of IPFUN register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_IPFUN2 | (0x0804U) | Offset address of IPFUN2 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_KNLMSK | (0x0820U) | Offset address of KNLMSK register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_KNLMSK2 | (0x0824U) | Offset address of KNLMSK2 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_LABCNT | (0x082CU) | Offset address of LABCNT register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_LMCTL | (0x0828U) | Offset address of LMCTL register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_PFFTAMSK | (0x0A88U) | Offset address of PFFTAMSK register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_PFFTASEL1 | (0x0A80U) | Offset address of PFFTASEL1 register for Slim-IMP. |
| IMPDRV\_REG\_IMPS\_PFFTBMSK | (0x0A94U) | Offset address of PFFTBMSK register for Slim-IMP. |

Table 5‑54 Definition Values (Core Control) 「R-CarV4H]

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_MASK\_U8BIT | (0xFF000000U) | Bit mask for Upper 8 bits |
| IMPDRV\_MASK\_U9\_16BIT | (0x00FF0000U) | Bit mask for Upper 9-16 bits |
| IMPDRV\_MASK\_U16BIT | (0xFFFF0000U) | Bit mask for Upper 16 bits |
| IMPDRV\_MASK\_L8BIT | (0x000000FFU) | Bit mask for Lower 8 bits |
| IMPDRV\_MASK\_BIT15 | (0x00008000U) | Bit mask for Only 15 bit |
| IMPDRV\_INIT\_CL\_ADDR | (0xFFFFFFFFU) | Initial value of CL address data |
| IMPDRV\_CALLBACK\_CODE\_DEF | (-1) | Callback code default value |
| IMPDRV\_RESERVE\_NUM | (2U) | Number of reserve parameter arrays |
| IMPDRV\_EXEPARAM\_MAX | (4U) | Number of extended parameter arrays |
| IMPDRV\_CORE\_NUM\_MAX | (8U) | Maximum value of Core number definition |
| IMPDRV\_CB\_RET\_MAX | (18U) | Maximum value of Call back reason |
| IMPDRV\_OFFSET\_4BYTE | (4U) | For 4 byte offset calculation |
| IMPDRV\_SHIFT\_8BIT | (8U) | For 8 bit shift calculation |
| IMPDRV\_SHIFT\_16BIT | (16U) | For 16 bit shift calculation |
| IMPDRV\_SHIFT\_24BIT | (24U) | For 24 bit shift calculation |
| IMPDRV\_SYNCC\_REGNUM | (4U) | Array size for SYNCC register |
| IMPDRV\_IMP\_CORENUM\_VAL | (4U) | Maximum number of cores for IMP. |
| IMPDRV\_IMP\_EXEPARAM\_CLBRK | (0U) | Index value of extend parameter for CL break address |
| IMPDRV\_REG\_IMP\_VCR | (0x0004U) | Offset address of VCR register for IMP. |
| IMPDRV\_REG\_IMP\_CNF | (0x0008U) | Offset address of CNF register for IMP. |
| IMPDRV\_REG\_IMP\_IFCFG | (0x0018U) | Offset address of CNFG register for IMP. |
| IMPDRV\_REG\_IMP\_IFCTL | (0x001CU) | Offset address of IFCTL register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR0 | (0x0040U) | Offset address of SYNCCR0 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR1 | (0x0044U) | Offset address of SYNCCR1 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR2 | (0x0048U) | Offset address of SYNCCR2 register for IMP. |
| IMPDRV\_REG\_IMP\_SYNCCR3 | (0x004CU) | Offset address of SYNCCR03 register for IMP. |
| IMPDRV\_REG\_IMP\_INTSTS | (0x0010U) | Offset address of INTSTS register for IMP. |
| IMPDRV\_REG\_IMP\_INTEN | (0x0014U) | Offset address of INTEN register for IMP. |
| IMPDRV\_REG\_IMP\_PSA | (0x0020U) | Offset address of PSA register for IMP. |
| IMPDRV\_REG\_IMP\_CLBRKADDRR | (0x00C0U) | Offset address of CLBRKADDRR register for IMP. |
| IMPDRV\_REG\_IMP\_HMPTR | (0x0514U) | Offset address of HMPTR register for IMP. |
| IMPDRV\_REG\_IMP\_HMDATA | (0x0518U) | Offset address of HMDATA register for IMP. |
| IMPDRV\_REG\_IMP\_HM1PTR | (0x0594U) | Offset address of HM1PTR register for IMP. |
| IMPDRV\_REG\_IMP\_HM1DATA | (0x0598U) | Offset address of HM1DATA register for IMP. |
| IMPDRV\_REG\_IMP\_MEM\_FUNC\_SA | (0x0B78U) | Offset address of SA register for IMP. |
| IMPDRV\_IMP\_VCR | (0x00600000U) | Hardware version value for IMP. |
| IMPDRV\_IMP\_CNF\_VAL | (0x00000001U) | CNF\_VAL register value for IMP. |
| IMPDRV\_IMP\_CNF\_SWRST | (0x80000000U) | CNF\_SWRST register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_EXE | (0x00000001U) | EXE register value for IMP. |
| IMPDRV\_IMP\_IFCFG\_VAL | (0x010010CCU) | IFCFG\_VAL register value for IMP. |
| IMPDRV\_IMP\_IFCTL\_ENDIAN | (0x22020200U) | ENDIAN register value for IMP. |
| IMPDRV\_IMP\_HMPTR\_VAL | (0x87FFU) | HMPTR\_VAL register value for IMP |
| IMPDRV\_IMP\_HMDATA\_VAL | (0x0000U) | HMDATA\_VAL register value for IMP. |
| IMPDRV\_IMP\_MEM\_FUNC\_SA\_VAL | (0x00FFU) | SA\_VAL register value for IMP. |
| IMPDRV\_IMP\_INTSTS\_MASKCPU | (0x10000000U) | MASKCPU interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_APIPINT | (0x00000001U) | APIPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_HPINT | (0x00000002U) | HPINT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_WUP | (0x04000000U) | WUP interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_INT | (0x00000020U) | INT interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_IER | (0x00000080U) | IER interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_TRAP | (0x00000040U) | TRAP interrupt enable registration. |
| IMPDRV\_IMP\_INTSTS\_CLR | (IMPDRV\_IMP\_INTSTS\_TRAP | IMPDRV\_IMP\_INTSTS\_IER | IMPDRV\_IMP\_INTSTS\_INT | IMPDRV\_IMP\_INTSTS\_WUP | IMPDRV\_IMP\_INTSTS\_HPINT | IMPDRV\_IMP\_INTSTS\_APIPINT | IMPDRV\_IMP\_INTSTS\_CLBRK) | CLR register value for IMP. |
| IMPDRV\_IMP\_REG\_MAX\_ADRS\_CNFCHK | (0x0001FFFFU) | End of offset address for ConfRegCheck of IMP |
| IMPDRV\_CNN\_CORENUM\_VAL | (1U) | Maximum number of cores for CNN. |
| IMPDRV\_CNN\_EXEPARAM\_CLBRK | (0U) | Index value of extend parameter for CL break address |
| IMPDRV\_REG\_CNN\_VCR | (0x0000U) | Offset address of VCR register for CNN. |
| IMPDRV\_CNN\_VCR | (0x00030200U) | Hardware version value for CNN. |
| IMPDRV\_REG\_CNN\_SWRST | (0x0008U) | Offset address of hardware register for SWRST. |
| IMPDRV\_REG\_CNN\_SR | (0x0010U) | Offset address of hardware register for SR. |
| IMPDRV\_REG\_CNN\_SRE | (0x0014U) | Offset address of hardware register for SRE. |
| IMPDRV\_REG\_CNN\_SRC | (0x0018U) | Offset address of hardware register for SRC. |
| IMPDRV\_REG\_CNN\_SRM | (0x001CU) | Offset address of hardware register for SRM. |
| IMPDRV\_REG\_CNN\_SACL | (0x0104U) | Offset address of hardware register for SACL |
| IMPDRV\_REG\_CNN\_SCLP | (0x0084U) | Offset address of hardware register for SCLP. |
| IMPDRV\_REG\_CNN\_CLBRKADDRR | (0x0114U) | Offset address of hardware register for CLBRKADDRR |
| IMPDRV\_REG\_CNN\_SYNCCR0 | (0x0900U) | Offset address of hardware register for SYNCCR0. |
| IMPDRV\_REG\_CNN\_SYNCCR1 | (0x0904U) | Offset address of hardware register for SYNCCR1. |
| IMPDRV\_REG\_CNN\_SYNCCR2 | (0x0908U) | Offset address of hardware register for YNCCR2. |
| IMPDRV\_REG\_CNN\_SYNCCR3 | (0x090CU) | Offset address of hardware register for MG2ISYNCCR3NTSEL. |
| IMPDRV\_CNN\_CNF\_SWRST | (0x00000001U) | SWRST register value for CNN. |
| IMPDRV\_CNN\_CNF\_CLR | (0x00000000U) | CLR register value for CNN. |
| IMPDRV\_CNN\_SR\_CLBUSY | (0x00002000U) | CLBSY register value for CNN. |
| IMPDRV\_CNN\_SR\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_CNN\_SR\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_CNN\_SR\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_CNN\_SR\_MSCO | (0x00000008U) | MSCO interrupt enable registration. |
| IMPDRV\_CNN\_SR\_WUPCOVF | (0x00004000U) | WUPCOVF interrupt enable registration. |
| IMPDRV\_CNN\_SR\_CLBRK | (0x00000020U) | CL break interrupt enable registration |
| IMPDRV\_CNN\_SCLP\_START | (0x00000001U) | CNN\_SCLP\_START register value for CNN |
| IMPDRV\_CNN\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of CNN |
| IMPDRV\_DMA\_CORENUM\_VAL | (4U) | Maximum number of cores for DMA. |
| IMPDRV\_DMA\_EXEPARAM\_CLBRK | (0U) | Index value of extend parameter for CL break address |
| IMPDRV\_DMA\_CORENUM0MAIN | (0U) | DMA Core 0 Main thread identification value. |
| IMPDRV\_DMA\_CORENUM0SUB | (1U) | DMA Core 0 Sub thread identification value. |
| IMPDRV\_DMA\_CORENUM1MAIN | (2U) | Offset address of VCR register for DMA. |
| IMPDRV\_DMA\_CORENUM1SUB | (3U) | DMA Core 1 Sub thread identification value. |
| IMPDRV\_REG\_DMA\_VCR | (0x0000U) | Offset address of VCR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR | (0x0004U) | Offset address of SCTLR register for DMA. |
| IMPDRV\_REG\_DMA\_SR | (0x0008U) | Offset address of SR register for DMA. |
| IMPDRV\_REG\_DMA\_SCR | (0x000CU) | Offset address of SCR register for DMA. |
| IMPDRV\_REG\_DMA\_SER | (0x0010U) | Offset address of SER register for DMA. |
| IMPDRV\_REG\_DMA\_IMR | (0x0014U) | Offset address of IMR register for DMA. |
| IMPDRV\_REG\_DMA\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for DMA. |
| IMPDRV\_REG\_DMA\_CLSAR | (0x0028U) | Offset address of CLSAR register for DMA. |
| IMPDRV\_REG\_DMA\_SR1 | (0x0030U) | Offset address of SR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR0 | (0x00E8U) | Offset address of SYNCCR0 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR1 | (0x00ECU) | Offset address of SYNCCR1 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR2 | (0x00F0U) | Offset address of SYNCCR2 register for DMA. |
| IMPDRV\_REG\_DMA\_SYNCCR3 | (0x00F4U) | Offset address of SYNCCR3 register for DMA. |
| IMPDRV\_DMA\_VCR | (0x17021420U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_SWRST | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR\_CLR | (0x00000000U) | Hardware version value for DMA. |
| IMPDRV\_DMA\_SCTLR1\_PS | (0x80000000U) | Hardware version value for DMA. |
| IMPDRV\_REG\_DMA\_THREAD\_OFFSET | (0x00000800U) | H/W Register offset for DMA sub-thread. |
| IMPDRV\_DMA\_SR\_TEND | (0x00000001U) | SA\_TEND interrupt enable registration. |
| IMPDRV\_DMA\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_DMA\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_DMA\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_DMA\_SR\_WUP | (0x00000080U) | WUP interrupt enable registration. |
| IMPDRV\_DMA\_SR\_CLBRK | (0x00000400U) | CLBRK interrupt enable registration |
| IMPDRV\_DMA\_SER\_FIX | (0x0000F300U) | Status Enable Registers that are always bit 1. |
| IMPDRV\_DMA\_RAMTSTR | (0x00D0U) | Offset address of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_MASK | (0x8000U) | Bit mask of RAMTSTR register for DMA. |
| IMPDRV\_DMA\_LOOPTIME\_VAL | (8U) | read count for register. |
| IMPDRV\_DMA\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of DMA. |
| IMPDRV\_OCV\_CORENUM\_VAL | (4U) | Maximum number of cores for OCV. |
| IMPDRV\_OCV\_EXEPARAM\_CLBRK | (0U) | Index value of extend parameter for CL break address |
| IMPDRV\_OCV\_OFFSET\_32B | (32U) | Offset 32byte for OCV. |
| IMPDRV\_REG\_OCV\_VCR0 | (0x0000U) | Offset address of VCR register for OCV. |
| IMPDRV\_REG\_OCV\_RSTR | (0x0008U) | Offset address of RSTR register for OCV. |
| IMPDRV\_REG\_OCV\_CR | (0x000CU) | Offset address of CR register for OCV. |
| IMPDRV\_REG\_OCV\_SR0 | (0x0010U) | Offset address of SR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SR1 | (0x0014U) | Offset address of SR1 register for OCV. |
| IMPDRV\_REG\_OCV\_SCR1 | (0x0018U) | Offset address of SCR1 register for OCV. |
| IMPDRV\_REG\_OCV\_ICR1 | (0x001CU) | Offset address of ICR1 register for OCV. |
| IMPDRV\_REG\_OCV\_IMR1 | (0x0020U) | Offset address of IMR1 register for OCV. |
| IMPDRV\_REG\_OCV\_MCR0 | (0x0040U) | Offset address of MCR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SR2 | (0x0024U) | Offset address of SR2 register for OCV. |
| IMPDRV\_REG\_OCV\_SCR2 | (0x0028U) | Offset address of SCR2 register for OCV. |
| IMPDRV\_REG\_OCV\_ICR2 | (0x002CU) | Offset address of ICR2 register for OCV. |
| IMPDRV\_REG\_OCV\_DLSAR | (0x0180U) | Offset address of DLSAR register for OCV. |
| IMPDRV\_REG\_OCV\_CLBRKADDRR | (0x03F4U) | Offset address of CLBRKADDRR register for OCV |
| IMPDRV\_REG\_OCV\_SYNCCR0 | (0x04C0U) | Offset address of SYNCCR0 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR1 | (0x04C4U) | Offset address of SYNCCR1 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR2 | (0x04C8U) | Offset address of SYNCCR2 register for OCV. |
| IMPDRV\_REG\_OCV\_SYNCCR3 | (0x04CCU) | Offset address of SYNCCR3 register for OCV. |
| IMPDRV\_REG\_OCV\_MEMINITR | (0x00F8U) | Offset address of MEMINITR register for OCV. |
| IMPDRV\_OCV\_VCR | (0x00000004U) | Hardware version value for OCV. |
| IMPDRV\_OCV\_RESET\_STATUS\_VAL | (0x00F10000U) | RESET\_STATUS value for OCV. |
| IMPDRV\_OCV\_WM\_INIT\_VAL | (0x00F1U) | Working Memory init value for OCV |
| IMPDRV\_OCV\_OFST\_START\_VAL | (0xC000U) | OFST\_START value for OCV. |
| IMPDRV\_OCV\_OFST\_END\_VAL | (0xE000U) | OFST\_END value for OCV. |
| IMPDRV\_OCV\_1KB\_VAL | (0x80064100U) | 1KB value for OCV. |
| IMPDRV\_OCV\_MCR0\_INIT\_VAL | (0x01000000U) | MCR0 value for OCV. |
| IMPDRV\_OCV\_CR\_PS | (0x00000001U) | PS register value for OCV. |
| IMPDRV\_OCV\_RSTR\_SWRST | (0x00000001U) | SWRST register value for OCV. |
| IMPDRV\_OCV\_RSTR\_CLR | (0x00000000U) | CLR register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL0 | (0x00040000U) | DCBANKSEL0register value for OCV. |
| IMPDRV\_OCV\_MCR0\_DCBANKSEL1 | (0x05000000U) | DCBANKSEL1 register value for OCV. |
| IMPDRV\_OCV\_SR1\_TRAP | (0x00000001U) | TRAP interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_IER | (0x00000002U) | IER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_INT | (0x00000004U) | INT interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_PBCOVF | (0x00000008U) | PBCOVF interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_SBO0ME | (0x00000010U) | SBO0ME interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_CLBRK | (0x00000400U) | CLBRK interrupt enable registration |
| IMPDRV\_OCV\_SR1\_USIER | (0x00001000U) | USIER interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_USINT | (0x00002000U) | USINT interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_WUPCOVF | (0x00004000U) | WUPCOVF interrupt enable registration. |
| IMPDRV\_OCV\_SR1\_UDIPSBRK | (0x10000000U) | UDIPSBRK interrupt enable registration |
| IMPDRV\_OCV\_SR1\_UDIVSBRK | (0x20000000U) | UDIVSBRK interrupt enable registration |
| IMPDRV\_OCV\_SR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in SR2 register. |
| IMPDRV\_OCV\_SCR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in SCR2 register |
| IMPDRV\_OCV\_ICR2\_MASK | (0xFFFFFFFFU) | Shader thread mask bits of used in ICR2 register |
| IMPDRV\_OCV\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of OCV |
| IMPDRV\_PSC\_CORENUM\_VAL | (1U) | Maximum number of cores for PSC. |
| IMPDRV\_PSC\_EXEPARAM\_CLBRK | (0U) | Index value of extend parameter for CL break address |
| IMPDRV\_REG\_PSC\_VCR | (0x0000U) | Offset address of VCR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR0 | (0x0004U) | Offset address of CTLR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SR | (0x0008U) | Offset address of SR register for PSC. |
| IMPDRV\_REG\_PSC\_SCR | (0x000CU) | Offset address of SCR register for PSC. |
| IMPDRV\_REG\_PSC\_SER | (0x0010U) | Offset address of SER register for PSC. |
| IMPDRV\_REG\_PSC\_IMR | (0x0014U) | Offset address of IMR register for PSC. |
| IMPDRV\_REG\_PSC\_SCTLR1 | (0x0018U) | Offset address of SCTLR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SR1 | (0x003CU) | Offset address of SR1 register for PSC. |
| IMPDRV\_REG\_PSC\_CLSAR | (0x0038U) | Offset address of CLSAR register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR0 | (0x0058U) | Offset address of SYNCCR0 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR1 | (0x0060U) | Offset address of SYNCCR1 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR2 | (0x0064U) | Offset address of SYNCCR2 register for PSC. |
| IMPDRV\_REG\_PSC\_SYNCCR3 | (0x0068U) | Offset address of SYNCCR3 register for PSC. |
| IMPDRV\_PSC\_VCR | (0x17020121U) | Hardware version value for PSC. |
| IMPDRV\_PSC\_SCTLR0\_SWRST | (0x80000000U) | SWRST register value for IMP. |
| IMPDRV\_PSC\_SCTLR0\_CLR | (0x00000000U) | CLR register value for IMP. |
| IMPDRV\_PSC\_SCTLR1\_CLE | (0x00000001U) | CLE register value for IMP. |
| IMPDRV\_PSC\_SR\_TEND | (0x00000001U) | TEND interrupt enable registration. |
| IMPDRV\_PSC\_SR\_TRAP | (0x00000010U) | TRAP interrupt enable registration. |
| IMPDRV\_PSC\_SR\_IER | (0x00000020U) | IER interrupt enable registration. |
| IMPDRV\_PSC\_SR\_INT | (0x00000040U) | INT interrupt enable registration. |
| IMPDRV\_PSC\_SR\_WUP | (0x00010000U) | WUP interrupt enable registration |
| IMPDRV\_PSC\_REG\_MAX\_ADRS\_CNFCHK | (0x0000FFFFU) | End of offset address for ConfRegCheck of PSC |
| IMPDRV\_OSAL\_DSP\_DEV\_NUM\_MAX | (IMPDRV\_DSP\_DEV\_NUM\_MAX + 1U) | Num of max sub device for OSAL DSP core. |
| IMPDRV\_CNN\_CLCNDGSBR\_MASK | (0x00000001U) | Bit mask for Condition for conditional GOSUB instruction. |
| IMPDRV\_CNN\_EXEPARAM\_GOSUB | (1U) | Index value of extend parameter for conditional GOSUB instruction. |
| IMPDRV\_REG\_CNN\_CLCNDGSBR | (0x0118U) | Offset address of CLCNDGSBR register for CNN. |
| IMPDRV\_DMA\_CLCNDGSBR\_MASK | (0x00000001U) | Bit mask for Condition for conditional GOSUB instruction. |
| IMPDRV\_DMA\_EXEPARAM\_GOSUB | (1U) | Index value of extend parameter for conditional GOSUB instruction. |
| IMPDRV\_REG\_DMA\_CLBRKADDRR | (0x03F4U) | Offset address of CLBRKADDRR register for DMA. |
| IMPDRV\_REG\_DMA\_CLCNDGSBR | (0x03FCU) | Offset address of CLCNDGSBR register for DMA. |
| IMPDRV\_DMAS\_CLCNDGSBR\_MASK | (0x00000001U) | Bit mask for Condition for conditional GOSUB instruction. |
| IMPDRV\_DMAS\_CORENUM1MAIN | (2U) | DMAS Core 1 Main thread identification value. |
| IMPDRV\_DMAS\_CORENUM1SUB | (3U) | DMAS Core 1 Sub thread identification value. |
| IMPDRV\_DMAS\_EXEPARAM\_CLBRK | (0U) | Index value of extend parameter for CL break address. |
| IMPDRV\_DMAS\_EXEPARAM\_GOSUB | (1U) | Index value of extend param for conditional GOSUB. |
| IMPDRV\_DMAS\_SR\_CLBRK | (0x00000400U) | CLBRK interrupt enable registration. |
| IMPDRV\_DMAS\_V1\_VCR | (0x20021013U) | Hardware version value for DMAS. |
| IMPDRV\_DMAS\_V2\_VCR | (0x22032218U) | Hardware version value for DMAS. |
| IMPDRV\_REG\_DMAS\_CLBRKADDRR | (0x03F4U) | Offset address of CLBRKADDRR register for DMA. |
| IMPDRV\_REG\_DMAS\_CLCNDGSBR | (0x03FCU) | Offset address of CLCNDGSBR register for DMAS. |
| IMPDRV\_DSP\_CORENUM\_VAL | (4U) | Maximum number of cores for IMP. |
| IMPDRV\_DSP\_REG\_MAX\_ADRS\_CNFCHK | (0x0019FFFFU) | End of offset address for ConfRegCheck of IMP. |
| IMPDRV\_DSP\_VDSP\_DEV\_MAIN | (0u) | VDSP device main. |
| IMPDRV\_DSP\_VDSP\_DEV\_SUB0 | (1u) | VDSP device sub0. |
| IMPDRV\_DSP\_VDSP\_DEV\_SUB1 | (2u) | VDSP device sub1. |
| IMPDRV\_DSP\_VDSP\_DEV\_SUB2 | (3u) | VDSP device sub2. |
| IMPDRV\_DSP\_VDSP\_DEV\_SUB3 | (4u) | VDSP device sub3. |
| IMPDRV\_DSP\_VDSP\_DEV\_SUB4 | (5u) | VDSP device sub4. |
| IMPDRV\_DSP\_VDSP\_DEV\_SUB5 | (6u) | VDSP device sub5. |
| IMPDRV\_DSP\_VDSP\_DEV\_SUB6 | (7u) | VDSP device sub6. |
| IMPDRV\_IMPREG\_ADDR\_END | (0xFFC00000U) | D\_ADD6\_START register REGION\_START value for VDSP. |
| IMPDRV\_IMPREG\_ADDR\_START | (0xF1000000U) | D\_ADD5\_START register REGION\_START value for VDSP. |
| IMPDRV\_REG\_IMPSLV\_DSP0CSTS | (0x00004014U) | Offset address of DSP ch0 Communication STaTus. |
| IMPDRV\_REG\_IMPSLV\_DSP1CSTS | (0x00004024U) | Offset address of DSP ch1 Communication STaTus. |
| IMPDRV\_REG\_IMPSLV\_DSP2CSTS | (0x00004034U) | Offset address of DSP ch2 Communication STaTus. |
| IMPDRV\_REG\_IMPSLV\_DSP3CSTS | (0x00004044U) | Offset address of DSP ch3 Communication STaTus. |
| IMPDRV\_REGOFS\_D\_ADD0\_ATT0 | (0x80924U) | Offset address of D\_ADD0\_ATT0 register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD0\_ATT1 | (0x80928U) | Offset address of D\_ADD1\_ATT1 register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD1\_ATT0 | (0x80934U) | Offset address of D\_ADD1\_ATT0 register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD1\_ATT1 | (0x80938U) | Offset address of D\_ADD1\_ATT1 register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD1\_START | (0x80930U) | Offset address of D\_ADD1\_START register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD2\_START | (0x80940U) | Offset address of D\_ADD2\_START register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD3\_ATT0 | (0x80954U) | Offset address of D\_ADD3\_ATT0 register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD3\_ATT1 | (0x80958U) | Offset address of D\_ADD3\_ATT1 register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD3\_START | (0x80950U) | Offset address of D\_ADD3\_START register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD4\_START | (0x80960U) | Offset address of D\_ADD4\_START register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD5\_ATT0 | (0x80974U) | Offset address of D\_ADD5\_ATT0 register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD5\_ATT1 | (0x80978U) | Offset address of D\_ADD5\_ATT1 register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD5\_START | (0x80970U) | Offset address of D\_ADD5\_START register for VDSP |
| IMPDRV\_REGOFS\_D\_ADD6\_START | (0x80980U) | Offset address of D\_ADD6\_START register for VDSP |
| IMPDRV\_REGOFS\_D\_DDCL | (0x8068CU) | Offset address of MMS\_DDCL register for VDSP |
| IMPDRV\_REGOFS\_D\_DDEA | (0x80680U) | Offset address of MMS\_DDEA register for VDSP |
| IMPDRV\_REGOFS\_D\_DDESC\_ID | (0x806A0U) | Offset address of MSS\_DDESC\_ID register for VDSP |
| IMPDRV\_REGOFS\_D\_DDIA | (0x80684U) | Offset address of MMS\_DDIA register for VDSP |
| IMPDRV\_REGOFS\_D\_DDTC | (0x80658U) | Offset address of MMS\_DDTC register for VDSP |
| IMPDRV\_REGOFS\_D\_SFT\_SCPD\_0 | (0x807E0U) | Offset address of IMPDRV\_REGOFS\_D\_SFT\_SCPD\_0 register for VDSP |
| IMPDRV\_REGOFS\_D\_SFT\_SCPD\_1 | (0x807E4U) | Offset address of IMPDRV\_REGOFS\_D\_SFT\_SCPD\_1 register for VDSP |
| IMPDRV\_REGOFS\_D\_SFT\_SCPD\_2 | (0x807E8U) | Offset address of IMPDRV\_REGOFS\_D\_SFT\_SCPD\_2 register for VDSP |
| IMPDRV\_REGOFS\_D\_SFT\_SCPD\_3 | (0x807ECU) | Offset address of IMPDRV\_REGOFS\_D\_SFT\_SCPD\_3 register for VDSP |
| IMPDRV\_REGOFS\_DMBE | (0x80604U) | Offset address of MSS\_DMBE register for VDSP |
| IMPDRV\_REGOFS\_MSS\_DMBA | (0x80600U) | Offset address of MSS\_DMBA register for VDSP |
| IMPDRV\_REGOFS\_MSS\_PCR | (0x80400U) | Offset address of MSS\_PCR register for VDSP |
| IMPDRV\_REGOFS\_P\_ADD0\_ATT0 | (0x80424U) | Offset address of P\_ADD0\_ATT0 register for VDSP |
| IMPDRV\_REGOFS\_P\_ADD1\_ATT0 | (0x8042CU) | Offset address of P\_ADD1\_ATT0 register for VDSP |
| IMPDRV\_REGOFS\_P\_ADD1\_START | (0x80428U) | Offset address of P\_ADD1\_START register for VDSP |
| IMPDRV\_REGOFS\_P\_ADD2\_ATT0 | (0x80434U) | Offset address of P\_ADD2\_ATT0 register for VDSP |
| IMPDRV\_REGOFS\_P\_ADD2\_START | (0x80430U) | Offset address of P\_ADD2\_START register for VDSP |
| IMPDRV\_REGOFS\_P\_ADD3\_ATT0 | (0x8043CU) | Offset address of P\_ADD3\_ATT0 register for VDSP |
| IMPDRV\_REGOFS\_P\_ADD3\_START | (0x80438U) | Offset address of P\_ADD3\_START register for VDSP. |
| IMPDRV\_REGOFS\_P\_ADD4\_START | (0x80440U) | Offset address of P\_ADD4\_START register for VDSP |
| IMPDRV\_REGOFS\_P\_CCOCR | (0x804E4U) | Offset address of P\_CCOCR register for VDSP |
| IMPDRV\_REGOFS\_P\_CCOSAR | (0x804E0U) | Offset address of P\_CCOSAR register for VDSP |
| IMPDRV\_REGOFS\_P\_PDEA | (0x80410U) | Offset address of P\_PDEA register for VDSP |
| IMPDRV\_REGOFS\_P\_PDIA | (0x80414U) | Offset address of P\_PDIA register for VDSP |
| IMPDRV\_REGOFS\_P\_PDTC | (0x80418U) | Offset address of P\_PDTC register for VDSP |
| IMPDRV\_REGOFS\_PSVM | (0x80E50U) | Offset address of PSVM register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_CONTROL | (0xC0038U) | Offset address of DSP\_CONTROL register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_GPIO\_IN | (0xC0014U) | Offset address of GPIO\_IN register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_GPIO\_OUT | (0xC0080U) | Offset address of GPIO\_OUT register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_ICU\_ACU\_LOCK | (0xC0004U) | Offset address of ICU\_ACU\_LOCK register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_OUT\_INT\_CLR | (0xC0044U) | Offset address of OUT\_INT\_CLR\_I register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_OUT\_INT\_EN | (0xC0040U) | Offset address of OUT\_INT\_EN\_I register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_OUT\_INT\_MSK | (0xC0048U) | Offset address of OUT\_INT\_MSK\_I register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_OUT\_INT\_STA | (0xC004CU) | Offset address of OUT\_INT\_STATE\_I register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_PSU\_STATE | (0xC007CU) | Offset address of PSU\_STATE register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_RST\_VEC\_ADR | (0xC0010U) | Offset address of RESET\_VEC register for VDSP |
| IMPDRV\_REGOFS\_VDSP\_VERSION1 | (0xC0094U) | Offset address of VERSION1 register for VDSP. |
| IMPDRV\_REGVAL\_CLR | (0x00000000U) | register clear value for VDSP. |
| IMPDRV\_REGVAL\_D\_SFT\_SCPD\_0\_OFF | (0x00U) | table num for crc rable. |
| IMPDRV\_REGVAL\_D\_SFT\_SCPD\_0\_ON | (0x01U) | table num for crc rable. |
| IMPDRV\_REGVAL\_DMBE\_IDLE | (0x00011FFFU) | MSS\_DMBE register value for VDSP |
| IMPDRV\_REGVAL\_DMBE\_INIT | (0x00000000U) | MSS\_DMBE register value for VDSP. |
| IMPDRV\_REGVAL\_IMPSLV\_DSPNCSTS | (0x00000000U) | DSPnCSTS register value. |
| IMPDRV\_REGVAL\_OUT\_INT\_TIMER00 | (0x0001U) | I\_TIMER00 value for VDSP. |
| IMPDRV\_REGVAL\_OUT\_INT\_TIMER01 | (0x0002U) | I\_TIMER00 value for VDSP. |
| IMPDRV\_REGVAL\_PSU\_STATE\_LSP | (0x00000008U) | PSU\_STATE register LIGHT\_SLP\_MD value for VDSP. |
| IMPDRV\_REGVAL\_PSU\_STATE\_SBY | (0x00000004U) | PSU\_STATE register STANDBY\_MD value for VDSP. |
| IMPDRV\_REGVAL\_PSVM\_PMOD\_SBY | (0x00000003U) | PSVM register value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_ACU\_LOCK | (0x0U) | ICU\_ACU\_LOCK register lock value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_ACU\_UNLOCK | (0x8U) | ICU\_ACU\_LOCK register unlock value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_BSZ\_8\_INCR | (0xA0) | MSS\_DDCL register BSZ 1000: 128 transfers (INCR) value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_CRC\_ERROR | (0x80000000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_CRITICAL\_INT | (0x20000000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_DIV0 | (0x08000000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_ERROR | (0xFF000000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_EXT\_DABSZ8 | ((uint32\_t)0xAU << 9U) | D\_ADDx\_ATT1 register DABSZ value for VDSP |
| IMPDRV\_REGVAL\_VDSP\_EXT\_DADOL | ((uint32\_t)0xFU << 13U) | D\_ADDx\_ATT1 register DADOL value for VDSP |
| IMPDRV\_REGVAL\_VDSP\_EXT\_DAUOL | ((uint32\_t)0x4U << 18U) | D\_ADDx\_ATT1 register DAUOL value for VDSP |
| IMPDRV\_REGVAL\_VDSP\_EXT\_DPRAW | ((uint32\_t)0x1U << 29U) | D\_ADDx\_START register DPRAW value for VDSP |
| IMPDRV\_REGVAL\_VDSP\_EXT\_L2A\_RD | ((uint32\_t)0x2U << 5U) | D\_ADDx\_ATT1 register L2A\_RD value for VDSP |
| IMPDRV\_REGVAL\_VDSP\_EXT\_L2A\_WR | ((uint32\_t)0x2U << 1U) | D\_ADDx\_ATT1 register L2A\_WR value for VDSP |
| IMPDRV\_REGVAL\_VDSP\_EXT\_MOM | ((uint32\_t)0x1U << 16U) | D\_ADDx\_ATT0 register MOM value for VDSP |
| IMPDRV\_REGVAL\_VDSP\_GPIO\_FSTDBY | (0x00000800U) | GPIO\_IN register F standby value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_GPIO\_RESUME | (0x00002000U) | GPIO\_OUT register resume value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_GPIO\_START | (0x00000008U) | GPIO\_IN register start value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_GPIO\_STDBY | (0x00000001U) | GPIO\_OUT register standby value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_GPIO\_STOP | (0x00000080U) | GPIO\_OUT register stop value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_ICU\_LOCK | (0x1U) | ICU\_ACU\_LOCK register lock value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_ICU\_UNLOCK | (0x0U) | ICU\_ACU\_LOCK register unlock value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_INT | (0x00020000U) | GPIO\_OUT register INT value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_MSS\_PCR | (((uint32\_t)1U << 2U) | ((uint32\_t)1U << 6U) | ((uint32\_t)1U << 7U) | ((uint32\_t)3U << 8U) | ((uint32\_t)1U << 12U)) | MSS\_PCR register value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_NORMAL\_INT | (0x40000000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_P\_CCOCR\_IV | (((uint32\_t)1U << 0U) | ((uint32\_t)1U << 1U) | ((uint32\_t)4U << 2U) | ((uint32\_t)1U << 7U) | ((uint32\_t)1024U << 16U)) | P\_CCOCR register Invalidate value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_P\_CCOCR\_PF | (((uint32\_t)1U << 0U) | ((uint32\_t)1U << 1U) | ((uint32\_t)3U << 2U) | ((uint32\_t)1U << 7U) | ((uint32\_t)1024U << 16U)) | P\_CCOCR register Pre-fetched value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_REG\_ACT | ((uint32\_t)0U << 28U) | D\_ADDx\_START register INACTIVE active value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_REG\_AXI0 | ((uint32\_t)0x2U << 20U) | D\_ADDx\_START register REGION\_MID AXIm0 value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_REG\_BLANK | ((uint32\_t)0x80U << 20U) | D\_ADDx\_START register REGION\_MID Blank region value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_REG\_EDP | ((uint32\_t)0x1U << 20U) | D\_ADDx\_START register REGION\_MID EDP value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_REG\_INACT | ((uint32\_t)1U << 28U) | D\_ADDx\_START register INACTIVE not active value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_RESUME | (0x00020000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_SAFETY\_ERROR | (0x10000000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_STACK\_VIOLATION | (0x02000000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_TIM\_FAULT | (0x01000000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_TRAP | (0x00010000U) | GPIO\_OUT register TRAP value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_VERSION1 | (0x20111119U) | Hardware version value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_WDOG\_EXPIRE | (0x04000000U) | GPIO\_OUT register error value for VDSP. |
| IMPDRV\_SPMX\_ADDR\_END | (0xED600000U) | D\_ADD4\_START register REGION\_START value for VDSP. |
| IMPDRV\_SPMX\_ADDR\_START | (0xED300000U) | D\_ADD3\_START register REGION\_START value for VDSP. |
| IMPDRV\_VDSP\_CB\_CODE\_INT | (1) | Callback code INT. |
| IMPDRV\_VDSP\_CB\_CODE\_TRAP | (0) | Callback code TRAP. |
| IMPDRV\_VDSP\_CHANNEL\_OPE\_BITS | (0x0FU) | Channel operate bits. |
| IMPDRV\_VDSP\_CONTROL\_PLOAD\_STOP | (0x0001U) | DSP\_CONTROL register PLOAD\_STOP value for VDSP. |
| IMPDRV\_VDSP\_D\_ADDR\_SHIFT | (12U) | D\_ADDx\_START register data shift for VDSP. |
| IMPDRV\_VDSP\_D\_DDCL\_DDIE\_ENABLE | (400U) | The maximum wait loop count for the D\_DDCL register. |
| IMPDRV\_VDSP\_D\_DDCL\_DDIE\_RESET | (0U) | The maximum wait loop count for the D\_DDCL register. |
| IMPDRV\_VDSP\_D\_DDCL\_WAIT\_LOOP | (100000U) | The maximum wait loop count for the D\_DDCL register. |
| IMPDRV\_VDSP\_DDMA\_BUSY\_MASK | ((uint32\_t)1U<<8U) | MSS\_DDCL register DDMA\_BUSY mask for VDSP. |
| IMPDRV\_VDSP\_DMBE\_WAIT\_LOOP | (100U) | The maximum wait loop count for the MSS\_DMBE register. |
| IMPDRV\_VDSP\_EXT\_MEM\_END | (0xC0000000U) | Valid DSP application execution end address. |
| IMPDRV\_VDSP\_EXT\_MEM\_START | (0x40000000U) | Valid DSP application execution start address. |
| IMPDRV\_VDSP\_GPIO\_WAIT\_LOOP | (0x00100000U) | The maximum wait loop count for the GPIO register. |
| IMPDRV\_VDSP\_IDM\_FIXED\_SIZE\_64KB | ((uint32\_t)0x4000U) | IDM Fixed size |
| IMPDRV\_VDSP\_IPM\_FIXED\_SIZE\_8KB | ((uint32\_t)0x2000U) | IPM Fixed size |
| IMPDRV\_VDSP\_P\_ADDX\_ATT0 | (0x1U) | P\_ADDx\_ATT0 register L1IC value for VDSP. |
| IMPDRV\_VDSP\_P\_AP\_ATT0 | ((uint32\_t)0x3U << 4U) | P\_ADDx\_ATT0 register P\_AP value for VDSP. |
| IMPDRV\_VDSP\_P\_CCOCR\_WAIT\_LOOP | (100000U) | The maximum wait loop count for the P\_CCOCR register. |
| IMPDRV\_VDSP\_P\_CCOSA\_MASK | (0xFFFFFFC0U) | P\_CCOSAR register P\_CCOSA mask for VDSP. |
| IMPDRV\_VDSP\_P\_L1ICO\_MASK | ((uint32\_t)1U << 1U) | P\_CCOCR register P\_L1ICO mask for VDSP. |
| IMPDRV\_VDSP\_P\_L2A\_ATT0 | ((uint32\_t)0x2U << 8U) | P\_ADDx\_ATT0 register P\_L2A value for VDSP. |
| IMPDRV\_VDSP\_P\_PDTC\_WAIT\_LOOP | (100000U) | The maximum wait loop count for the P\_PDTC register. |
| IMPDRV\_VDSP\_PSU\_ST\_SLP\_LOOP | (100U) | Maximum wait loop count until PSU\_STATE register is in sleep mode. |
| IMPDRV\_VDSP\_PSU\_ST\_STD\_LOOP | (10U) | Maximum wait loop count until PSU\_STATE register is in stand by mode. |
| IMPDRV\_VDSP\_REGVAL\_PDMA\_BUSY | ((uint32\_t)1U << 29U) | P\_PDTC register PDTC PDMA BUSY value for VDSP. |
| IMPDRV\_IMP\_CLCNDGSBR\_MASK | (0x00000001U) | Bit mask for Condition for conditional GOSUB instruction. |
| IMPDRV\_IMP\_EXEPARAM\_GOSUB | (1U) | Index value of extend parameter for conditional GOSUB instruction. |
| IMPDRV\_IMP\_INTSTS\_CLBRK | (0x00000400U) | CLBRK interrupt enable registration. |
| IMPDRV\_REG\_IMP\_CLCNDGSBR | (0x00C4U) | Offset address of CLCNDGSBR register for IMP. |
| IMPDRV\_OCV\_CLCNDGSBR\_MASK | (0x00000001U) | Bit mask for Condition for conditional GOSUB instruction. |
| IMPDRV\_OCV\_EXEPARAM\_GOSUB | (1U) | Index value of extend parameter for conditional GOSUB instruction. |
| IMPDRV\_REG\_OCV\_CLCNDGSBR | (0x03FCU) | Offset address of CLCNDGSBR register for OCV. |
| IMPDRV\_PSC\_CLCNDGSBR\_MASK | (0x00000001U) | Bit mask for Condition for conditional GOSUB instruction. |
| IMPDRV\_PSC\_EXEPARAM\_GOSUB | (1U) | Index value of extend parameter for conditional GOSUB instruction. |
| IMPDRV\_PSC\_SR\_CLBRK | (0x00000400U) | CLBRK interrupt enable registration. |
| IMPDRV\_REG\_PSC\_CLBRKADDRR | (0x03F4U) | Offset address of CLBRKADDRR register for PSC. |
| IMPDRV\_REG\_PSC\_CLCNDGSBR | (0x03FCU) | Offset address of CLCNDGSBR register for PSC. |
| IMPDRV\_CRC\_TABLE\_MAX | (256) | table num for crc rable. |
| IMPDRV\_DSP\_CORENUM\_VAL | (2U) | Maximum number of cores for IMP. |
| IMPDRV\_DSP\_VDSP\_DEV\_MAIN | (0u) | Interrupt |
| IMPDRV\_DSP\_VDSP\_DEV\_SUB7 | (8u) | VDSP device sub7. |
| IMPDRV\_REGVAL\_VDSP\_TRAP | (0x00010000U) | GPIO\_OUT register INT value for VDSP. |
| IMPDRV\_REGVAL\_VDSP\_VERSION1 | (0x20211220U) | Hardware version value for VDSP. |
| IMPDRV\_SPMX\_ADDR\_START | (0xED200000U) | D\_ADD3\_START register REGION\_START value for VDSP. |

#### OS Dependence Layer

Table 5‑55: Definition Values (OS Dependence Layer)

|  |  |  |
| --- | --- | --- |
| Name | Value | Description |
| IMPDRV\_IMPTOP\_DEV\_TYPE | (“imp\_top”) | Static OSAL resource definition for “imp\_top”. |
| IMPDRV\_DEV\_LIST\_SIZE | (255U) | Buffer size for R\_OSAL\_IoGetDeviceList. |
| IMPDRV\_REG\_OFFSET\_MAX | (1024U \* 256U \* 8U) | Maximum value for Register offset. |
| IMPDRV\_IRQ\_CHANNEL\_0 | (0U) | IRQ channel number (0) |
| IMPDRV\_IRQ\_CHANNEL\_1 | (1U) | IRQ channel number (1) |
| IMPDRV\_IRQ\_CHANNEL\_2 | (2U) | IRQ channel number (2) |
| IMPDRV\_IRQ\_CHANNEL\_3 | (3U) | IRQ channel number (3) |
| IMPDRV\_IRQ\_CHANNEL\_4 | (4U) | IRQ channel number (4) |
| IMPDRV\_IRQ\_CHANNEL\_5 | (5U) | IRQ channel number (5) |
| IMPDRV\_IRQ\_CHANNEL\_6 | (6U) | IRQ channel number (6) |
| IMPDRV\_IRQ\_CHANNEL\_MAX | (7U) | Maximum value for IRQ channel |
| IMPDRV\_DUMMY\_UINT64 | (0xFFFFFFFFFFFFFFFFULL) | Uint64\_t dummy value. |
| IMPDRV\_QUEUE\_MAX\_NUMBER | (2U) | Maximum number of message queues |
| IMPDRV\_QUEUE\_MAX\_MSG\_SIZE | (sizeof(uint32\_t)) | Message size from interrupt handler |
| IMPDRV\_DSP\_CORE\_0 | (0U) | DSP core number (0). |
| IMPDRV\_DSP\_CORE\_1 | (1U) | DSP core number (1). |
| IMPDRV\_DSP\_CORE\_2 | (2U) | DSP core number (2). |
| IMPDRV\_DSP\_CORE\_3 | (3U) | DSP core number (3). |
| IMPDRV\_DSP\_VDSP\_DEV\_SUB1 | (2U) | num of sub device for vsdp\*\_reg. |

### Enum

#### API Layer

##### e\_impdrv\_errorcode\_t

Table 5‑56: e\_impdrv\_errorcode\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_EC\_OK = 0,  IMPDRV\_EC\_NG\_CHECKFAIL = -200,  IMPDRV\_EC\_NG\_SEQSTATE = -201,  IMPDRV\_EC\_NG\_SYSTEMERROR = -205,  IMPDRV\_EC\_NG\_ARGNULL = -207,  IMPDRV\_EC\_NG\_PARAM = -208,  IMPDRV\_EC\_NG\_ATTRIBUTE = -209,  IMPDRV\_EC\_NG\_NOTSUPPORT = -210,  IMPDRV\_EC\_NG\_PMSYSTEMERROR = -211,  IMPDRV\_EC\_NG\_INSTANCE = -212,  IMPDRV\_EC\_NG\_DSP\_HALT = -213  } e\_impdrv\_errorcode\_t; | | |
| **Description** | IMP Driver notifies the user of an error by this result value. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_EC\_OK | 0 | Successful completion. |
| IMPDRV\_EC\_NG\_CHECKFAIL | -200 | This error is caused by the safety mechanism check fails. |
| IMPDRV\_EC\_NG\_SEQSTATE | -201 | Sequence Error.  This error occurs by illegal state transition.  In this case, modify the function order to call the function from the correct state machine. |
| IMPDRV\_EC\_NG\_SYSTEMERROR | -205 | System error.  This error occurs by hardware error in IMP-X6 or OSAL function error.  In this case, execute system reset or reconsider the OSAL settings and try again. |
| IMPDRV\_EC\_NG\_ARGNULL | -207 | Arguments is NULL.  This error occurs by setting the argument to NULL.  In this case, the user can continue by put the correct pointer to the argument. |
| IMPDRV\_EC\_NG\_PARAM | -208 | Parameter error.  This error occurs by specifying an invalid parameter.  In this case, the user can continue by put the correct value to the argument. |
| IMPDRV\_EC\_NG\_ATTRIBUTE | -209 | This error is caused by not accurate setting the attribute. In this case, the user can continue by setting the attributes required by the following functions:  ・R\_IMPDRV\_Start  ・R\_IMPDRV\_Execute |
| IMPDRV\_EC\_NG\_NOTSUPPORT | -210 | Not supported parameter error.  Occurs when you specify a core type or core number that hardware does not support.  In this case, the user can continue by put the correct value to the argument. |
| IMPDRV\_EC\_NG\_PMSYSTEMERROR | -211 | PMSystem error.  This error occurs by OSAL function (only Power Management function) error.  In this case, execute system reset or reconsider the OSAL settings and try again. |
| IMPDRV\_EC\_NG\_INSTANCE | -212 | Instance parameter error.  Checking for errors between instances. |
| IMPDRV\_EC\_NG\_DSP\_HALT | -213 | VDSP error notice |
| **Remarks** | N/A | | |

##### e\_impdrv\_core\_type\_t

Table 5‑57: e\_impdrv\_core\_type\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_CORE\_TYPE\_INVALID = 0,  IMPDRV\_CORE\_TYPE\_IMP ,  IMPDRV\_CORE\_TYPE\_IMP\_SLIM ,  IMPDRV\_CORE\_TYPE\_OCV ,  IMPDRV\_CORE\_TYPE\_DMAC ,  IMPDRV\_CORE\_TYPE\_DMAC\_SLIM ,  IMPDRV\_CORE\_TYPE\_PSCEXE ,  IMPDRV\_CORE\_TYPE\_PSCOUT ,  IMPDRV\_CORE\_TYPE\_CNN ,  IMPDRV\_CORE\_TYPE\_DSP ,  IMPDRV\_CORE\_TYPE\_DTA ,  IMPDRV\_CORE\_TYPE\_IMR = 1000,  IMPDRV\_CORE\_TYPE\_LDMAC  } e\_impdrv\_core\_type\_t; | | |
| **Description** | IMP Driver determines the core type, selected by this value. | | |
| **Enumerato**  **r** | **Name** | **Value** | **Description** |
| IMPDRV\_CORE\_TYPE\_INVALID | 0 | Core type number of Invalid value. |
| IMPDRV\_CORE\_TYPE\_IMP | 1 | Core type number of IMP core. |
| IMPDRV\_CORE\_TYPE\_IMP\_SLIM | 2 | Core type number of Slim-IMP core. |
| IMPDRV\_CORE\_TYPE\_OCV | 3 | Core type number of OCV core. |
| IMPDRV\_CORE\_TYPE\_DMAC | 4 | Core type number of IMP DMAC. |
| IMPDRV\_CORE\_TYPE\_DMAC\_SLIM | 5 | Core type number of Slim-DMAC core. |
| IMPDRV\_CORE\_TYPE\_PSCEXE | 6 | Core type number of IMP PSC. This type can be specified only in “core” parameter for APIs. |
| IMPDRV\_CORE\_TYPE\_PSCOUT | 7 | Core type number of IMP PSC output. This type can be specified only in “coremap” parameter for R\_IMPDRV\_Start. Refer the note of Core map definition for detail. |
| IMPDRV\_CORE\_TYPE\_CNN | 8 | Core type number of IMP CNN. |
| IMPDRV\_CORE\_TYPE\_DSP | 9 | Core type number of DSP. |
| IMPDRV\_CORE\_TYPE\_DTA | 10 | Core type number of DTA. |
| IMPDRV\_CORE\_TYPE\_IMR | 1000 | Core type number of IMR. (Other than IMP-Xn) |
| IMPDRV\_CORE\_TYPE\_LDMAC | 1001 | Core type number of Lock Step DMAC core |
| **Remarks** | N/A | | |

##### e\_impdrv\_instance\_t

Table 5‑58: e\_impdrv\_instance\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_INSTANCE\_INVALID = 0  IMPDRV\_INSTANCE\_0 ,  IMPDRV\_INSTANCE\_1 ,  IMPDRV\_INSTANCE\_2 ,  IMPDRV\_INSTANCE\_3 ,  IMPDRV\_INSTANCE\_4 ,  IMPDRV\_INSTANCE\_5 ,  IMPDRV\_INSTANCE\_6  } e\_impdrv\_instance\_t; | | |
| **Description** | IMP Driver determines the Instance number(with related IRQ number), selected by this value. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_INSTANCE\_INVALID | 0 | Invalid value |
| IMPDRV\_INSTANCE\_0 | 1 | Instance number (0) SPI 576 Domain0 Interrupt |
| IMPDRV\_INSTANCE\_1 | 2 | Instance number (1) SPI 577 Domain0 Interrupt |
| IMPDRV\_INSTANCE\_2 | 3 | Instance number (2) SPI 578 Domain0 Interrupt |
| IMPDRV\_INSTANCE\_3 | 4 | Instance number (3) SPI 579 Domain1 Interrupt |
| IMPDRV\_INSTANCE\_4 | 5 | Instance number (4) SPI 580 Domain1 Interrupt |
| IMPDRV\_INSTANCE\_5 | 6 | Instance number (5) SPI 581 Domain1 Interrupt |
| IMPDRV\_INSTANCE\_6 | 7 | Instance number (6) SPI 582 Merge Interrupt |
| **Remarks** | N/A | | |

##### e\_impdrv\_irq\_group\_t

Table 5‑59: e\_impdrv\_irq\_group\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_IRQ\_GROUP\_INVALID = 0,  IMPDRV\_IRQ\_GROUP\_NONE ,  IMPDRV\_IRQ\_GROUP\_0 ,  IMPDRV\_IRQ\_GROUP\_1 ,  IMPDRV\_IRQ\_GROUP\_2  } e\_impdrv\_irq\_group\_t; | | |
| **Description** | IMP Driver determines the Interrupt group of st\_impdrv\_irq\_group\_t, selected by this value. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_IRQ\_GROUP\_INVALID | 0 | Invalid value |
| IMPDRV\_IRQ\_GROUP\_NONE | 1 | No group settings. |
| IMPDRV\_IRQ\_GROUP\_0 | 2 | IRQ group 0. |
| IMPDRV\_IRQ\_GROUP\_1 | 3 | IRQ group 1. |
| IMPDRV\_IRQ\_GROUP\_2 | 4 | IRQ group 2. |
| **Remarks** | N/A | | |

##### e\_impdrv\_cb\_ret\_t

Table 5‑60: e\_impdrv\_cb\_ret\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_CB\_RET\_OK = 0,  IMPDRV\_CB\_RET\_BEFORE\_EXEC ,  IMPDRV\_CB\_RET\_RESERVED ,  IMPDRV\_CB\_RET\_ILLEGAL ,  IMPDRV\_CB\_RET\_INT ,  IMPDRV\_CB\_RET\_CLBRK ,  IMPDRV\_CB\_RET\_PBCOVF ,  IMPDRV\_CB\_RET\_INT\_PBCOVF ,  IMPDRV\_CB\_RET\_USIER ,  IMPDRV\_CB\_RET\_SBO0ME ,  IMPDRV\_CB\_RET\_INT\_SBO0ME ,  IMPDRV\_CB\_RET\_TRAP\_SBO0ME ,  IMPDRV\_CB\_RET\_WUPCOVF ,  IMPDRV\_CB\_RET\_HPINT ,  IMPDRV\_CB\_RET\_APIPINT ,  IMPDRV\_CB\_RET\_USINT ,  IMPDRV\_CB\_RET\_END ,  IMPDRV\_CB\_RET\_MSCO ,  IMPDRV\_CB\_RET\_UDIVSBRK ,  IMPDRV\_CB\_RET\_UDIPSBRK ,  IMPDRV\_CB\_RET\_DSP\_HALT  } e\_impdrv\_cb\_ret\_t; | | |
| **Description** | IMP driver notifies the user of the callback results by this result value. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_CB\_RET\_OK | 0 | Arguments of callback function. (Normal) |
| IMPDRV\_CB\_RET\_BEFORE\_EXEC | 1 | Arguments of callback function. (Before CL execute) |
| IMPDRV\_CB\_RET\_RESERVED | 2 | Reserved definition. |
| IMPDRV\_CB\_RET\_ILLEGAL | 3 | Arguments of callback function. (Illegal error) |
| IMPDRV\_CB\_RET\_INT | 4 | Arguments of callback function. (INT interrupt) |
| IMPDRV\_CB\_RET\_CLBRK | 5 | CLBRK interrupt |
| IMPDRV\_CB\_RET\_PBCOVF | 6 | Arguments of callback function. (In the case of “Performance Busy Counter Overflow” ) |
| IMPDRV\_CB\_RET\_INT\_PBCOVF | 7 | Arguments of callback function. (In the case of ”Performance Busy Counter Overflow” and “INT interrupt”.) |
| IMPDRV\_CB\_RET\_USIER | 8 | Arguments of callback function. (In the case of “USIER” error.) |
| IMPDRV\_CB\_RET\_SBO0ME | 9 | Arguments of callback function.( In the case of “SBO0ME) |
| IMPDRV\_CB\_RET\_INT\_SBO0ME | 10 | Arguments of callback function. (In the case of ” SBO0ME” and “INT interrupt”.) |
| IMPDRV\_CB\_RET\_TRAP\_SBO0ME | 11 | Arguments of callback function. (In the case of ” SBO0ME” and “ TRAP interrupt”.) |
| IMPDRV\_CB\_RET\_WUPCOVF | 12 | In the case of “WUPCOVF” error |
| IMPDRV\_CB\_RET\_HPINT | 13 | In the case of “HPINT interrupt” |
| IMPDRV\_CB\_RET\_APIPINT | 14 | In the case of “APIPINT interrupt” |
| IMPDRV\_CB\_RET\_USINT | 15 | In the case of “USINT interrupt” |
| IMPDRV\_CB\_RET\_END | 16 | In the case of “END interrupt” |
| IMPDRV\_CB\_RET\_MSCO | 17 | In the case of “MSCO interrupt” |
| IMPDRV\_CB\_RET\_UDIVSBRK | 18 | In the case of “UDIVSBRK interrupt” |
| IMPDRV\_CB\_RET\_UDIPSBRK | 19 | In the case of “UDIPSBRK interrupt” |
| IMPDRV\_CB\_RET\_DSP\_HALT | 20 | In the case of "VDSP error notice" |
| **Remarks** | N/A | | |

##### e\_impdrv\_pm\_policy\_t

Table 5‑61: e\_impdrv\_pm\_policy\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_PM\_POLICY\_INVALID = 0,  IMPDRV\_PM\_POLICY\_CG ,  IMPDRV\_PM\_POLICY\_PG ,  IMPDRV\_PM\_POLICY\_HP  } e\_impdrv\_pm\_policy\_t; | | |
| **Description** | Power management policy. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_PM\_POLICY\_INVALID | 0 | Invalid value |
| IMPDRV\_PM\_POLICY\_CG | 1 | Specify the “Power Gated Policy” of power management, “Clock domain OFF / Power domain ON” when the core is stopped. |
| IMPDRV\_PM\_POLICY\_PG | 2 | Specify the “Clock Gated Policy” of power management, “Clock domain OFF / Power domain OFF” when the core is stopped. |
| IMPDRV\_PM\_POLICY\_HP | 3 | Specify the “High Performance Policy” of power management, “Clock domain ON / Power domain ON” when the core is stopped. |
| **Remarks** | N/A | | |

##### e\_impdrv\_param\_t

Table 5‑62: e\_impdrv\_param\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_PARAM\_INVALID = 0,  IMPDRV\_PARAM\_OFF,  IMPDRV\_PARAM\_ON  } e\_impdrv\_param\_t; | | |
| **Description** | Generic enum for parameters ON and OFF. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_PARAM\_INVALID | 0 | Invalid value |
| IMPDRV\_PARAM\_OFF | 1 | Parameter OFF. |
| IMPDRV\_PARAM\_ON | 2 | Parameter ON. |
| **Remarks** | N/A | | |

##### e\_impdrv\_irqmask\_t

Table 5‑63: e\_impdrv\_irqmask\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_IRQMASK\_END = 0,  IMPDRV\_IRQMASK\_WUPCOVF,  IMPDRV\_IRQMASK\_USIER,  IMPDRV\_IRQMASK\_USINT,  IMPDRV\_IRQMASK\_PBCOVF,  IMPDRV\_IRQMASK\_SBO0ME,  IMPDRV\_IRQMASK\_HPINT,  IMPDRV\_IRQMASK\_APIPINT,  IMPDRV\_IRQMASK\_MSCO  } e\_impdrv\_irqmask\_t; | | |
| **Description** | IMPDRV interrupt mask | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_IRQMASK\_END | 0 | Disable to interrupt for END |
| IMPDRV\_IRQMASK\_WUPCOVF | 1 | Disable to interrupt for WUPCOVF |
| IMPDRV\_IRQMASK\_USIER | 2 | Disable to interrupt for USIER |
| IMPDRV\_IRQMASK\_USINT | 3 | Disable to interrupt for USINT |
| IMPDRV\_IRQMASK\_PBCOVF | 4 | Disable to interrupt for PBCOVF |
| IMPDRV\_IRQMASK\_SBO0ME | 5 | Disable to interrupt for SBO0ME |
| IMPDRV\_IRQMASK\_HPINT | 6 | Disable to interrupt for HPINT |
| IMPDRV\_IRQMASK\_APIPINT | 7 | Disable to interrupt for APIPINT |
| IMPDRV\_IRQMASK\_MSCO | 8 | Disable to interrupt for MSCO |
| **Remarks** | N/A | | |

##### e\_impdrv\_fatalcode\_t

Table 5‑64: e\_impdrv\_fatalcode\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_FC\_DRV\_ERROR = 0,  IMPDRV\_FC\_UNEXPECT\_INT  } e\_impdrv\_fatalcode\_t; | | |
| **Description** | IMPDRV fatal error code. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_FC\_DRV\_ERROR | 0 | Driver Internal Error. |
| IMPDRV\_FC\_UNEXPECT\_INT | 1 | Unexpected interrupt. |
| **Remarks** | N/A | | |

##### e\_impdrv\_protect\_mode\_t

Table 5‑65: e\_impdrv\_protect\_mode\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_PROTECT\_INVALID = 0,  IMPDRV\_PROTECT\_EDC,  IMPDRV\_PROTECT\_ECC  } e\_impdrv\_protect\_mode\_t;; | | |
| **Description** | IMPDRV Select of Memory protection mode (EDC/ECC). | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_PROTECT\_INVALID | 0 | Invalid value |
| IMPDRV\_PROTECT\_EDC | 1 | EDC mode |
| IMPDRV\_PROTECT\_ECC | 2 | ECC mode |
| **Remarks** | N/A | | |

##### e\_impdrv\_reg\_req\_state\_t

Table 5‑66: e\_impdrv\_reg\_req\_state\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_REG\_REQ\_STATE\_INVALID = 0,  IMPDRV\_REG\_REQ\_STATE\_REQUIRED,  IMPDRV\_REG\_REQ\_STATE\_RELEASED  } e\_impdrv\_reg\_req\_state\_t; | | |
| **Description** | IMPDRV Required state to the Register read/write function. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_REG\_REQ\_STATE\_INVALID | 0 | Invalid state |
| IMPDRV\_REG\_REQ\_STATE\_REQUIRED | 1 | Required state |
| IMPDRV\_REG\_REQ\_STATE\_RELEASED | 2 | Release state |
| **Remarks** | N/A | | |

##### e\_impdrv\_pm\_state\_t

Table 5‑67: e\_impdrv\_pm\_state\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum {  IMPDRV\_PM\_STATE\_INVALID = 0,  IMPDRV\_PM\_STATE\_PG = 1,  IMPDRV\_PM\_STATE\_CG = 2,  IMPDRV\_PM\_STATE\_HP = 4,  IMPDRV\_PM\_STATE\_RESET = 8,  IMPDRV\_PM\_STATE\_READY = 16  } e\_impdrv\_pm\_state\_t; | | |
| **Description** | IMPDRV Power management state. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_PM\_STATE\_INVALID | 0 | Invalid state |
| IMPDRV\_PM\_STATE\_PG | 1 | “Power Gated Policy” for power management, and “Clock domain OFF / Power domain OFF” when the core is stopped. |
| IMPDRV\_PM\_STATE\_CG | 2 | “Clock Gated Policy” for power management, and “Clock domain OFF / Power domain ON” when the core is stopped. |
| IMPDRV\_PM\_STATE\_HP | 4 | “High Performance Policy” for power management, and “Clock domain ON / Power domain ON” when the core is stopped. |
| IMPDRV\_PM\_STATE\_RESET | 8 | “Reset state” for power management, and “Clock domain ON / Power domain ON” when the core is in reset state. |
| IMPDRV\_PM\_STATE\_READY | 16 | “Ready state” for power management, and “Clock domain ON / Power domain ON” when the core is not in reset status. |
| **Remarks** | N/A | | |

##### e\_impdrv\_gosub\_cond\_t

Table 5‑67: e\_impdrv\_gosub\_cond\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum {  IMPDRV\_GOSUB\_COND\_INVALID = 0,  IMPDRV\_GOSUB\_COND\_NOTEXEC,  IMPDRV\_GOSUB\_COND\_EXEC  } e\_impdrv\_gosub\_cond\_t; | | |
| **Description** | IMPDRV Specifies the condition in case of a conditional GOSUB instruction. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_GOSUB\_COND\_INVALID | 0 | Invalid value |
| IMPDRV\_GOSUB\_COND\_NOTEXEC | 1 | GOSUB is not executed, NOP is instead executed |
| IMPDRV\_GOSUB\_COND\_EXEC | 2 | GOSUB is executed |
| **Remarks** | N/A | | |

#### General Control

None.

#### Common Control

##### e\_impdrv\_mb\_mem\_init\_t

Table 5‑68: e\_impdrv\_mb\_mem\_init\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_MB\_MBM\_INIT\_ODD,  IMPDRV\_MB\_MBM\_INIT\_EVEN,  } e\_impdrv\_mb\_mem\_init\_t; | | |
| **Description** | IMPDRV Multi-Bank memory initialization kind. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_MB\_MBM\_INIT\_ODD | 0 | I Multi-Bank memory odd initialization |
| IMPDRV\_MB\_MBM\_INIT\_EVEN | 1 | Multi-Bank memory even initialization |
| **Remarks** | N/A | | |

#### Core Control

##### e\_impdrv\_state\_t

Table 5‑69: e\_impdrv\_state\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_STATE\_UNINIT = 0,  IMPDRV\_STATE\_INIT ,  IMPDRV\_STATE\_READY ,  IMPDRV\_STATE\_EXEC ,  IMPDRV\_STATE\_INT  } e\_impdrv\_state\_t; | | |
| **Description** | IMP Driver determines the Finite-State machine by this value.  For details, refer to the “3.1 Finite-State machine” in [3]. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_STATE\_UNINIT | 0 | Uninitialized state |
| IMPDRV\_STATE\_INIT | 1 | Initialization state |
| IMPDRV\_STATE\_READY | 2 | Ready state |
| IMPDRV\_STATE\_EXEC | 3 | Execution state |
| IMPDRV\_STATE\_INT | 4 | Interrupting state |
| **Remarks** | N/A | | |

##### e\_impdrv\_dspctl\_load\_type\_t

Table 5‑69: e\_impdrv\_dspctl\_load\_type\_t

|  |  |  |  |
| --- | --- | --- | --- |
| **Format** | typedef enum  {  IMPDRV\_VDSP\_LOAD\_TYPE\_INT = (0),  IMPDRV\_VDSP\_LOAD\_TYPE\_EXT  }e\_impdrv\_dspctl\_load\_type\_t; | | |
| **Description** | VDSP load tyoe. | | |
| **Enumerator** | **Name** | **Value** | **Description** |
| IMPDRV\_VDSP\_LOAD\_TYPE\_INT | 0 | Load type INT |
| IMPDRV\_VDSP\_LOAD\_TYPE\_EXT | 1 | Load type EXT |
| **Remarks** | N/A | | |

#### OS Dependence Layer

None.

### Constants Table

#### API Layer

None.

#### General Control

##### s\_impdrv\_core\_type\_table

Table 5‑70: s\_impdrv\_core\_type\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const e\_impdrv\_core\_type\_t s\_impdrv\_core\_type\_table[IMPDRV\_CORE\_TYPE\_MAX – 1U] =  {  /\* core\_type \*/  IMPDRV\_CORE\_TYPE\_IMP, /\*\*< IMP core \*/  IMPDRV\_CORE\_TYPE\_OCV, /\*\*< OCV core \*/  IMPDRV\_CORE\_TYPE\_DMAC, /\*\*< DMAC core \*/  IMPDRV\_CORE\_TYPE\_PSCEXE, /\*\*< PSC(exe) core \*/  IMPDRV\_CORE\_TYPE\_PSCOUT, /\*\*< PSC(out) core \*/  IMPDRV\_CORE\_TYPE\_CNN, /\*\*< CNN core \*/  IMPDRV\_CORE\_TYPE\_LDMAC, /\*\*< Lock Step DMAC core \*/  IMPDRV\_CORE\_TYPE\_DTA /\*\*< Debug Trace Agent \*/  }; |
| **Description** | IMP Driver uses this table to convert sequential numbers to core type enumerated values. |
| **Remarks** | N/A |

Table 5‑71: s\_impdrv\_core\_type\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const e\_impdrv\_core\_type\_t s\_impdrv\_core\_type\_table[IMPDRV\_CORE\_TYPE\_MAX – 1U] =  {  /\*\* core\_type \*/  IMPDRV\_CORE\_TYPE\_IMP , /\*\*< IMP core\*/  IMPDRV\_CORE\_TYPE\_IMP\_SLIM , /\*\*< Slim-IMP core\*/  IMPDRV\_CORE\_TYPE\_OCV , /\*\*< OCV core\*/  IMPDRV\_CORE\_TYPE\_DMAC , /\*\*< DMAC core\*/  IMPDRV\_CORE\_TYPE\_DMAC\_SLIM , /\*\*< Slim-DMAC core\*/  IMPDRV\_CORE\_TYPE\_PSCEXE , /\*\*< PSC(exe) core\*/  IMPDRV\_CORE\_TYPE\_PSCOUT , /\*\*< PSC(out) core\*/  IMPDRV\_CORE\_TYPE\_CNN , /\*\*< CNN core\*/  IMPDRV\_CORE\_TYPE\_DSP , /\*\*< DSP core\*/  IMPDRV\_CORE\_TYPE\_DTA /\*\*< Debug Trace Agent\*/  }; |
| **Description** | IMP Driver uses this table to convert sequential numbers to core type enumerated values. |
| **Remarks** | N/A |

#### Common Control

##### s\_impdrv\_inten\_addr

Table 5‑72: s\_impdrv\_inten\_addr

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const uint32\_t s\_impdrv\_inten\_addr[IMPDRV\_INSTANCETABLE\_NUM] =  {  0xFFFFFFFFU, /\*\*< Dummy for Index adjustment \*/  IMPDRV\_REG\_INTEN00, /\*\* IMPDRV\_INSTANCE\_0 \*/  IMPDRV\_REG\_INTEN01, /\*\* IMPDRV\_INSTANCE\_1 \*/  IMPDRV\_REG\_INTEN02, /\*\* IMPDRV\_INSTANCE\_2 \*/  IMPDRV\_REG\_INTEN10, /\*\* IMPDRV\_INSTANCE\_3 \*/  IMPDRV\_REG\_INTEN11, /\*\* IMPDRV\_INSTANCE\_4 \*/  IMPDRV\_REG\_INTEN12, /\*\* IMPDRV\_INSTANCE\_5 \*/  IMPDRV\_REG\_MINTEN /\*\* IMPDRV\_INSTANCE\_6 \*/  }; |
| **Description** | IMP Driver determines the Offset address of Interrupt enable register by this table.  Currently, it only uses one place, so it is defined in the function (Coverity pointed correspondence). Planned to be defined outside the function in the future. |
| **Remarks** | N/A |

##### s\_impdrv\_inten0\_cnv\_table

Table 5‑73: s\_impdrv\_inten0\_cnv\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_inten\_tbl\_t s\_impdrv\_inten0\_cnv\_table[IMPDRV\_INTEN0\_CORE\_MAX] =  {  /\*\* coreType, CoreNum, bit \*/  { IMPDRV\_CORE\_TYPE\_IMP, 0, 0x00000001U },  { IMPDRV\_CORE\_TYPE\_IMP, 1, 0x00000002U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0, 0x00000004U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0, 0x00000008U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1, 0x00000010U },  { IMPDRV\_CORE\_TYPE\_OCV, 0, 0x00000020U },  { IMPDRV\_CORE\_TYPE\_OCV, 1, 0x00000040U },  { IMPDRV\_CORE\_TYPE\_OCV, 4, 0x00000080U },  { IMPDRV\_CORE\_TYPE\_OCV, 6, 0x00000100U },  { IMPDRV\_CORE\_TYPE\_CNN, 0, 0x00000200U },  { IMPDRV\_CORE\_TYPE\_CNN, 2, 0x00000400U }  }; |
| **Description** | IMP Driver determines the Bit values of Interrupt enable register by this table.  This bit value is converted from the core type and the core number.  The settings in this table apply to the “INTEN00”, “INTEN01” and “INTEN02” register.  Currently, it only uses one place, so it is defined in the function (Coverity pointed correspondence). Planned to be defined outside the function in the future. |
| **Remarks** | N/A |

##### s\_impdrv\_inten0\_group\_table

Table 5‑74: s\_impdrv\_inten0\_group\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_group\_tbl\_t s\_impdrv\_inten0\_group\_table[IMPDRV\_GROUP\_MAX] =  {  /\*\* group\_bit group\_reg \*/  { 0x00000800U, IMPDRV\_REG\_G00INTSEL },  { 0x00001000U, IMPDRV\_REG\_G01INTSEL },  { 0x00002000U, IMPDRV\_REG\_G02INTSEL }  }; |
| **Description** | IMP Driver determines the IRQ grouping values of Interrupt enable register by this table.  This table provides cross-conversion between group bits and group registers.  The settings in this table apply to the “INTEN00”, “INTEN01” and “INTEN02” register.  Currently, it only uses one place, so it is defined in the function (Coverity pointed correspondence). Planned to be defined outside the function in the future. |
| **Remarks** | N/A |

##### s\_impdrv\_inten1\_cnv\_table

Table 5‑75: s\_impdrv\_inten1\_cnv\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_inten\_tbl\_t s\_impdrv\_inten1\_cnv\_table[IMPDRV\_INTEN1\_CORE\_MAX] =  {  /\*\* coreType, CoreNum bit \*/  { IMPDRV\_CORE\_TYPE\_IMP, 2, 0x00000001U },  { IMPDRV\_CORE\_TYPE\_IMP, 3, 0x00000002U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 1, 0x00000004U },  { IMPDRV\_CORE\_TYPE\_DMAC, 2, 0x00000008U },  { IMPDRV\_CORE\_TYPE\_DMAC, 3, 0x00000010U },  { IMPDRV\_CORE\_TYPE\_OCV, 2, 0x00000020U },  { IMPDRV\_CORE\_TYPE\_OCV, 3, 0x00000040U },  { IMPDRV\_CORE\_TYPE\_OCV, 5, 0x00000080U },  { IMPDRV\_CORE\_TYPE\_OCV, 7, 0x00000100U },  { IMPDRV\_CORE\_TYPE\_CNN, 1, 0x00000400U }  }; |
| **Description** | IMP Driver determines the Bit values of Interrupt enable register by this table.  This bit value is converted from the core type and the core number.  The settings in this table apply to the “INTEN10”, “INTEN11” and “INTEN12” register.  Currently, it only uses one place, so it is defined in the function (Coverity pointed correspondence). Planned to be defined outside the function in the future. |
| **Remarks** | N/A |

##### s\_impdrv\_inten1\_group\_table

Table 5‑76: s\_impdrv\_inten1\_group\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_group\_tbl\_t s\_impdrv\_inten1\_group\_table[IMPDRV\_GROUP\_MAX] =  {  /\*\* group\_bit group\_reg \*/  { 0x00000800U, IMPDRV\_REG\_G10INTSEL },  { 0x00001000U, IMPDRV\_REG\_G11INTSEL },  { 0x00002000U, IMPDRV\_REG\_G12INTSEL }  }; |
| **Description** | IMP Driver determines the IRQ grouping values of Interrupt enable register by this table.  This table provides cross-conversion between group bits and group registers.  The settings in this table apply to the “INTEN10”, “INTEN11” and “INTEN12” register.  Currently, it only uses one place, so it is defined in the function (Coverity pointed correspondence). Planned to be defined outside the function in the future. |
| **Remarks** | N/A |

##### s\_impdrv\_minten\_cnv\_table

Table 5‑77: s\_impdrv\_minten\_cnv\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_inten\_tbl\_t s\_impdrv\_minten\_cnv\_table[IMPDRV\_MINTEN\_CORE\_MAX] =  {  /\*\* coreType, CoreNum bit \*/  { IMPDRV\_CORE\_TYPE\_IMP, 0, 0x00000001U },  { IMPDRV\_CORE\_TYPE\_IMP, 1, 0x00000002U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0, 0x00000004U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0, 0x00000008U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1, 0x00000010U },  { IMPDRV\_CORE\_TYPE\_OCV, 0, 0x00000020U },  { IMPDRV\_CORE\_TYPE\_OCV, 1, 0x00000040U },  { IMPDRV\_CORE\_TYPE\_OCV, 4, 0x00000080U },  { IMPDRV\_CORE\_TYPE\_OCV, 6, 0x00000100U },  { IMPDRV\_CORE\_TYPE\_CNN, 0, 0x00000200U },  { IMPDRV\_CORE\_TYPE\_CNN, 2, 0x00000400U },  { IMPDRV\_CORE\_TYPE\_IMP, 2, 0x00000800U },  { IMPDRV\_CORE\_TYPE\_IMP, 3, 0x00001000U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 1, 0x00002000U },  { IMPDRV\_CORE\_TYPE\_DMAC, 2, 0x00004000U },  { IMPDRV\_CORE\_TYPE\_DMAC, 3, 0x00008000U },  { IMPDRV\_CORE\_TYPE\_OCV, 2, 0x00010000U },  { IMPDRV\_CORE\_TYPE\_OCV, 3, 0x00020000U },  { IMPDRV\_CORE\_TYPE\_OCV, 5, 0x00040000U },  { IMPDRV\_CORE\_TYPE\_OCV, 7, 0x00080000U },  { IMPDRV\_CORE\_TYPE\_CNN, 1, 0x00200000U }  }; |
| **Description** | IMP Driver determines the Bit values of Interrupt enable register by this table.  This bit value is converted from the core type and the core number.  The settings in this table apply to the “MINTEN” register.  Currently, it only uses one place, so it is defined in the function (Coverity pointed correspondence). Planned to be defined outside the function in the future. |
| **Remarks** | N/A |

##### s\_impdrv\_minten\_group\_table

Table 5‑78: s\_impdrv\_minten\_group\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_group\_tbl\_t s\_impdrv\_minten\_group\_table[IMPDRV\_GROUP\_MAX] =  {  /\*\* group\_bit group\_reg \*/  { 0x00400000U, IMPDRV\_REG\_MG0INTSEL },  { 0x00800000U, IMPDRV\_REG\_MG1INTSEL },  { 0x01000000U, IMPDRV\_REG\_MG2INTSEL }  }; |
| **Description** | IMP Driver determines the IRQ grouping values of Interrupt enable register by this table.  This table provides cross-conversion between group bits and group registers.  The settings in this table apply to the “MINTEN” register.  Currently, it only uses one place, so it is defined in the function (Coverity pointed correspondence). Planned to be defined outside the function in the future. |
| **Remarks** | N/A |

##### s\_impdrv\_inten\_addr

Table 5‑79: s\_impdrv\_inten\_addr

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const uint32\_t s\_impdrv\_inten\_addr[IMPDRV\_INSTANCETABLE\_NUM] =  {  IMPDRV\_DUMMY\_UINT32, /\*\*< Dummy for Index adjustment \*/  IMPDRV\_REG\_IMR, /\*\* IMPDRV\_INSTANCE\_0 \*/  IMPDRV\_REG\_IMR1, /\*\* IMPDRV\_INSTANCE\_1 \*/  IMPDRV\_REG\_IMR2, /\*\* IMPDRV\_INSTANCE\_2 \*/  IMPDRV\_REG\_IMR3, /\*\* IMPDRV\_INSTANCE\_3 \*/  IMPDRV\_REG\_IMR4, /\*\* IMPDRV\_INSTANCE\_4 \*/  }; |
| **Description** | IMP Driver determines the Offset address of Interrupt enable register by this table.  Currently, it only uses one place, so it is defined in the function (Coverity pointed correspondence). Planned to be defined outside the function in the future. |
| **Remarks** | N/A |

##### s\_impdrv\_inten\_cnv\_table

Table 5‑80: s\_impdrv\_inten\_cnv\_table

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M]**  IMPDRV\_STATIC  const st\_impdrv\_inten\_tbl\_t s\_impdrv\_inten\_cnv\_table[IMPDRV\_INTEN\_CORE\_MAX] =  {  /\*\* coreType, CoreNum, bit \*/  { IMPDRV\_CORE\_TYPE\_IMP, 0, 0x00000001U },  { IMPDRV\_CORE\_TYPE\_IMP, 1, 0x00000002U },  { IMPDRV\_CORE\_TYPE\_IMP, 2, 0x00000004U },  { IMPDRV\_CORE\_TYPE\_IMP, 3, 0x00000008U },  { IMPDRV\_CORE\_TYPE\_OCV, 0, 0x00000010U },  { IMPDRV\_CORE\_TYPE\_OCV, 1, 0x00000020U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0, 0x00000040U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1, 0x00000080U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0, 0x00000100U },  { IMPDRV\_CORE\_TYPE\_CNN, 0, 0x00000200U },  };  **[R-CarV3H]**  IMPDRV\_STATIC  const st\_impdrv\_inten\_tbl\_t s\_impdrv\_inten\_cnv\_table[IMPDRV\_INTEN\_CORE\_MAX] =  {  /\*\* coreType, CoreNum, bit \*/  { IMPDRV\_CORE\_TYPE\_IMP, 0, 0x00000001U },  { IMPDRV\_CORE\_TYPE\_IMP, 1, 0x00000002U },  { IMPDRV\_CORE\_TYPE\_IMP, 2, 0x00000004U },  { IMPDRV\_CORE\_TYPE\_IMP, 3, 0x00000008U },  { IMPDRV\_CORE\_TYPE\_IMP, 4, 0x00000010U },  { IMPDRV\_CORE\_TYPE\_IMP\_SLIM, 0, 0x00000020U },  { IMPDRV\_CORE\_TYPE\_OCV, 0, 0x00000040U },  { IMPDRV\_CORE\_TYPE\_OCV, 1, 0x00000080U },  { IMPDRV\_CORE\_TYPE\_OCV, 2, 0x00000100U },  { IMPDRV\_CORE\_TYPE\_OCV, 3, 0x00000200U },  { IMPDRV\_CORE\_TYPE\_OCV, 4, 0x00000400U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0, 0x00000800U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1, 0x00001000U },  { IMPDRV\_CORE\_TYPE\_DMAC, 2, 0x00002000U },  { IMPDRV\_CORE\_TYPE\_DMAC, 3, 0x00004000U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0, 0x00008000U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 1, 0x00010000U },  { IMPDRV\_CORE\_TYPE\_CNN, 0, 0x00020000U }  };  **[R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_inten\_tbl\_t s\_impdrv\_inten\_cnv\_table[IMPDRV\_INTEN\_CORE\_MAX] =  {  /\*\* coreType, CoreNum, bit \*/  { IMPDRV\_CORE\_TYPE\_IMP, 0, 0x00000001U },  { IMPDRV\_CORE\_TYPE\_IMP, 1, 0x00000002U },  { IMPDRV\_CORE\_TYPE\_IMP, 2, 0x00000004U },  { IMPDRV\_CORE\_TYPE\_IMP, 3, 0x00000008U },  { IMPDRV\_CORE\_TYPE\_IMP, 4, 0x00000010U },  { IMPDRV\_CORE\_TYPE\_IMP\_SLIM, 0, 0x00000020U },  { IMPDRV\_CORE\_TYPE\_OCV, 0, 0x00000040U },  { IMPDRV\_CORE\_TYPE\_OCV, 1, 0x00000080U },  { IMPDRV\_CORE\_TYPE\_OCV, 2, 0x00000100U },  { IMPDRV\_CORE\_TYPE\_OCV, 3, 0x00000200U },  { IMPDRV\_CORE\_TYPE\_OCV, 4, 0x00000400U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0, 0x00000800U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1, 0x00001000U },  { IMPDRV\_CORE\_TYPE\_DMAC, 2, 0x00002000U },  { IMPDRV\_CORE\_TYPE\_DMAC, 3, 0x00004000U },  { IMPDRV\_CORE\_TYPE\_DMAC\_SLIM, 0, 0x00008000U },  { IMPDRV\_CORE\_TYPE\_DMAC\_SLIM, 1, 0x00010000U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0, 0x00020000U },  { IMPDRV\_CORE\_TYPE\_CNN, 0, 0x00040000U }  };  [R-CarV4H]  Not Defined |
| **Description** | IMP Driver determines the Bit values of Interrupt enable register by this table.  This bit value is converted from the core type and the core number.  The settings in this table apply to the “IMR”, “IMR1”, “IMR2”, “IMR3” and , “IMR4” register.  Currently, it only uses one place, so it is defined in the function (Coverity pointed correspondence). Planned to be defined outside the function in the future. |
| **Remarks** | N/A |

##### s\_corectl\_func\_tbl

Table 5‑81: s\_corectl\_func\_tbl

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_corectl\_func\_t s\_corectl\_func\_tbl[IMPDRV\_CORE\_TYPE\_MAX] =  {  /\*\* Not Assigned \*/  { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_IMP \*/  { impdrv\_impctl\_is\_valid\_core, impdrv\_impctl\_check\_state,  impdrv\_impctl\_set\_state, impdrv\_impctl\_init\_start,  impdrv\_impctl\_init\_end, impdrv\_impctl\_start,  impdrv\_impctl\_stop, impdrv\_impctl\_attr\_init,  impdrv\_impctl\_set\_mem\_init, impdrv\_impctl\_set\_core\_map,  impdrv\_impctl\_set\_cl, impdrv\_impctl\_set\_irq\_mask,  impdrv\_impctl\_execute, impdrv\_impctl\_int\_handler, impdrv\_impctl\_resume\_exe, impdrv\_impctl\_pm\_set\_policy, impdrv\_impctl\_pm\_get\_policy, NULL, NULL, NULL,  impdrv\_impctl\_set\_cl\_brk\_addr, impdrv\_impctl\_set\_cond\_gosub,  impdrv\_impctl\_pm\_get\_state, impdrv\_impctl\_quit  },  /\* IMPDRV\_CORE\_TYPE\_IMP\_SLIM \*/  { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_OCV \*/  { impdrv\_ocvctl\_is\_valid\_core, impdrv\_ocvctl\_check\_state,  impdrv\_ocvctl\_set\_state, impdrv\_ocvctl\_init\_start,  impdrv\_ocvctl\_init\_end, impdrv\_ocvctl\_start,  impdrv\_ocvctl\_stop, impdrv\_ocvctl\_attr\_init,  impdrv\_ocvctl\_set\_mem\_init, impdrv\_ocvctl\_set\_core\_map,  impdrv\_ocvctl\_set\_cl, impdrv\_ocvctl\_set\_irq\_mask,  impdrv\_ocvctl\_execute, impdrv\_ocvctl\_int\_handler, impdrv\_ocvctl\_resume\_exe, impdrv\_ocvctl\_pm\_set\_policy, impdrv\_ocvctl\_pm\_get\_policy, NULL, NULL, NULL,  impdrv\_ocvctl\_set\_cl\_brk\_addr, impdrv\_ocvctl\_set\_cond\_gosub,  impdrv\_ocvctl\_pm\_get\_state, impdrv\_ocvctl\_quit  },  /\*\* IMPDRV\_CORE\_TYPE\_DMAC \*/  { impdrv\_dmactl\_is\_valid\_core, impdrv\_dmactl\_check\_state,  impdrv\_dmactl\_set\_state, impdrv\_dmactl\_init\_start,  impdrv\_dmactl\_init\_end, impdrv\_dmactl\_start,  impdrv\_dmactl\_stop, impdrv\_dmactl\_attr\_init,  impdrv\_dmactl\_set\_mem\_init, impdrv\_dmactl\_set\_core\_map,  impdrv\_dmactl\_set\_cl, impdrv\_dmactl\_set\_irq\_mask,  impdrv\_dmactl\_execute, impdrv\_dmactl\_int\_handler, impdrv\_dmactl\_resume\_exe, impdrv\_dmactl\_pm\_set\_policy, impdrv\_dmactl\_pm\_get\_policy, NULL, NULL, NULL,  impdrv\_dmactl\_set\_cl\_brk\_addr, impdrv\_dmactl\_set\_cond\_gosub,  impdrv\_dmactl\_pm\_get\_state, impdrv\_dmactl\_quit  },  /\* IMPDRV\_CORE\_TYPE\_DMAC\_SLIM \*/  { impdrv\_dmasctl\_is\_valid\_core, impdrv\_dmasctl\_check\_state,  impdrv\_dmasctl\_set\_state, impdrv\_dmasctl\_init\_start,  impdrv\_dmasctl\_init\_end, impdrv\_dmasctl\_start,  impdrv\_dmasctl\_stop, impdrv\_dmasctl\_attr\_init,  impdrv\_dmasctl\_set\_mem\_init, impdrv\_dmasctl\_set\_core\_map,  impdrv\_dmasctl\_set\_cl, impdrv\_dmasctl\_set\_irq\_mask,  impdrv\_dmasctl\_execute, impdrv\_dmasctl\_int\_handler, impdrv\_dmasctl\_resume\_exe, impdrv\_dmasctl\_pm\_set\_policy, impdrv\_dmasctl\_pm\_get\_policy, NULL, NULL, NULL,  impdrv\_dmasctl\_set\_cl\_brk\_addr, impdrv\_dmasctl\_set\_cond\_gosub,  impdrv\_dmasctl\_pm\_get\_state, impdrv\_dmasctl\_quit  },  /\*\* IMPDRV\_CORE\_TYPE\_PSCEXE \*/  { impdrv\_pscctl\_is\_valid\_core, impdrv\_pscctl\_check\_state,  impdrv\_pscctl\_set\_state, impdrv\_pscctl\_init\_start,  impdrv\_pscctl\_init\_end, impdrv\_pscctl\_start,  impdrv\_pscctl\_stop, impdrv\_pscctl\_attr\_init,  impdrv\_pscctl\_set\_mem\_init, impdrv\_pscctl\_set\_core\_map,  impdrv\_pscctl\_set\_cl, impdrv\_pscctl\_set\_irq\_mask,  impdrv\_pscctl\_execute, impdrv\_pscctl\_int\_handler, impdrv\_pscctl\_resume\_exe, impdrv\_pscctl\_pm\_set\_policy, impdrv\_pscctl\_pm\_get\_policy, NULL, NULL, NULL,  impdrv\_pscctl\_set\_cl\_brk\_addr, impdrv\_pscctl\_set\_cond\_gosub,  impdrv\_pscctl\_pm\_get\_state, impdrv\_pscctl\_quit  },  /\*\* IMPDRV\_CORE\_TYPE\_PSCOUT \*/  { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_CNN \*/  { impdrv\_cnnctl\_is\_valid\_core, impdrv\_cnnctl\_check\_state, impdrv\_cnnctl\_set\_state, impdrv\_cnnctl\_init\_start, impdrv\_cnnctl\_init\_end, impdrv\_cnnctl\_start, impdrv\_cnnctl\_stop, impdrv\_cnnctl\_attr\_init, impdrv\_cnnctl\_set\_mem\_init, impdrv\_cnnctl\_set\_core\_map, impdrv\_cnnctl\_set\_cl, impdrv\_cnnctl\_set\_irq\_mask, impdrv\_cnnctl\_execute, impdrv\_cnnctl\_int\_handler, impdrv\_cnnctl\_resume\_exe, impdrv\_cnnctl\_pm\_set\_policy, impdrv\_cnnctl\_pm\_get\_policy, NULL, NULL, NULL,  impdrv\_cnnctl\_set\_cl\_brk\_addr, impdrv\_cnnctl\_set\_cond\_gosub,  impdrv\_cnnctl\_pm\_get\_state, impdrv\_cnnctl\_quit  },  /\*\* IMPDRV\_CORE\_TYPE\_DSP \*/  { impdrv\_dspctl\_is\_valid\_core, impdrv\_dspctl\_check\_state,  impdrv\_dspctl\_set\_state, impdrv\_dspctl\_init\_start,  impdrv\_dspctl\_init\_end, impdrv\_dspctl\_dsp\_start,  impdrv\_dspctl\_stop, impdrv\_dspctl\_attr\_init,  impdrv\_dspctl\_set\_mem\_init, impdrv\_dspctl\_set\_core\_map,  NULL, NULL, impdrv\_dspctl\_dsp\_execute,  impdrv\_dspctl\_int\_handler, impdrv\_dspctl\_resume\_exe,  impdrv\_dspctl\_pm\_set\_policy, impdrv\_dspctl\_pm\_get\_policy,  impdrv\_dspctl\_set\_dsp, NULL,  impdrv\_dspctl\_conf\_reg\_check, NULL, NULL,  impdrv\_dspctl\_pm\_get\_state, impdrv\_dspctl\_quit  },  /\*\* IMPDRV\_CORE\_TYPE\_DTA \*/  { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL  },  }; |
| **Description** | IMP Driver determines the Call functions for Core control component by this table. |
| **Remarks** | N/A |

Table 5‑82: s\_corectl\_func\_tbl

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_corectl\_func\_t s\_corectl\_func\_tbl[IMPDRV\_CORE\_TYPE\_MAX] =  {  /\*\* Not Assigned \*/  { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_IMP \*/  { impdrv\_impctl\_is\_valid\_core, impdrv\_impctl\_check\_state,  impdrv\_impctl\_set\_state, impdrv\_impctl\_init\_start,  impdrv\_impctl\_init\_end, impdrv\_impctl\_start,  impdrv\_impctl\_stop, impdrv\_impctl\_attr\_init,  impdrv\_impctl\_set\_mem\_init, impdrv\_impctl\_set\_core\_map,  impdrv\_impctl\_set\_cl, impdrv\_impctl\_set\_irq\_mask,  impdrv\_impctl\_execute, impdrv\_impctl\_int\_handler, impdrv\_impctl\_resume\_exe, impdrv\_impctl\_pm\_set\_policy, impdrv\_impctl\_pm\_get\_policy, NULL,  impdrv\_impctl\_bus\_if\_check, impdrv\_impctl\_conf\_reg\_check,  NULL, NULL  },  /\* IMPDRV\_CORE\_TYPE\_IMP\_SLIM \*/ [R-CarV3H / V3H\_2]  { impdrv\_impctl\_is\_valid\_core, impdrv\_impctl\_check\_state,  impdrv\_impctl\_set\_state, impdrv\_impctl\_init\_start,  impdrv\_impctl\_init\_end, impdrv\_impctl\_start,  impdrv\_impctl\_stop, impdrv\_impctl\_attr\_init,  impdrv\_impctl\_set\_mem\_init, impdrv\_impctl\_set\_core\_map,  impdrv\_impctl\_set\_cl, impdrv\_impctl\_set\_irq\_mask,  impdrv\_impctl\_execute, impdrv\_impctl\_int\_handler, impdrv\_impctl\_resume\_exe, impdrv\_impctl\_pm\_set\_policy, impdrv\_impctl\_pm\_get\_policy, NULL,  impdrv\_impsctl\_bus\_if\_check, impdrv\_impsctl\_conf\_reg\_check,  NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_OCV \*/  { impdrv\_ocvctl\_is\_valid\_core, impdrv\_ocvctl\_check\_state,  impdrv\_ocvctl\_set\_state, impdrv\_ocvctl\_init\_start,  impdrv\_ocvctl\_init\_end, impdrv\_ocvctl\_start,  impdrv\_ocvctl\_stop, impdrv\_ocvctl\_attr\_init,  impdrv\_ocvctl\_set\_mem\_init, impdrv\_ocvctl\_set\_core\_map,  impdrv\_ocvctl\_set\_cl, impdrv\_ocvctl\_set\_irq\_mask,  impdrv\_ocvctl\_execute, impdrv\_ocvctl\_int\_handler, impdrv\_ocvctl\_resume\_exe, impdrv\_ocvctl\_pm\_set\_policy, impdrv\_ocvctl\_pm\_get\_policy, NULL,  NULL, impdrv\_ocvctl\_conf\_reg\_check,  NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_DMAC \*/  { impdrv\_dmactl\_is\_valid\_core, impdrv\_dmactl\_check\_state,  impdrv\_dmactl\_set\_state, impdrv\_dmactl\_init\_start,  impdrv\_dmactl\_init\_end, impdrv\_dmactl\_start,  impdrv\_dmactl\_stop, impdrv\_dmactl\_attr\_init,  impdrv\_dmactl\_set\_mem\_init, impdrv\_dmactl\_set\_core\_map,  impdrv\_dmactl\_set\_cl, impdrv\_dmactl\_set\_irq\_mask,  impdrv\_dmactl\_execute, impdrv\_dmactl\_int\_handler, impdrv\_dmactl\_resume\_exe, impdrv\_dmactl\_pm\_set\_policy, impdrv\_dmactl\_pm\_get\_policy, NULL,  impdrv\_dmactl\_bus\_if\_check, impdrv\_dmactl\_conf\_reg\_check,  NULL, NULL  },  /\* IMPDRV\_CORE\_TYPE\_DMAC\_SLIM \*/ [R-CarV3H\_2]  { impdrv\_impctl\_is\_valid\_core, impdrv\_impctl\_check\_state,  impdrv\_impctl\_set\_state, impdrv\_impctl\_init\_start,  impdrv\_impctl\_init\_end, impdrv\_impctl\_start,  impdrv\_impctl\_stop, impdrv\_impctl\_attr\_init,  impdrv\_impctl\_set\_mem\_init, impdrv\_impctl\_set\_core\_map,  impdrv\_impctl\_set\_cl, impdrv\_impctl\_set\_irq\_mask,  impdrv\_impctl\_execute, impdrv\_impctl\_int\_handler, impdrv\_impctl\_resume\_exe, impdrv\_impctl\_pm\_set\_policy, impdrv\_dmasctl\_pm\_get\_policy, NULL,  NULL, impdrv\_dmasctl\_conf\_reg\_check,  NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_PSCEXE \*/  { impdrv\_pscctl\_is\_valid\_core, impdrv\_pscctl\_check\_state,  impdrv\_pscctl\_set\_state, impdrv\_pscctl\_init\_start,  impdrv\_pscctl\_init\_end, impdrv\_pscctl\_start,  impdrv\_pscctl\_stop, impdrv\_pscctl\_attr\_init,  impdrv\_pscctl\_set\_mem\_init, impdrv\_pscctl\_set\_core\_map,  impdrv\_pscctl\_set\_cl, impdrv\_pscctl\_set\_irq\_mask,  impdrv\_pscctl\_execute, impdrv\_pscctl\_int\_handler, impdrv\_pscctl\_resume\_exe, impdrv\_pscctl\_pm\_set\_policy, impdrv\_pscctl\_pm\_get\_policy, NULL,  NULL, impdrv\_pscctl\_conf\_reg\_check,  NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_PSCOUT \*/  { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_CNN \*/  { impdrv\_cnnctl\_is\_valid\_core, impdrv\_cnnctl\_check\_state, impdrv\_cnnctl\_set\_state, impdrv\_cnnctl\_init\_start, , impdrv\_cnnctl\_start, impdrv\_cnnctl\_stop, impdrv\_cnnctl\_attr\_init, impdrv\_cnnctl\_set\_mem\_init, impdrv\_cnnctl\_set\_core\_map, impdrv\_cnnctl\_set\_cl, impdrv\_cnnctl\_set\_irq\_mask, impdrv\_cnnctl\_execute, impdrv\_cnnctl\_int\_handler, impdrv\_cnnctl\_resume\_exe, impdrv\_cnnctl\_pm\_set\_policy, impdrv\_cnnctl\_pm\_get\_policy, NULL,  NULL, impdrv\_cnnctl\_conf\_reg\_check,  NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_LDMAC \*/  { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL NULL, NULL, NULL, NULL, NULL  },  /\*\* IMPDRV\_CORE\_TYPE\_DTA \*/  { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL NULL, NULL, NULL, NULL, NULL  },  }; |
| **Description** | IMP Driver determines the Call functions for Core control component by this table. |
| **Remarks** | N/A |

##### s\_impdrv\_core\_to\_syncc\_table

Table 5‑83: s\_impdrv\_core\_to\_syncc\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_syncc\_table\_t s\_impdrv\_core\_to\_syncc\_table[IMPDRV\_SYNCCTABLE\_NUM] =  {  /\* core\_type, core\_num, syncc\_val \*/  { IMPDRV\_CORE\_TYPE\_IMP, 0U, 0x00U },  { IMPDRV\_CORE\_TYPE\_IMP, 1U, 0x01U },  { IMPDRV\_CORE\_TYPE\_IMP, 2U, 0x02U },  { IMPDRV\_CORE\_TYPE\_IMP, 3U, 0x03U },  { IMPDRV\_CORE\_TYPE\_OCV, 0U, 0x10U },  { IMPDRV\_CORE\_TYPE\_OCV, 1U, 0x11U },  { IMPDRV\_CORE\_TYPE\_OCV, 2U, 0x12U },  { IMPDRV\_CORE\_TYPE\_OCV, 3U, 0x13U },  { IMPDRV\_CORE\_TYPE\_OCV, 4U, 0x14U },  { IMPDRV\_CORE\_TYPE\_OCV, 5U, 0x15U },  { IMPDRV\_CORE\_TYPE\_OCV, 6U, 0x16U },  { IMPDRV\_CORE\_TYPE\_OCV, 7U, 0x17U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0U, 0x20U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1U, 0x21U },  { IMPDRV\_CORE\_TYPE\_DMAC, 2U, 0x22U },  { IMPDRV\_CORE\_TYPE\_DMAC, 3U, 0x23U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0U, 0x30U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 1U, 0x31U },  { IMPDRV\_CORE\_TYPE\_CNN, 0U, 0x40U },  { IMPDRV\_CORE\_TYPE\_CNN, 1U, 0x41U },  { IMPDRV\_CORE\_TYPE\_CNN, 2U, 0x42U },  { IMPDRV\_CORE\_TYPE\_DTA, 0U, 0x70U },  }; |
| **Description** | IMP Driver determines the Bit values of the SYNCC value by this table.  This bit value is converted from the core type and the core number.  The settings in this table apply to the “SYNCCR” register. |
| **Remarks** | N/A |

Table 5‑84: s\_impdrv\_core\_to\_syncc\_table

|  |
| --- |
| **[R-CarV3M]**  IMPDRV\_STATIC  const st\_impdrv\_syncc\_table\_t s\_impdrv\_core\_to\_syncc\_table[IMPDRV\_SYNCCTABLE\_NUM] =  {  /\* core\_type, core\_num, syncc\_val \*/  { IMPDRV\_CORE\_TYPE\_INVALID, 0U, 0x00U },  { IMPDRV\_CORE\_TYPE\_IMP, 0U, 0x00U },  { IMPDRV\_CORE\_TYPE\_IMP, 1U, 0x01U },  { IMPDRV\_CORE\_TYPE\_IMP, 2U, 0x02U },  { IMPDRV\_CORE\_TYPE\_IMP, 3U, 0x03U },  { IMPDRV\_CORE\_TYPE\_OCV, 0U, 0x10U },  { IMPDRV\_CORE\_TYPE\_OCV, 1U, 0x11U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0U, 0x20U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1U, 0x21U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0U, 0x30U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 0U, 0x30U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 1U, 0x31U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 2U, 0x32U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 3U, 0x33U },  { IMPDRV\_CORE\_TYPE\_CNN, 0U, 0x40U },  { IMPDRV\_CORE\_TYPE\_DTA, 0U, 0x70U }  };  **[R-CarV3H]**  IMPDRV\_STATIC  const st\_impdrv\_syncc\_table\_t s\_impdrv\_core\_to\_syncc\_table[IMPDRV\_SYNCCTABLE\_NUM] =  {  /\* core\_type, core\_num, syncc\_val \*/  { IMPDRV\_CORE\_TYPE\_INVALID, 0U, 0xFFU },  { IMPDRV\_CORE\_TYPE\_IMP, 0U, 0x00U },  { IMPDRV\_CORE\_TYPE\_IMP, 1U, 0x01U },  { IMPDRV\_CORE\_TYPE\_IMP, 2U, 0x02U },  { IMPDRV\_CORE\_TYPE\_IMP, 3U, 0x03U },  { IMPDRV\_CORE\_TYPE\_IMP, 4U, 0x04U },  { IMPDRV\_CORE\_TYPE\_IMP\_SLIM, 0U, 0x05U },  { IMPDRV\_CORE\_TYPE\_OCV, 0U, 0x10U },  { IMPDRV\_CORE\_TYPE\_OCV, 1U, 0x11U },  { IMPDRV\_CORE\_TYPE\_OCV, 2U, 0x12U },  { IMPDRV\_CORE\_TYPE\_OCV, 3U, 0x13U },  { IMPDRV\_CORE\_TYPE\_OCV, 4U, 0x14U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0U, 0x20U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1U, 0x21U },  { IMPDRV\_CORE\_TYPE\_DMAC, 2U, 0x22U },  { IMPDRV\_CORE\_TYPE\_DMAC, 3U, 0x23U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0U, 0x30U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 1U, 0x31U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 0U, 0x30U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 1U, 0x31U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 2U, 0x32U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 3U, 0x33U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 4U, 0x34U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 5U, 0x35U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 6U, 0x36U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 7U, 0x37U },  { IMPDRV\_CORE\_TYPE\_CNN, 0U, 0x40U },  { IMPDRV\_CORE\_TYPE\_IMR, 4U, 0x54U },  { IMPDRV\_CORE\_TYPE\_IMR, 5U, 0x55U },  { IMPDRV\_CORE\_TYPE\_DTA, 0U, 0x70U }  };  **[R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_syncc\_table\_t s\_impdrv\_core\_to\_syncc\_table[IMPDRV\_SYNCCTABLE\_NUM] =  {  /\* core\_type, core\_num, syncc\_val \*/  { IMPDRV\_CORE\_TYPE\_INVALID, 0U, 0xFFU },  { IMPDRV\_CORE\_TYPE\_IMP, 0U, 0x00U },  { IMPDRV\_CORE\_TYPE\_IMP, 1U, 0x01U },  { IMPDRV\_CORE\_TYPE\_IMP, 2U, 0x02U },  { IMPDRV\_CORE\_TYPE\_IMP, 3U, 0x03U },  { IMPDRV\_CORE\_TYPE\_IMP, 4U, 0x04U },  { IMPDRV\_CORE\_TYPE\_IMP\_SLIM, 0U, 0x05U },  { IMPDRV\_CORE\_TYPE\_OCV, 0U, 0x10U },  { IMPDRV\_CORE\_TYPE\_OCV, 1U, 0x11U },  { IMPDRV\_CORE\_TYPE\_OCV, 2U, 0x12U },  { IMPDRV\_CORE\_TYPE\_OCV, 3U, 0x13U },  { IMPDRV\_CORE\_TYPE\_OCV, 4U, 0x14U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0U, 0x20U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1U, 0x21U },  { IMPDRV\_CORE\_TYPE\_DMAC, 2U, 0x22U },  { IMPDRV\_CORE\_TYPE\_DMAC, 3U, 0x23U },  { IMPDRV\_CORE\_TYPE\_DMAC\_SLIM, 0U, 0x24U },  { IMPDRV\_CORE\_TYPE\_DMAC\_SLIM, 1U, 0x25U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0U, 0x30U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 0U, 0x30U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 1U, 0x31U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 2U, 0x32U },  { IMPDRV\_CORE\_TYPE\_PSCOUT, 3U, 0x33U },  { IMPDRV\_CORE\_TYPE\_CNN, 0U, 0x40U },  { IMPDRV\_CORE\_TYPE\_IMR, 4U, 0x54U },  { IMPDRV\_CORE\_TYPE\_IMR, 5U, 0x55U },  { IMPDRV\_CORE\_TYPE\_DTA, 0U, 0x70U }  };  [R-CarV4H]  IMPDRV\_STATIC  const st\_impdrv\_syncc\_table\_t s\_impdrv\_core\_to\_syncc\_table[IMPDRV\_SYNCCTABLE\_NUM] =  {  /\* core\_type, core\_num, syncc\_val \*/  { IMPDRV\_CORE\_TYPE\_INVALID, 0U, 0x00U },  { IMPDRV\_CORE\_TYPE\_IMP, 0U, 0x00U },  { IMPDRV\_CORE\_TYPE\_IMP, 1U, 0x01U },  { IMPDRV\_CORE\_TYPE\_IMP, 2U, 0x02U },  { IMPDRV\_CORE\_TYPE\_IMP, 3U, 0x03U },  { IMPDRV\_CORE\_TYPE\_OCV, 0U, 0x10U },  { IMPDRV\_CORE\_TYPE\_OCV, 1U, 0x11U },  { IMPDRV\_CORE\_TYPE\_OCV, 2U, 0x12U },  { IMPDRV\_CORE\_TYPE\_OCV, 3U, 0x13U },  { IMPDRV\_CORE\_TYPE\_DMAC, 0U, 0x20U },  { IMPDRV\_CORE\_TYPE\_DMAC, 1U, 0x21U },  { IMPDRV\_CORE\_TYPE\_DMAC, 2U, 0x22U },  { IMPDRV\_CORE\_TYPE\_DMAC, 3U, 0x23U },  { IMPDRV\_CORE\_TYPE\_DMAC\_SLIM, 0U, 0x24U },  { IMPDRV\_CORE\_TYPE\_DMAC\_SLIM, 1U, 0x25U },  { IMPDRV\_CORE\_TYPE\_DMAC\_SLIM, 2U, 0x26U },  { IMPDRV\_CORE\_TYPE\_DMAC\_SLIM, 3U, 0x27U },  { IMPDRV\_CORE\_TYPE\_PSCEXE, 0U, 0x30U },  { IMPDRV\_CORE\_TYPE\_CNN, 0U, 0x40U },  { IMPDRV\_CORE\_TYPE\_DSP, 0U, 0x50U },  { IMPDRV\_CORE\_TYPE\_DSP, 1U, 0x51U },  { IMPDRV\_CORE\_TYPE\_DSP, 2U, 0x52U },  { IMPDRV\_CORE\_TYPE\_DSP, 3U, 0x53U },  { IMPDRV\_CORE\_TYPE\_IMR, 0U, 0x60U },  { IMPDRV\_CORE\_TYPE\_IMR, 1U, 0x61U },  { IMPDRV\_CORE\_TYPE\_IMR, 2U, 0x62U },  { IMPDRV\_CORE\_TYPE\_IMR, 3U, 0x63U },  { IMPDRV\_CORE\_TYPE\_IMR, 4U, 0x64U },  { IMPDRV\_CORE\_TYPE\_DTA, 0U, 0x70U },  }; |
| IMP Driver determines the Bit values of the SYNCC value by this table.  This bit value is converted from the core type and the core number.  The settings in this table apply to the “SYNCCR” register. |
| N/A |

##### s\_impdrv\_inten\_reg\_tbl

Table 5‑85: s\_impdrv\_inten\_reg\_tbl

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const st\_impdrv\_inten\_reg\_tbl\_t s\_impdrv\_inten\_reg\_tbl[IMPDRV\_INSTANCETABLE\_NUM] =  {  /\*\* p\_inten\_group\_table p\_inten\_cnv\_table cnv\_table\_num \*/  { NULL, NULL, 0xFFFFFFFFU },  { s\_impdrv\_inten0\_group\_table, s\_impdrv\_inten0\_cnv\_table, IMPDRV\_INTEN0\_CORE\_MAX},  { s\_impdrv\_inten0\_group\_table, s\_impdrv\_inten0\_cnv\_table, IMPDRV\_INTEN0\_CORE\_MAX},  { s\_impdrv\_inten0\_group\_table, s\_impdrv\_inten0\_cnv\_table, IMPDRV\_INTEN0\_CORE\_MAX},  { s\_impdrv\_inten1\_group\_table, s\_impdrv\_inten1\_cnv\_table, IMPDRV\_INTEN1\_CORE\_MAX},  { s\_impdrv\_inten1\_group\_table, s\_impdrv\_inten1\_cnv\_table, IMPDRV\_INTEN1\_CORE\_MAX},  { s\_impdrv\_inten1\_group\_table, s\_impdrv\_inten1\_cnv\_table, IMPDRV\_INTEN1\_CORE\_MAX},  { s\_impdrv\_minten\_group\_table, s\_impdrv\_minten\_cnv\_table, IMPDRV\_MINTEN\_CORE\_MAX},  }; |
| **Description** | IMP Driver determines conversion of register table by this table.  Follows the st\_impdrv\_inten\_reg\_tbl\_t structure. |
| **Remarks** | N/A |

Table 5‑86: s\_impdrv\_inten\_reg\_tbl

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const [st\_impdrv\_inten\_reg\_tbl\_t](#_st_impdrv_inten_reg_tbl_t)s\_impdrv\_inten\_reg\_tbl[IMPDRV\_INSTANCETABLE\_NUM] =  {  /\*\* p\_inten\_group\_table p\_inten\_cnv\_table cnv\_table\_num \*/  { NULL, NULL, 　　　　　　　IMPDRV\_DUMMY\_UINT32 },  { s\_impdrv\_inten0\_group\_table, s\_impdrv\_inten0\_cnv\_table, IMPDRV\_INTEN0\_CORE\_MAX},  { s\_impdrv\_inten0\_group\_table, s\_impdrv\_inten0\_cnv\_table, IMPDRV\_INTEN0\_CORE\_MAX},  { s\_impdrv\_inten0\_group\_table, s\_impdrv\_inten0\_cnv\_table, IMPDRV\_INTEN0\_CORE\_MAX},  { s\_impdrv\_inten1\_group\_table, s\_impdrv\_inten1\_cnv\_table, IMPDRV\_INTEN1\_CORE\_MAX},  { s\_impdrv\_inten1\_group\_table, s\_impdrv\_inten1\_cnv\_table, IMPDRV\_INTEN1\_CORE\_MAX},  { s\_impdrv\_inten1\_group\_table, s\_impdrv\_inten1\_cnv\_table, IMPDRV\_INTEN1\_CORE\_MAX},  { s\_impdrv\_minten\_group\_table, s\_impdrv\_minten\_cnv\_table, IMPDRV\_MINTEN\_CORE\_MAX},  }; |
| **Description** | IMP Driver determines conversion of register table by this table.  Follows the [st\_impdrv\_inten\_reg\_tbl\_t](#_st_impdrv_inten_reg_tbl_t) structure. |
| **Remarks** | N/A |

##### s\_hwrsc\_def\_table

Table 5‑87: s\_hwrsc\_def\_table

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M]**  IMPDRV\_STATIC  const [st\_impdrv\_hwrsc\_def\_t](#_st_impdrv_hwrsc_def_t) s\_hwrsc\_def\_table[IMPDRV\_HWRSC\_TABLE\_NUM] =  {  /\*\* Resource Name(Key), Physical adrs, Area size Read only internal \*/  { “imp\_top\_00” , 0xFFA00000U , 0x00010000U , true , false },  { “imp\_spmi\_00”, 0xED000000U , 0x000E0000U , false , false },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true }  };  **[R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const [st\_impdrv\_hwrsc\_def\_t](#_st_impdrv_hwrsc_def_t) s\_hwrsc\_def\_table[IMPDRV\_HWRSC\_TABLE\_NUM] =  {  /\*\* Resource Name(Key), Physical adrs, Area size Read only internal \*/  { “imp\_top\_00” , 0xFFA00000U , 0x00010000U , true , false },  { “imp\_spmi\_00”, 0xED000000U , 0x00200000U , false , false },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true }  };  [R-CarV4H]  IMPDRV\_STATIC  const st\_impdrv\_hwrsc\_def\_t s\_hwrsc\_def\_table[IMPDRV\_HWRSC\_TABLE\_NUM] =  {  /\*\* Resource Name(Key), Physical adrs, Area size Read only internal \*/  { "imp\_top\_00" , 0xFF900000U , 0x00004000U , true , false },  { "imp\_spmi\_00" , 0xED300000U , 0x00100000U , false , false },  { "imp\_spmc\_00" , 0xED400000U , 0x00200000U , false , false },  { "imp\_reg\_spmi\_00" , 0xFFA80000U , 0x00004000U , true , false },  { "imp\_reg\_spmc\_00" , 0xFFAB0000U , 0x00004000U , true , false },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true },  { NULL , 0x00000000U , 0x00000000U , true , true }  }; |
| **Description** | IMPDRV\_Private\_Static\_Variables Private file static variables  Follows the [st\_impdrv\_hwrsc\_def\_t](#_st_impdrv_hwrsc_def_t) structure. |
| **Remarks** | N/A |

##### s\_impdrv\_used\_instance

Table 5‑88: s\_impdrv\_used\_instance

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const uint32\_t s\_impdrv\_used\_instance[IMPDRV\_INSTANCETABLE\_NUM] =  {  0xFFFFFFFFU, /\*\*< Dummy for Index adjustment \*/  0x00000001U, /\*\*< IMPDRV\_INSTANCE\_0 \*/  0x00000002U, /\*\*< IMPDRV\_INSTANCE\_1 \*/  0x00000004U, /\*\*< IMPDRV\_INSTANCE\_2 \*/  0x00000008U, /\*\*< IMPDRV\_INSTANCE\_3 \*/  0x00000010U /\*\*< IMPDRV\_INSTANCE\_4 \*/  };  [R-CarV4H]  IMPDRV\_STATIC  const uint32\_t s\_impdrv\_used\_instance[IMPDRV\_INSTANCETABLE\_NUM] =  {  0xFFFFFFFFU, /\*\*< Dummy for Index adjustment \*/  0x00000001U, /\*\*< IMPDRV\_INSTANCE\_0 \*/  0x00000002U, /\*\*< IMPDRV\_INSTANCE\_1 \*/  0x00000004U /\*\*< IMPDRV\_INSTANCE\_2 \*/  }; |
| **Description** | IMP Driver determines conversion of register table by this table. |
| **Remarks** | N/A |

##### s\_impdrv\_inten\_group\_table

Table 5‑89: s\_impdrv\_inten\_group\_table

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_group\_tbl\_t s\_impdrv\_inten\_group\_table[IMPDRV\_GROUP\_MAX] =  {  /\*\* group\_bit group\_reg \*/  { IMPDRV\_DUMMY\_UINT32, IMPDRV\_DUMMY\_UINT32 }, /\*\*< Dummy for Index \*/  { IMPDRV\_DUMMY\_UINT32, IMPDRV\_DUMMY\_UINT32 }, /\*\*< Dummy for Index \*/  { 0x20000000U, IMPDRV\_REG\_G0INTSEL }, /\*\* Group0. \*/  { 0x40000000U, IMPDRV\_REG\_G1INTSEL }, /\*\* Group1. \*/  { 0x80000000U, IMPDRV\_REG\_G2INTSEL } /\*\* Group2. \*/  };  [R-CarV4H]  Not Defined |
| **Description** | IMP Driver determines conversion of group table by this table.  Follows the [st\_impdrv\_inten\_reg\_tbl\_t](#_st_impdrv_inten_reg_tbl_t) structure. |
| **Remarks** | N/A |

##### s\_impdrv\_cnv\_ins\_table

Table 5‑90: s\_impdrv\_cnv\_ins\_table

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  e\_impdrv\_instance\_t s\_impdrv\_cnv\_ins\_table =  {  /\*\* core\_type \*/  IMPDRV\_INSTANCE\_0,/\*\*< Identification value for assigning to the IRQ number (0th) \*/  IMPDRV\_INSTANCE\_1,/\*\*< Identification value for assigning to the IRQ number (1st) \*/  IMPDRV\_INSTANCE\_2,/\*\*< Identification value for assigning to the IRQ number (2nd) \*/  IMPDRV\_INSTANCE\_3,/\*\*< Identification value for assigning to the IRQ number (3rd) \*/  IMPDRV\_INSTANCE\_4,/\*\*< Identification value for assigning to the IRQ number (4th) \*/  };  [R-CarV4H]  IMPDRV\_STATIC  const e\_impdrv\_instance\_t s\_impdrv\_cnv\_ins\_table[IMPDRV\_INSTANCETABLE\_NUM - 1U] =  {  /\*\* core\_type \*/  IMPDRV\_INSTANCE\_0 , /\*\*< Identification value for assigning to the IRQ number (0th) \*/  IMPDRV\_INSTANCE\_1 , /\*\*< Identification value for assigning to the IRQ number (1st) \*/  IMPDRV\_INSTANCE\_2 , /\*\*< Identification value for assigning to the IRQ number (2nd)\*/  }; |
| **Description** | IMP Driver determines conversion of Instance table by this table.  Follows the e\_impdrv\_instance\_t structure. |
| **Remarks** | N/A |

#### Core Control

##### s\_mb\_init\_info1

Table 5‑91: s\_mb\_init\_info1

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_dma\_write\_info\_tbl\_t s\_mb\_init\_info1[IMPDRV\_DMA\_MB\_INFO\_SIZE1] =  {  {IMPDRV\_REG\_DMA\_IMGSIZER,IMPDRV\_DMA\_IMGSIZER\_VAL,true,IMPDRV\_DMA\_IMGSIZER\_VAL},  {IMPDRV\_REG\_DMA\_FCR0, IMPDRV\_DMA\_FCR0\_VAL, true,IMPDRV\_DMA\_FCR0\_VAL},  {IMPDRV\_REG\_DMA\_FCR1, IMPDRV\_DMA\_FCR1\_VAL, true,IMPDRV\_DMA\_FCR1\_VAL}  };  [R-CarV4H]  Not Defined |
| **Description** | The IMP Driver initializes the multi-bank memory using this table.  Follows the st\_impdrv\_dma\_write\_info\_tbl\_t structure. |
| **Remarks** | N/A |

##### s\_mb\_init\_info2

Table 5‑92: s\_mb\_init\_info2

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_dma\_write\_info\_tbl\_t s\_mb\_init\_info2[IMPDRV\_DMA\_MB\_INFO\_SIZE2] =  {  {IMPDRV\_REG\_DMA\_S0STR, IMPDRV\_DMA\_S0STR\_VAL, true, IMPDRV\_DMA\_S0STR\_VAL },  {IMPDRV\_REG\_DMA\_S0DATAR, IMPDRV\_DMA\_S0DATAR\_VAL, true, IMPDRV\_DMA\_S0DATAR\_VAL },  {IMPDRV\_REG\_DMA\_S0CR, IMPDRV\_DMA\_S0CR\_VAL, true, IMPDRV\_DMA\_S0CR\_VAL },  {IMPDRV\_REG\_DMA\_S1SAR, IMPDRV\_DMA\_S1SAR\_VAL, true, IMPDRV\_DMA\_S1SAR\_VAL },  {IMPDRV\_REG\_DMA\_S1STR, IMPDRV\_DMA\_S1STR\_VAL, true, IMPDRV\_DMA\_S1STR\_VAL },  {IMPDRV\_REG\_DMA\_S1DATAR, IMPDRV\_DMA\_S1DATAR\_VAL, true, IMPDRV\_DMA\_S1DATAR\_VAL },  {IMPDRV\_REG\_DMA\_S1CR, IMPDRV\_DMA\_S1CR\_VAL, true, IMPDRV\_DMA\_S1CR\_VAL }  };  **[R-CarV4H]**  Not Defined |
| **Description** | The IMP Driver initializes the multi-bank memory using this table.  Follows the st\_impdrv\_dma\_write\_info\_tbl\_t structure. |
| **Remarks** | N/A |

##### s\_mb\_init\_info3

Table 5‑93: s\_mb\_init\_info3

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_dma\_write\_info\_tbl\_t s\_mb\_init\_info3[IMPDRV\_DMA\_MB\_INFO\_SIZE3] =  {  {IMPDRV\_REG\_DMA\_D0STR, IMPDRV\_DMA\_D0STR\_VAL, true, IMPDRV\_DMA\_D0STR\_VAL },  {IMPDRV\_REG\_DMA\_D0CR, IMPDRV\_DMA\_D0CR\_VAL, true, IMPDRV\_DMA\_D0CR\_VAL },  {IMPDRV\_REG\_DMA\_DSWPR, IMPDRV\_DMA\_DSWPR\_VAL, true, IMPDRV\_DMA\_DSWPR\_VAL },  {IMPDRV\_REG\_DMA\_TSCR, IMPDRV\_DMA\_TSCR\_VAL, true, IMPDRV\_DMA\_TSCR\_VAL },  {IMPDRV\_REG\_DMA\_SCTLR, IMPDRV\_DMA\_SCTLR0\_MB\_VAL, false, 0U }  };  **[R-CarV4H]**  Not Defined |
| **Description** | The IMP Driver initializes the multi-bank memory using this table.  Follows the st\_impdrv\_dma\_write\_info\_tbl\_t structure. |
| **Remarks** | N/A |

##### s\_test\_pattern\_tbl

Table 5‑94: s\_test\_pattern\_tbl

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC const struct {  uint32\_t pattern;  size\_t size;  } s\_test\_pattern\_tbl[] = {  { 0x55555555U, (sizeof(uint32\_t) \* 8U) },  { 0xAAAAAAAAU, (sizeof(uint32\_t) \* 8U) },  { 0x33333333U, (sizeof(uint32\_t) \* 8U) },  { 0xCCCCCCCCU, (sizeof(uint32\_t) \* 8U) },  { 0x0F0F0F0FU, (sizeof(uint32\_t) \* 8U) },  { 0xF0F0F0F0U, (sizeof(uint32\_t) \* 8U) },  { 0xFFFFFFFFU, (sizeof(uint32\_t) \* 8U) },  { 0x00000000U, (sizeof(uint32\_t) \* 8U) }  };  **[R-CarV4H]**  Not Defined |
| **Description** | Test pattern to the test buffer. Private static variables. |
| **Remarks** | N/A |

##### s\_soft\_reset

Table 5‑95: s\_soft\_reset

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_imp\_write\_info\_tbl\_t s\_soft\_reset[] =  {  { IMPDRV\_REG\_IMP\_CNF, (IMPDRV\_IMP\_CNF\_VAL | IMPDRV\_IMP\_CNF\_SWRST), false, 0U },  { IMPDRV\_REG\_IMP\_CNF, (IMPDRV\_IMP\_CNF\_VAL), false, 0U }  };  IMPDRV\_STATIC  const st\_impdrv\_dma\_write\_info\_tbl\_t s\_soft\_reset[] =  {  { IMPDRV\_REG\_DMA\_SCTLR, IMPDRV\_DMA\_SCTLR\_SWRST, false, 0U },  { IMPDRV\_REG\_DMA\_SCTLR, IMPDRV\_DMA\_SCTLR\_CLR, false, 0U }  };  **[R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_imp\_write\_info\_tbl\_t s\_soft\_reset[] =  {  { IMPDRV\_REG\_IMPS\_CNF, (IMPDRV\_IMPS\_CNF\_VAL | IMPDRV\_IMPS\_CNF\_SWRST), false, 0U },  { IMPDRV\_REG\_IMPS\_CNF, (IMPDRV\_IMPS\_CNF\_VAL), false, 0U }  };  **[R-CarV4H]**  Not Defined |
| **Description** | Write data from software reset table. Private static variables. |
| **Remarks** | N/A |

##### s\_interrupt\_enable

Table 5‑96: s\_interrupt\_enable

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_imp\_write\_info\_tbl\_t s\_interrupt\_enable[] =  {  { IMPDRV\_REG\_IMP\_INTSTS, IMPDRV\_IMP\_INTSTS\_CLR, false, 0U },  { IMPDRV\_REG\_IMP\_INTEN, (IMPDRV\_IMP\_INTSTS\_MASKCPU | IMPDRV\_IMP\_INTSTS\_APIPINT), false, 0U }  };  **[R-CarV3M]**  IMPDRV\_STATIC  const st\_impdrv\_dma\_write\_info\_tbl\_t s\_interrupt\_enable[] =  {  { IMPDRV\_REG\_DMA\_SCR, 0x00000071U, false, 0U },  { IMPDRV\_REG\_DMA\_SER, (0x00000071U | IMPDRV\_DMA\_SER\_FIX), true, (0x00000071U | IMPDRV\_DMA\_SER\_FIX) },  { IMPDRV\_REG\_DMA\_IMR, (0x00000070U | IMPDRV\_DMA\_SER\_FIX), false, 0U }  };  **[R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_imp\_write\_info\_tbl\_t s\_interrupt\_enable[] =  {  { IMPDRV\_REG\_IMPS\_INTSTS, IMPDRV\_IMPS\_INTSTS\_CLR, false, 0U },  { IMPDRV\_REG\_IMPS\_INTEN, (IMPDRV\_IMPS\_INTSTS\_MASKCPU | IMPDRV\_IMPS\_INTSTS\_APIPINT), false, 0U }  };  **[R-CarV4H]**  Not Defined |
| **Description** | Write data from interrupt setting table. Private static variables. |
| **Remarks** | N/A |

##### s\_transfer\_config

Table 5‑97: s\_transfer\_config

|  |  |
| --- | --- |
| **Format** | **[R-CarV3M] [R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_imp\_write\_info\_tbl\_t s\_transfer\_config[] =  {  { IMPDRV\_REG\_IMP\_IPFUN2, 0x00100000U, true, 0x00100000U },  { IMPDRV\_REG\_IMP\_IPFORM, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_APMAG, 0x01010101U, true, 0x01010101U },  { IMPDRV\_REG\_IMP\_APCLPX, 0x00001FFFU, true, 0x00001FFFU },  { IMPDRV\_REG\_IMP\_CNST, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_BINTHR, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_BINTHR2, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_KNLMSK, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_KNLMSK2, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_LMCTL, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF02, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF35, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF68, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF911, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF1214, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF15, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF1820, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF2123, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF24, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF02H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF35H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF68H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF911H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF1214H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF1517H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF1820H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF2123H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_COEFF24H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_PFFTASEL1, 0x76543210U, true, 0x76543210U },  { IMPDRV\_REG\_IMP\_PFFTAMSK, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_PFFTBMSK, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMP\_APSBSP, 0U , true, 0U },  { IMPDRV\_REG\_IMP\_APSIZE\_SA, 256U , true, 256U },  { IMPDRV\_REG\_IMP\_APSIZE\_SB, 0U , true, 0U },  { IMPDRV\_REG\_IMP\_APSIZE\_DST, 256U , true, 256U },  { IMPDRV\_REG\_IMP\_APDLY, 0x00000004U, true, 0x00000004U },  { IMPDRV\_REG\_IMP\_APCFG, 0x01033310U, true, 0x01033310U },  { IMPDRV\_REG\_IMP\_IPFUN, 0xF2000000U, true, 0xF2000000U },  { IMPDRV\_REG\_IMP\_IPFUN2, 0x60104000U, true, 0x60104000U },  { IMPDRV\_REG\_IMP\_PFFTASEL1, 0x00000000U, true, 0x00000000U }  };  **[R-CarV3M]**  IMPDRV\_STATIC  const st\_impdrv\_dma\_write\_info\_tbl\_t s\_transfer\_config[] =  {  { IMPDRV\_REG\_DMA\_FCR0, 0x000000CCU, true, 0x000000CCU },  { IMPDRV\_REG\_DMA\_S0STR, 0x00000100U, true, 0x00000100U },  { IMPDRV\_REG\_DMA\_S0DATAR, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_DMA\_S0CR, 0x80000003U, true, 0x80000003U },  { IMPDRV\_REG\_DMA\_S1SAR, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_DMA\_S1STR, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_DMA\_S1DATAR, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_DMA\_S1CR, 0x00000003U, true, 0x00000003U },  { IMPDRV\_REG\_DMA\_D0STR, 0x00000100U, true, 0x00000100U },  { IMPDRV\_REG\_DMA\_D0CR, 0x00000003U, true, 0x00000003U },  { IMPDRV\_REG\_DMA\_DSWPR, 0x00000000U, true, 0x00000000U }  };  **[R-CarV3H] [R-CarV3H\_2]**  IMPDRV\_STATIC  const st\_impdrv\_imp\_write\_info\_tbl\_t s\_transfer\_config[] =  {  { IMPDRV\_REG\_IMPS\_IPFUN2, 0x00100000U, true, 0x00100000U },  { IMPDRV\_REG\_IMPS\_IPFORM, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_APMAG, 0x01010101U, true, 0x01010101U },  { IMPDRV\_REG\_IMPS\_APCLPX, 0x00001FFFU, true, 0x00001FFFU },  { IMPDRV\_REG\_IMPS\_CNST, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_BINTHR, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_BINTHR2, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_KNLMSK, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_KNLMSK2, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_LMCTL, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF02, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF35, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF68, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF911, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF1214, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF15, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF1820, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF2123, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF24, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF02H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF35H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF68H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF911H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF1214H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF1517H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF1820H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF2123H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_COEFF24H, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_PFFTASEL1, 0x76543210U, true, 0x76543210U },  { IMPDRV\_REG\_IMPS\_PFFTAMSK, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_PFFTBMSK, 0x00000000U, true, 0x00000000U },  { IMPDRV\_REG\_IMPS\_APSBSP, 0U , true, 0U },  { IMPDRV\_REG\_IMPS\_APSIZE\_SA, 256U , true, 256U },  { IMPDRV\_REG\_IMPS\_APSIZE\_SB, 0U , true, 0U },  { IMPDRV\_REG\_IMPS\_APSIZE\_DST, 256U , true, 256U },  { IMPDRV\_REG\_IMPS\_APDLY, 0x00000004U, true, 0x00000004U },  { IMPDRV\_REG\_IMPS\_APCFG, 0x01033310U, true, 0x01033310U },  { IMPDRV\_REG\_IMPS\_IPFUN, 0xF2000000U, true, 0xF2000000U },  { IMPDRV\_REG\_IMPS\_IPFUN2, 0x60104000U, true, 0x60104000U },  { IMPDRV\_REG\_IMPS\_PFFTASEL1, 0x00000000U, true, 0x00000000U }  };  **[R-Car V4H]**  Not Defined |
| **Description** | Write data from DMA configuration settings table. Private static variables. |
| **Remarks** | N/A |

#### OS Dependence Layer

##### sp\_type\_cnv\_table

Table 5‑98: sp\_type\_cnv\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const char \*const sp\_type\_cnv\_table[IMPDRV\_CORE\_TYPE\_MAX] =  {  “”, 　　　　/\*\*< Not Assigned \*/  “imp”, /\*\*< IMP core \*/  “imp\_ocv”, /\*\*< OCV core \*/  “imp\_dma”, /\*\*< DMAC core \*/  “imp\_psc”, /\*\*< PSC(exe) core \*/  “”, /\*\*< PSC(out) core \*/  “imp\_cnn”, /\*\*< CNN core \*/  “imp\_ldma”, /\*\*< L-DMAC core \*/  “imp\_dta” /\*\*< DTA \*/  }; |
| **Description** | IMP Driver determines the OSAL resources for each core types by this table. |
| **Remarks** | N/A |

Table 5‑99: sp\_type\_cnv\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const char \*const sp\_type\_cnv\_table[IMPDRV\_CORE\_TYPE\_MAX] =  {  “”, 　　　　/\*\*< Not Assigned \*/  “imp”, /\*\*< IMP core \*/  “imp\_slim”, /\*\*< Slim-IMP core \*/  “imp\_ocv”, /\*\*< OCV core \*/  “imp\_dma”, /\*\*< DMAC core \*/  “imp\_dma\_slim”, /\*\*< Slim-DMAC core \*/  “imp\_psc”, /\*\*< PSC(exe) core \*/  “”, /\*\*< PSC(out) core \*/  “imp\_cnn”, /\*\*< CNN core \*/  “imp\_ldma”, /\*\*< L-DMAC core \*/  “imp\_dta” /\*\*< DTA \*/  };  **[R-CarV4H]**  IMPDRV\_STATIC  const char \*const sp\_type\_cnv\_table[IMPDRV\_CORE\_TYPE\_MAX] =  {  "", /\*\*< Not Assigned \*/  "imp", /\*\*< IMP core \*/  "imp\_slim", /\*\*< Slim-IMP core \*/  "imp\_ocv", /\*\*< OCV core \*/  "imp\_dma", /\*\*< DMAC core \*/  "imp\_dma\_slim", /\*\*< Slim-DMAC core \*/  "imp\_psc", /\*\*< PSC(exe) core \*/  "", /\*\*< PSC(out) core \*/  "imp\_cnn", /\*\*< CNN core \*/  "vdsp", /\*\*< DSP \*/  "imp\_dta" /\*\*< DTA \*/  }; |
| **Description** | IMP Driver determines the OSAL resources for each core types by this table. |
| **Remarks** | N/A |

##### s\_impdrv\_irq\_channel\_table

Table 5‑100: s\_impdrv\_irq\_channel\_table

|  |  |
| --- | --- |
| **Format** | IMPDRV\_STATIC  const uint32\_t s\_impdrv\_irq\_channel\_table[IMPDRV\_IRQ\_CHANNEL\_MAX + 1U] =  {  /\*\* IRQ channel number \*/  IMPDRV\_DUMMY\_UINT64, /\*\*< Dummy for Index adjustment \*/  IMPDRV\_IRQ\_CHANNEL\_0, /\*\*< IRQ channel number (0) \*/  IMPDRV\_IRQ\_CHANNEL\_1, /\*\*< IRQ channel number (1) \*/  IMPDRV\_IRQ\_CHANNEL\_2, /\*\*< IRQ channel number (2) \*/  IMPDRV\_IRQ\_CHANNEL\_3, /\*\*< IRQ channel number (3) \*/  IMPDRV\_IRQ\_CHANNEL\_4, /\*\*< IRQ channel number (4) \*/  IMPDRV\_IRQ\_CHANNEL\_5, /\*\*< IRQ channel number (5) \*/  IMPDRV\_IRQ\_CHANNEL\_6 /\*\*< IRQ channel number (6) \*/  }; |
| **Description** | IMP Driver uses this table to convert the instance number enumeration value into an interrupt channel value. |
| **Remarks** | N/A |

# Device Specific definition

The setting parameters to the API of IMP Driver differ depending on the device (SoC).

IMP driver checks and controls the differences in the device.

Table 6‑1 shows the device differences and IMP driver check function.

Table 6‑1 Device Differences

|  |  |  |  |
| --- | --- | --- | --- |
| ***Device Name*** | ***IMP Driver Function*** | | |
| ***R\_IMPDRV\_Init*** | ***R\_IMPDRV\_Quit*** | ***R\_IMPDRV\_AttrInit*** |
| ***V3M*** | Initialize of the IMP Driver (IMP-Xn cores). | Uninitialize of the IMP Driver (IMP-Xn cores). | Initialize of the Attribute data. |
| ***V3H*** | (Same as above) | (Same as above) | (Same as above) |
| ***V3H\_2*** | (Same as above) | (Same as above) | (Same as above) |
| ***V4H*** | (Same as above) | (Same as above) | (Same as above) |
| ***Difference between devices*** | There are differences regarding the cores and instances that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type to be initialized is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number to be initialized is supported by the SoC.  - impdrv\_cmnctl\_chk\_instance\_num  Check if the instance to be initialized is supported by the SoC.  There are differences regarding the hardware resources that the device supports.  [Check functions]  - impdrv\_cmnctl\_reg\_hwrsc\_open  Open only the available hardware resources.  [Device Specific definition]  - s\_hwrsc\_def\_table  Each device has a different register address and value.  [Device Specific definition]  - 5.4.1.4 Common Control  - 5.4.1.5 Core Control | There are differences regarding the cores and instances that the device supports.  [Check functions]  None.  (Because it is checked at the timing of R\_IMPDRV\_Init)  There are differences regarding the hardware resources that the device supports.  [Check functions]  - impdrv\_cmnctl\_reg\_hwrsc\_close  Close only the available hardware resources.  [Device Specific definition]  - s\_hwrsc\_def\_table  Each device has a different register address and value.  [Device Specific definition]  - 5.4.1.4 Common Control | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC. |

|  |  |  |  |
| --- | --- | --- | --- |
| ***Device Name*** | ***IMP Driver Function*** | | |
| ***R\_IMPDRV\_AttrSetCoreMemInit*** | ***R\_IMPDRV\_Start*** | ***R\_IMPDRV\_Stop*** |
| ***V3M*** | Set whether to initialize core memory. | Start of the specific core on IMP-Xn. | Stop of the specific core on IMP-Xn. |
| ***V3H*** | (Same as above) | (Same as above) | (Same as above) |
| ***V3H\_2*** | (Same as above) | (Same as above) | (Same as above) |
| ***V4H*** | (Same as above) | (Same as above) | (Same as above) |
| ***Difference between devices*** | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC. | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC.  Each device has a different register address and value.  [Device Specific definition]  - 5.4.1.5 Core Control | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC. |

|  |  |  |  |
| --- | --- | --- | --- |
| ***Device Name*** | ***IMP Driver Function*** | | |
| ***R\_IMPDRV\_AttrSetCoreMap*** | ***R\_IMPDRV\_AttrSetCl*** | ***R\_IMPDRV\_AttrSetIrqMask*** |
| ***V3M*** | Set of the Core map. | Set of the CL physical address. | Set of the IRQ mask. |
| ***V3H*** | (Same as above) | (Same as above) | (Same as above) |
| ***V3H\_2*** | (Same as above) | (Same as above) | (Same as above) |
| ***V4H*** | (Same as above) | (Same as above) | (Same as above) |
| ***Difference between devices*** | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC.  There are differences regarding the cores in the core map that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_syncc\_val  Check if the cores in the core map are supported by the SoC. | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC. | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC. |

|  |  |  |  |
| --- | --- | --- | --- |
| ***Device Name*** | ***IMP Driver Function*** | | |
| ***R\_IMPDRV\_SetIrqGroup*** | ***R\_IMPDRV\_Execute*** | ***R\_IMPDRV\_ResumeExecution*** |
| ***V3M*** | Set of the IRQ grouping. | Execute of the specific core on IMP-Xn. | Resumes execute of the specific core on IMP-Xn. |
| ***V3H*** | (Same as above) | (Same as above) | (Same as above) |
| ***V3H\_2*** | (Same as above) | (Same as above) | (Same as above) |
| ***V4H*** | (Same as above) | (Same as above) | (Same as above) |
| ***Difference between devices*** | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC.  There are differences in the supported irq group.  [Check functions]  - impdrv\_cmnctl\_chk\_group\_data  Check if the irq group is supported by the SoC and instance.  Each device has a different register address and value.  [Device Specific definition]  - 5.4.1.4 Common Control | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC.  There is a difference between the interrupts supported by the device.  [Check functions]  - impdrv\_\*\*\*ctl\_get\_inten\_val  Ignore interrupts that are not supported by the SoC.  Each device has a different register address and value.  [Device Specific definition]  - 5.4.1.5 Core Control | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC.  There is a difference between the interrupts supported by the device.  [Check functions]  - impdrv\_\*\*\*ctl\_get\_inten\_val  Ignore interrupts that are not supported by the SoC.  Each device has a different register address and value.  [Device Specific definition]  - 5.4.1.5 Core Control |

|  |  |  |  |
| --- | --- | --- | --- |
| ***Device Name*** | ***IMP Driver Function*** | | |
| ***R\_IMPDRV\_GetVersion*** | ***R\_IMPDRV\_SetPmPolicy*** | ***R\_IMPDRV\_GetPmPolicy*** |
| ***V3M*** | Get the software version of IMP Driver. | Set of the power management policy. | Get of the power management policy. |
| ***V3H*** | (Same as above) | (Same as above) | (Same as above) |
| ***V3H\_2*** | (Same as above) | (Same as above) | (Same as above) |
| ***V4H*** | (Same as above) | (Same as above) | (Same as above) |
| ***Difference between devices*** | Not use | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC. | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC. |

|  |  |  |  |
| --- | --- | --- | --- |
| ***Device Name*** | ***IMP Driver Function*** | | |
| ***R\_IMPDRV\_RegGetHwInfo*** | ***R\_IMPDRV\_RegRequired*** | ***R\_IMPDRV\_RegRead32*** |
| ***V3M*** | Get the Register area information of Specified device ID. | Require access to the Specified device ID. | Read 32-bit data from the Specified device ID. |
| ***V3H*** | (Same as above) | (Same as above) | (Same as above) |
| ***V3H\_2*** | (Same as above) | (Same as above) | (Same as above) |
| ***V4H*** | (Same as above) | (Same as above) | (Same as above) |
| ***Difference between devices*** | There are differences regarding the hardware resources that the device supports.  [Check functions]  - impdrv\_cmnctl\_reg\_find\_resource  Check if the hardware resource is supported by the SoC. | There are differences regarding the hardware resources that the device supports.  [Check functions]  - impdrv\_cmnctl\_reg\_find\_resource  Check if the hardware resource is supported by the SoC. | There are differences regarding the hardware resources that the device supports.  [Check functions]  - impdrv\_cmnctl\_reg\_find\_resource  Check if the hardware resource is supported by the SoC. |

|  |  |  |  |
| --- | --- | --- | --- |
| ***Device Name*** | ***IMP Driver Function*** | | |
| ***R\_IMPDRV\_RegWrite32*** | ***R\_IMPDRV\_SetMemPotect*** | ***R\_IMPDRV\_BusIfCheck*** |
| ***V3M*** | Write 32-bit data to the Specified device ID. | Not support | Check the internal bus interface at performing DMA transfer. |
| ***V3H*** | (Same as above) | Not support | (Same as above) |
| ***V3H\_2*** | (Same as above) | Set the memory protection function. | (Same as above) |
| ***V4H*** | (Same as above) | (Same as above) | (Same as above) |
| ***Difference between devices*** | There are differences regarding the hardware resources that the device supports.  [Check functions]  - impdrv\_cmnctl\_reg\_find\_resource  Check if the hardware resource is supported by the SoC. | There is a difference in the supported memory protect mode (EDC/ECC).  [Check functions]  - impdrv\_cmnctl\_reg\_set\_mem\_protect  Check if the memory protect mode (ECC) is supported by the SoC. | There are differences in the core that supports Internal Bus Interface Check.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC.  Each device has a different register address and value.  [Device Specific definition]  - 5.4.1.4 Common Control  - 5.4.1.5 Core Control  - s\_transfer\_config |

|  |  |  |  |
| --- | --- | --- | --- |
| ***Device Name*** | ***IMP Driver Function*** | | |
| ***R\_IMPDRV\_ConfRegCheck*** | ***R\_IMPDRV\_ModuleStopCheck*** | ***R\_IMPDRV\_AttrSetDsp*** |
| ***V3M*** | Check the configuration register at read back of register. | Check the Unintended module stop at read back of register. | Not support |
| ***V3H*** | (Same as above) | (Same as above) | Not support |
| ***V3H\_2*** | (Same as above) | (Same as above) | Not support |
| ***V4H*** | (Same as above) | (Same as above) | (Same as above) |
| ***Difference between devices*** | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC.  Each device has a different register address and value.  [Device Specific definition]  - 5.4.1.5 Core Control | There are differences regarding the cores that the device supports.  [Check functions]  - impdrv\_cmnctl\_get\_corectl\_func  Check if the core type is supported by the SoC.  - impdrv\_\*\*\*ctl\_is\_valid\_core  Check if the core number is supported by the SoC.  Each device has a different register address and value.  [Device Specific definition]  - 5.4.1.5 Core Control | Not support |

**Version History**

| **Date** | **Version** | **Change** | **Approver** | **Checker** | **Author** |
| --- | --- | --- | --- | --- | --- |
|  |  |  |  |  |  |
| October XX, 2022 | 0.01M | The following is the change history from Unit Design Specification for xOS2 (LLWEB-20103556, Ver 1.00M). |  |  | HiICS |
| Table 2-1.  - Add R\_IMPDRV\_AttrSetClBrkAddr() |
| -Add 2.1.1.11 R\_IMPDRV\_AttrSetClBrkAddr |
| Table 2-33. -Add mpdrv\_genctl\_set\_cl\_brk\_addr() |
| Add 2.2.1.1 impdrv\_genctl\_set\_cl\_brk\_addr |
| Table 2-117  -Add impdrv\_\*\*\*ctl\_set\_cl\_brk\_addr |
| Add 2.4.1.13 impdrv\_\*\*\*ctl\_set\_cl\_brk\_addrexecute |
| Add Table 5-49 Definition values (Common Control) [R-CarV4H] |
| Add Table 5-54 Definition Values (Core Control) 「R-CarV4H] |
| Add the V4H in Table 6 |
| Add V4H definition :  Table 5 83: -s\_impdrv\_core\_to\_syncc\_table  -Table 5 85: s\_hwrsc\_def\_table  -Table 5 87: s\_impdrv\_used\_instance  -Table 5 89: s\_impdrv\_cnv\_ins\_table  -Table 5 98: |
| Add comment which have no definition in V4H :  -Table 5 88: s\_impdrv\_inten\_group\_table  -Table 5 90: s\_mb\_init\_info1  -Table 5 91: s\_mb\_init\_info2  -Table 5 92: s\_mb\_init\_info3  -Table 5 93: s\_test\_pattern\_tbl  -Table 5 94: s\_soft\_reset  -Table 5 95: s\_interrupt\_enable  -Table 5 96: s\_transfer\_config |
| Chapter and Item numbers are renumbered |
| May 25, 2023 | 0.02M | The following is the change history for the 6/9 release (performance improvement) |  |  | T.Ogura |
| Table 2-1  -Add R\_IMPDRV\_GetPMState |
| Add 2.1.1.16 R\_IMPDRV\_GetPMState |
| Table 2-34  -Add impdrv\_genctl\_pm\_get\_state |
| Add 2.2.1.10 impdrv\_genctl\_pm\_get\_state |
| Table 2-119  -Add impdrv\_\*\*\*ctl\_quit  -Add impdrv\_\*\*\*ctl\_pm\_get\_state  -Add impdrv\_dspctl\_dsp\_start\_pre  -Add impdrv\_dspctl\_dsp\_update\_app  -Add impdrv\_dspctl\_load\_ptcm  -Add impdrv\_dspctl\_stop\_reg |
| Add 2.4.1.8 impdrv\_\*\*\*ctl\_quit |
| Add 2.4.1.20 impdrv\_\*\*\*ctl\_pm\_get\_state |
| Table 2-176  -Add impdrv\_osdep\_pm\_get\_state  -Add impdrv\_osdep\_dev\_open\_imp  -Add impdrv\_osdep\_dev\_open\_dsp  -Add impdrv\_osdep\_dev\_open\_dsp\_sub |
| Add 2.5.1.11 impdrv\_osdep\_pm\_get\_state |
| Add 2.5.1.26 impdrv\_osdep\_dev\_open\_imp |
| Add 2.5.1.35  impdrv\_osdep\_dev\_open\_dsp |
| Table 5-16  -Add new member (p\_impdrvCorectlPmGetState and p\_impdrvCorectlQuit)  -Add missing member (p\_impdrvCorectlSetDsp, p\_impdrvCorectlSetClBrkAddr and p\_impdrvCorectlSetGosubCond) |
| Table 5-80  -Modify due to st\_impdrv\_corectl\_func\_t updates |
| Add 5.4.2.1.12 e\_impdrv\_pm\_state\_t |
| Modify Description to add Update Information  -2.2.1.2 impdrv\_genctl\_quit  -2.2.1.18 impdrv\_genctl\_reg\_set\_mem\_protect  -2.2.2.4 impdrv\_genctl\_chk\_state\_init  -2.3.1.9 impdrv\_cmnctl\_get\_corectl\_func  -2.4.1.5 impdrv\_\*\*\*ctl\_init\_end  -2.4.1.6 impdrv\_\*\*\*ctl\_start  -2.4.1.7 impdrv\_\*\*\*ctl\_stop  -2.4.1.15 impdrv\_\*\*\*ctl\_execute  -2.4.1.18 impdrv\_\*\*\*ctl\_pm\_set\_policy  -2.4.1.19 impdrv\_dspctl\_pm\_get\_policy  -2.4.1.24 impdrv\_dspctl\_dsp\_start\_pre  -2.4.2.30 impdrv\_dspctl\_dsp\_update\_app  -2.4.2.31 impdrv\_dspctl\_load\_ptcm  -2.4.2.32 impdrv\_dspctl\_stop\_reg  -2.5.1.7 impdrv\_osdep\_pow\_on\_imp  -2.5.1.9 impdrv\_osdep\_pm\_set\_policy  -2.5.1.10 impdrv\_osdep\_pm\_get\_policy  -2.5.1.36 impdrv\_osdep\_pow\_on\_imp\_dsp  -2.5.2.2 impdrv\_osdep\_pow\_on  -2.5.2.3 impdrv\_osdep\_pow\_off  -2.5.2.8 impdrv\_osdep\_dev\_open\_dsp\_sub |
| The following is the change history to fix review findings(SP17\_1) |
| Fixed Parameters In/Out information.  -2.1.1.16  -2.5.1.26  -2.5.2.8 |
| Fixed Parameters description.  -2.2.1.10  -2.4.1.24  -2.4.2.30  -2.4.2.32  -2.5.1.11  -2.5.1.26  -2.5.1.35  -2.5.2.8 |
| Fixed Description.  -2.2.1.2  -2.2.2.4  -2.4.1.5  -2.4.1.8 |
| Fixed Remarks  -2.4.1.24  -2.4.2.30  -2.4.2.31  -2.4.2.32 |
| Minor corrections (e.g. typo, Link error)  -Table 2-176  - 5.4.3.3.10 |
| Assign UD ID to the added function |
| Aug 10, 2023 | 0.03M | Update Activity Diagrams of Chapter 3 due to modify in 0.02M. | S.Hirosawa | H.Matsunaga | T.Ogura |
| Feb 16,2024 | 0.04M | Update Activity Diagrams of Chapter 3 due to modify in xOS3.[V3H1,V3H2,V3M2,V4H2] |  |  | HiICS |
| Modify due to st\_impdrv\_corectl\_func\_t updates.  - Table 5 16  - Table 5 82 |
| Update Data Design  -Table 5-42  -Table 5-56  -Table 5-60 |
| Add Software Unit Design  - R\_IMPDRV\_AttrSetDsp  - R\_IMPDRV\_AttrSetGosubCond  - impdrv\_genctl\_set\_dsp  - impdrv\_genctl\_dsp\_int\_handler  - impdrv\_genctl\_set\_gosub\_cond  - impdrv\_cmnctl\_get\_init\_param  - impdrv\_cmnctl\_get\_dsp\_func  - impdrv\_dspctl\_set\_dsp  - impdrv\_\*\*\*ctl\_set\_cond\_gosub  - impdrv\_\*\*\*ctl\_set\_extend\_config  - impdrv\_dspctl\_init\_dsp  - impdrv\_dspctl\_get\_device\_io  - impdrv\_osdep\_register\_dsp\_irq  - impdrv\_osdep\_enable\_dsp\_irq  - impdrv\_osdep\_disable\_dsp\_irq  - impdrv\_osdep\_unregister\_dsp\_irq  - impdrv\_osdep\_reset\_core\_dsp  - impdrv\_osdep\_get\_dsp\_irq\_channel  - impdrv\_osdep\_dsp0\_int\_handler  - impdrv\_osdep\_dsp1\_int\_handler  - impdrv\_osdep\_dsp2\_int\_handler  - impdrv\_osdep\_dsp3\_int\_handler  - impdrv\_osdep\_wait\_for\_req\_state  Update Software Unit Design  - R\_IMPDRV\_Quit  - R\_IMPDRV\_AttrSetIRQMask  - R\_IMPDRV\_AttrSetClBrkAddr  - R\_IMPDRV\_RegGetHwInfo  - impdrv\_api\_chk\_init\_data  - impdrv\_api\_chk\_core\_info  - impdrv\_api\_chk\_conf\_reg\_check  - impdrv\_genctl\_init  - impdrv\_genctl\_quit  - impdrv\_genctl\_start  - impdrv\_genctl\_stop  - impdrv\_genctl\_set\_cl\_brk\_addr  - impdrv\_genctl\_resume\_exe  - impdrv\_genctl\_set\_core\_mem\_init  - impdrv\_genctl\_set\_irq\_mask  - impdrv\_genctl\_set\_irq\_group  - impdrv\_genctl\_reg\_get\_hw\_info  - impdrv\_genctl\_reg\_read32  - impdrv\_genctl\_reg\_write32  - impdrv\_genctl\_reg\_required  - impdrv\_genctl\_prologue  - impdrv\_genctl\_chk\_state\_init  - impdrv\_genctl\_chk\_state\_uninit  - impdrv\_genctl\_set\_state\_uninit  - impdrv\_genctl\_core\_init  - impdrv\_genctl\_init\_get\_func  - impdrv\_genctl\_init\_set\_state  - impdrv\_genctl\_init\_attr\_init  - impdrv\_cmnctl\_chk\_core\_info  - impdrv\_cmnctl\_chk\_instance\_num  - impdrv\_cmnctl\_cnv\_int\_bit\_core  - impdrv\_ocvctl\_irq\_status\_clear  - impdrv\_ocvctl\_check\_inten\_1st  - impdrv\_ocvctl\_check\_inten\_2nd  - impdrv\_osdep\_mutex\_unlock  - impdrv\_osdep\_pow\_on\_hwrsc  - impdrv\_osdep\_queue\_send\_period  - impdrv\_osdep\_pow\_off  Update References |
| Feb 29,2024 | 0.05M | Add Software Unit Design  - impdrv\_cmnctl\_reg\_spm\_preset  - impdrv\_cmnctl\_reg\_spm\_initialize  - impdrv\_cmnctl\_reg\_spm\_ena\_access  - impdrv\_cmnctl\_reg\_spm\_wait\_init  - impdrv\_cmnctl\_reg\_spm\_chk\_init  - impdrv\_dspctl\_init\_core  - impdrv\_dspctl\_chk\_execute\_data  - impdrv\_dspctl\_dsp\_execute\_pre  - impdrv\_dspctl\_tcm\_config\_d  - impdrv\_dspctl\_tcm\_config\_p  - impdrv\_dspctl\_load\_dtcm  - impdrv\_dspctl\_dsp\_standby  - impdrv\_dspctl\_dsp\_foece\_standby  - impdrv\_dspctl\_chk\_int\_data  Update Software Unit Design  - impdrv\_cmnctl\_init  - impdrv\_cmnctl\_quit  - impdrv\_cmnctl\_judge\_int  - impdrv\_cmnctl\_mutex\_destroy  - impdrv\_cmnctl\_mutex\_lock  - impdrv\_cmnctl\_get\_corectl\_func  - impdrv\_cmnctl\_get\_syncc\_val  - impdrv\_cmnctl\_reg\_init  - impdrv\_cmnctl\_reg\_quit  - impdrv\_cmnctl\_reg\_set\_mem\_protect  - impdrv\_cmnctl\_reg\_mem\_init  - impdrv\_cmnctl\_reg\_read32  - impdrv\_cmnctl\_reg\_write32  - impdrv\_cmnctl\_reg\_required  - impdrv\_cmnctl\_save\_irq\_mask  - impdrv\_cmnctl\_force\_irq\_mask  - impdrv\_cmnctl\_restore\_irq\_mask  - impdrv\_cmnctl\_conf\_reg\_check  - impdrv\_cmnctl\_reg\_chk\_mem\_protect  - impdrv\_cmnctl\_cnv\_int\_core\_bit  - impdrv\_cmnctl\_execute\_no\_group  - impdrv\_cmnctl\_execute\_group  - impdrv\_cmnctl\_chk\_init\_data  - impdrv\_cmnctl\_chk\_group\_data  - impdrv\_cmnctl\_calc\_checksum  - impdrv\_cmnctl\_reg\_mb\_initialize  - impdrv\_\*\*\*ctl\_init\_end  - impdrv\_\*\*\*ctl\_set\_core\_map  - impdrv\_\*\*\*ctl\_set\_cl\_brk\_addr  - impdrv\_\*\*\*ctl\_conf\_reg\_check  - impdrv\_\*\*\*ctl\_soft\_reset  - impdrv\_\*\*\*ctl\_set\_syncc\_config  - impdrv\_\*\*\*ctl\_set\_syncc\_config (\*\*\*:dma/dmas)  - impdrv\_\*\*\*ctl\_int\_cb  - impdrv\_\*\*\*ctl\_int\_cb (\*\*\*:imp/imps)  - impdrv\_\*\*\*ctl\_check\_inten  Add DSP Core portion of Software Unit Design  - impdrv\_\*\*\*ctl\_is\_valid\_core  - impdrv\_\*\*\*ctl\_check\_state  - impdrv\_\*\*\*ctl\_init\_start  - impdrv\_\*\*\*ctl\_stop  - impdrv\_\*\*\*ctl\_attr\_init  - impdrv\_\*\*\*ctl\_int\_handler  - impdrv\_\*\*\*ctl\_resume\_exe |  |  | HiICS |
| Mar, 11, 2024 | 0.06M | Added Software Unit Design  - impdrv\_ocvctl\_init\_core  - impdrv\_\*\*\*ctl\_stop(\*\*\*:dma/dmas)  Fixed Software Unit Design  Fixed description  - impdrv\_\*\*\*ctl\_stop  - impdrv\_\*\*\*ctl\_init\_core  - impdrv\_dmactl\_mb\_init  Fixed Reentrancy  - impdrv\_cnnctl\_get\_inten\_val  - impdrv\_dmactl\_get\_inten\_val  - impdrv\_dmasctl\_get\_inten\_val  - impdrv\_impctl\_get\_inten\_val  - impdrv\_impsctl\_get\_inten\_val  - impdrv\_ocvctl\_get\_inten\_val  - impdrv\_pscctl\_get\_inten\_val  - impdrv\_dmactl\_mb\_init\_main  - impdrv\_dmactl\_mb\_init\_pre  - impdrv\_dmactl\_tbl\_write\_reg  - impdrv\_\*\*\*ctl\_tbl\_write\_reg  - impdrv\_dmactl\_cl\_pre  - impdrv\_dmactl\_mb\_init  Fixed Parameters  - impdrv\_\*\*\*ctl\_int\_main\_func  - impdrv\_dmactl\_mb\_init\_main  - impdrv\_dmactl\_mb\_init\_pre  - impdrv\_dmactl\_tbl\_write\_reg  - impdrv\_dmactl\_cl\_pre  - impdrv\_dmactl\_mb\_init |  |  | KSK |
| Mar, 13, 2024 | Update Data Design  - 5.4.1 Definition  Table 5-43: Definition Values (Common definition)  Table 5-45: Definition Values (Common Control) [R-CarV3M / V3H / V3H\_2]  Table 5-49: Definition values (Common Control) [R-CarV4H]  Table 5-50: Definition Values (Core Control) [R-CarV3M / V3H / V3H\_2]  Table 5-51: Definition Values (Core Control)  Table 5-52: Definition Values (Core Control) [R-CarV3M]  Table 5-53: Definition Values (Core Control) [R-CarV3H]  Table 5-54: Definition Values (Core Control) [R-CarV3H\_2]  Table 5-55 Definition Values (Core Control) [R-CarV4H]  Table 5-56: Definition Values (OS Dependence Layer)  - 5.4.2 Enum  Table 5-69: e\_impdrv\_gosub\_cond\_t  Table 5-72: e\_impdrv\_dspctl\_load\_type\_t |
| Mar, 15, 2024 | Update References  Added to 2.Software Unit Design  - impdrv\_udefctl\_udef\_crc  - impdrv\_udefctl\_set\_ecm  - impdrv\_dspctl\_dsp\_start  - impdrv\_dspctl\_dsp\_execute  - impdrv\_dspctl\_crc\_sub  Fixed Return Value  - impdrv\_dspctl\_resume\_exe  - impdrv\_dspctl\_tcm\_config\_p  - impdrv\_dspctl\_load\_dtcm  Updated the following function’s activity diagrams  -impdrv\_\*\*\*ctl\_pm\_get\_state Note(4)  -impdrv\_dspctl\_dsp\_start Note(6)  -impdrv\_dspctl\_dsp\_execute Note(5)(8)(9)(11)(12)  -impdrv\_dspctl\_stop Note(8)  -impdrv\_dspctl\_int\_handler Note(1)(6)(8)  -impdrv\_dspctl\_resume\_exe Note(8)  -impdrv\_dspctl\_load\_ptcm Note(4)  -impdrv\_dspctl\_tcm\_config\_p Note(7)(8)(9)(10)  -impdrv\_dspctl\_load\_dtcm Note(6)(8)(9)(10)(11)(12)  -impdrv\_dspctl\_stop\_reg Note(5)  -impdrv\_dspctl\_dsp\_foece\_standby Note(3)  -impdrv\_dspctl\_crc\_sub (New)  Update Data Design  -5.4.1 Definition  Table 5-49: Definition Values (Common Control) [R-CarV4H]  Table 5-54: Definition Values (Core Control) [R-CarV4H] |
| Mar, 19, 2024 | Added Software Unit Design  - impdrv\_genctl\_get\_worksize |
| Mar 19, 2024 | 0.07M | Fixed for PR findings(LLWEB-20186048)  2.1.3.1 impdrv\_udefctl\_udef\_crc  2.1.3.2 impdrv\_udefctl\_set\_ecm  2.4.1.28 impdrv\_dspctl\_dsp\_start  - Corrected Range.  2.4.1.29 impdrv\_dspctl\_dsp\_execute  2.4.2.48 impdrv\_dspctl\_crc\_sub  - Corrected Range, Interrupt State.  3　Activity Diagrams  Remove disable ECM from impdrv\_dspctl\_dsp\_execute Note(9).  5.4.1 Definition  - Corrected value of IMPDRV\_REGVAL\_VDSP\_ERROR |  |  | KSK |