MPC5748G: MachineCheck exception hen trying to access peripherals in user mode

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

MPC5748G: MachineCheck exception hen trying to access peripherals in user mode

259 次查看
Nox-rr
Contributor I

Hello,

I ported OpenPicoRTOS to PowerPC platforms & ran into an issue.

Despite configuring the PBRIDGE (correctly ?) i get a MachineCheck exception every time i try to access a peripheral in user mode.

Supervisor mode works fine but it's not really what i'm after, i want user/supervisor mode management (+MPU) & being able to access peripherals in user mode.

I tried various things but nothing seems to work, i don't know if i'm doing something wrong of it it's simply not possible.

Right now i just kept everything in supervisor mode for demonstration purposes, here's the current state of the code:

 - My attempt at configuring the PBRIDGE:

https://github.com/jnaulet/OpenPicoRTOS/blob/v1.11.x/arch/powerpc/e200z4/mach-mpc574x/startup.S

 - The de-activated user mode (in arch_save_first_context):

https://github.com/jnaulet/OpenPicoRTOS/blob/v1.11.x/arch/powerpc/e200z4/picoRTOS_portasm.S

 - The complete demo i use for debugging this system:

https://github.com/jnaulet/OpenPicoRTOS/tree/v1.11.x/demo/devkit-mpc5748g

Any help is appreciated.

Kind regards.

0 项奖励
回复
1 回复

128 次查看
petervlna
NXP TechSupport
NXP TechSupport

Hello,

there can be multiple reasons for user mode access rejection:

Most probably PBRIDGE or MPU configuration.

You can start checking following:

  1. PBRIDGE PACR/OPACR initialization.
  2. Whether all peripheral slots are configured for user access.
  3. MPU region definitions covering:
    • 0xFxxxxxxx peripheral space
    • read/write permissions
    • supervisor/user attributes.
  4. MSR value after the RTOS drops to user mode.
  5. The exact peripheral address that causes the fault.
  6. MCSR/ESR/DEAR at IVOR1 entry.

Best Regards,

Peter

0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-2387351%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3EMPC5748G%EF%BC%9A%E5%B0%9D%E8%AF%95%E5%9C%A8%E7%94%A8%E6%88%B7%E6%A8%A1%E5%BC%8F%E4%B8%8B%E8%AE%BF%E9%97%AE%E5%A4%96%E5%9B%B4%E8%AE%BE%E5%A4%87%E6%97%B6%E5%8F%91%E7%94%9F%20MachineCheck%20%E5%BC%82%E5%B8%B8%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2387351%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%EF%BC%8C%3C%2FP%3E%3CP%3E%E6%88%91%E5%B0%86%20OpenPicoRTOS%20%E7%A7%BB%E6%A4%8D%E5%88%B0%20PowerPC%20%E5%B9%B3%E5%8F%B0%E6%97%B6%E9%81%87%E5%88%B0%E4%BA%86%E9%97%AE%E9%A2%98%E3%80%82%3C%2FP%3E%3CP%3E%E5%B0%BD%E7%AE%A1%E6%88%91%E5%B7%B2%E6%AD%A3%E7%A1%AE%E9%85%8D%E7%BD%AE%E4%BA%86%20PBRIDGE%EF%BC%8C%E4%BD%86%E6%AF%8F%E6%AC%A1%E5%B0%9D%E8%AF%95%E5%9C%A8%E7%94%A8%E6%88%B7%E6%A8%A1%E5%BC%8F%E4%B8%8B%E8%AE%BF%E9%97%AE%E5%A4%96%E5%9B%B4%E8%AE%BE%E5%A4%87%E6%97%B6%EF%BC%8C%E9%83%BD%E4%BC%9A%E5%87%BA%E7%8E%B0%20MachineCheck%20%E5%BC%82%E5%B8%B8%E3%80%82%3C%2FP%3E%3CP%3E%E7%AE%A1%E7%90%86%E5%91%98%E6%A8%A1%E5%BC%8F%E8%BF%90%E8%A1%8C%E8%89%AF%E5%A5%BD%EF%BC%8C%E4%BD%86%E8%BF%99%E5%B9%B6%E4%B8%8D%E6%98%AF%E6%88%91%E6%83%B3%E8%A6%81%E7%9A%84%EF%BC%8C%E6%88%91%E6%83%B3%E8%A6%81%E7%94%A8%E6%88%B7%2F%E7%AE%A1%E7%90%86%E5%91%98%E6%A8%A1%E5%BC%8F%E7%AE%A1%E7%90%86%EF%BC%88%2BMPU%EF%BC%89%E5%B9%B6%E4%B8%94%E8%83%BD%E5%A4%9F%E5%9C%A8%E7%94%A8%E6%88%B7%E6%A8%A1%E5%BC%8F%E4%B8%8B%E8%AE%BF%E9%97%AE%E5%A4%96%E5%9B%B4%E8%AE%BE%E5%A4%87%E3%80%82%3C%2FP%3E%3CP%3E%E6%88%91%E5%B0%9D%E8%AF%95%E4%BA%86%E5%90%84%E7%A7%8D%E6%96%B9%E6%B3%95%EF%BC%8C%E4%BD%86%E4%BC%BC%E4%B9%8E%E9%83%BD%E8%A1%8C%E4%B8%8D%E9%80%9A%EF%BC%8C%E6%88%91%E4%B8%8D%E7%9F%A5%E9%81%93%E6%98%AF%E6%88%91%E5%81%9A%E9%94%99%E4%BA%86%E4%BB%80%E4%B9%88%EF%BC%8C%E8%BF%98%E6%98%AF%E6%A0%B9%E6%9C%AC%E5%B0%B1%E5%81%9A%E4%B8%8D%E5%88%B0%E3%80%82%3C%2FP%3E%3CP%3E%E7%9B%AE%E5%89%8D%E4%B8%BA%E4%BA%86%E6%BC%94%E7%A4%BA%E7%9B%AE%E7%9A%84%EF%BC%8C%E6%88%91%E5%B0%86%E6%89%80%E6%9C%89%E7%A8%8B%E5%BA%8F%E9%83%BD%E4%BF%9D%E6%8C%81%E5%9C%A8%E7%AE%A1%E7%90%86%E6%A8%A1%E5%BC%8F%E4%B8%8B%EF%BC%8C%E4%BB%A5%E4%B8%8B%E6%98%AF%E5%BD%93%E5%89%8D%E4%BB%A3%E7%A0%81%E7%8A%B6%E6%80%81%EF%BC%9A%3C%2FP%3E%3CP%3E-%20%E6%88%91%E5%B0%9D%E8%AF%95%E9%85%8D%E7%BD%AE%20PBRIDGE%EF%BC%9A%3C%2FP%3E%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fgithub.com%2Fjnaulet%2FOpenPicoRTOS%2Fblob%2Fv1.11.x%2Farch%2Fpowerpc%2Fe200z4%2Fmach-mpc574x%2Fstartup.S%22%20target%3D%22_blank%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3Ehttps%3A%2F%2Fgithub.com%2Fjnaulet%2FOpenPicoRTOS%2Fblob%2Fv1.11.x%2Farch%2Fpowerpc%2Fe200z4%2Fmach-mpc574x%2Fstartup.S%3C%2FA%3E%3C%2FP%3E%3CP%3E-%20%E5%B7%B2%E5%81%9C%E7%94%A8%E7%9A%84%E7%94%A8%E6%88%B7%E6%A8%A1%E5%BC%8F%EF%BC%88%E5%9C%A8%20arch_save_first_context%20%E4%B8%AD%EF%BC%89%EF%BC%9A%3C%2FP%3E%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fgithub.com%2Fjnaulet%2FOpenPicoRTOS%2Fblob%2Fv1.11.x%2Farch%2Fpowerpc%2Fe200z4%2FpicoRTOS_portasm.S%22%20target%3D%22_blank%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3Ehttps%3A%2F%2Fgithub.com%2Fjnaulet%2FOpenPicoRTOS%2Fblob%2Fv1.11.x%2Farch%2Fpowerpc%2Fe200z4%2FpicoRTOS_portasm.S%3C%2FA%3E%3C%2FP%3E%3CP%3E-%20%E6%88%91%E7%94%A8%E4%BA%8E%E8%B0%83%E8%AF%95%E6%AD%A4%E7%B3%BB%E7%BB%9F%E7%9A%84%E5%AE%8C%E6%95%B4%E6%BC%94%E7%A4%BA%EF%BC%9A%3C%2FP%3E%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fgithub.com%2Fjnaulet%2FOpenPicoRTOS%2Ftree%2Fv1.11.x%2Fdemo%2Fdevkit-mpc5748g%22%20target%3D%22_blank%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3Ehttps%3A%2F%2Fgithub.com%2Fjnaulet%2FOpenPicoRTOS%2Ftree%2Fv1.11.x%2Fdemo%2Fdevkit-mpc5748g%3C%2FA%3E%3C%2FP%3E%3CP%3E%E9%9D%9E%E5%B8%B8%E6%84%9F%E8%B0%A2%E6%82%A8%E7%9A%84%E5%B8%AE%E5%8A%A9%E3%80%82%3C%2FP%3E%3CP%3E%E4%BA%B2%E5%88%87%E7%9A%84%E9%97%AE%E5%80%99%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2388099%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20MPC5748G%3A%20MachineCheck%20exception%20hen%20trying%20to%20access%20peripherals%20in%20user%20mode%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2388099%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%EF%BC%8C%3C%2FP%3E%0A%3CP%3E%E7%94%A8%E6%88%B7%E6%A8%A1%E5%BC%8F%E8%AE%BF%E9%97%AE%E8%A2%AB%E6%8B%92%E7%BB%9D%E7%9A%84%E5%8E%9F%E5%9B%A0%E5%8F%AF%E8%83%BD%E6%9C%89%E5%A4%9A%E7%A7%8D%EF%BC%9A%3C%2FP%3E%0A%3CP%3E%E5%BE%88%E5%8F%AF%E8%83%BD%E6%98%AF%20PBRIDGE%20%E6%88%96%20MPU%20%E9%85%8D%E7%BD%AE%E3%80%82%3C%2FP%3E%0A%3CP%3E%E6%82%A8%E5%8F%AF%E4%BB%A5%E5%BC%80%E5%A7%8B%E6%A3%80%E6%9F%A5%E4%BB%A5%E4%B8%8B%E5%86%85%E5%AE%B9%EF%BC%9A%3C%2FP%3E%0A%3COL%3E%0A%3CLI%3EPBRIDGE%20PACR%2FOPACR%20%E5%88%9D%E5%A7%8B%E5%8C%96%E3%80%82%3C%2FLI%3E%0A%3CLI%3E%E6%89%80%E6%9C%89%E5%A4%96%E5%9B%B4%E8%AE%BE%E5%A4%87%E6%8F%92%E6%A7%BD%E6%98%AF%E5%90%A6%E9%83%BD%E5%B7%B2%E9%85%8D%E7%BD%AE%E4%B8%BA%E4%BE%9B%E7%94%A8%E6%88%B7%E8%AE%BF%E9%97%AE%E3%80%82%3C%2FLI%3E%0A%3CLI%3EMPU%E5%8C%BA%E5%9F%9F%E5%AE%9A%E4%B9%89%E6%B6%B5%E7%9B%96%EF%BC%9A%0A%3CUL%3E%0A%3CLI%3E0xFxxxxxxx%20%E5%A4%96%E5%9B%B4%E7%A9%BA%E9%97%B4%3C%2FLI%3E%0A%3CLI%3E%E8%AF%BB%2F%E5%86%99%E6%9D%83%E9%99%90%3C%2FLI%3E%0A%3CLI%3E%E7%AE%A1%E7%90%86%E5%91%98%2F%E7%94%A8%E6%88%B7%E5%B1%9E%E6%80%A7%E3%80%82%3C%2FLI%3E%0A%3C%2FUL%3E%0A%3C%2FLI%3E%0A%3CLI%3ERTOS%20%E9%99%8D%E8%87%B3%E7%94%A8%E6%88%B7%E6%A8%A1%E5%BC%8F%E5%90%8E%E7%9A%84%20MSR%20%E5%80%BC%E3%80%82%3C%2FLI%3E%0A%3CLI%3E%E5%AF%BC%E8%87%B4%E6%95%85%E9%9A%9C%E7%9A%84%E7%A1%AE%E5%88%87%E5%A4%96%E5%9B%B4%E8%AE%BE%E5%A4%87%E5%9C%B0%E5%9D%80%E3%80%82%3C%2FLI%3E%0A%3CLI%3EMCSR%2FESR%2FDEAR%20%E5%9C%A8%20IVOR1%20%E5%85%A5%E5%8F%A3%E5%A4%84%E3%80%82%3C%2FLI%3E%0A%3C%2FOL%3E%0A%3CP%3E%E9%A1%BA%E7%A5%9D%E5%95%86%E7%A5%BA%EF%BC%81%3C%2FP%3E%0A%3CP%3EPeter%3C%2FP%3E%3C%2FLINGO-BODY%3E