mirror of
git://nv-tegra.nvidia.com/linux-nvgpu.git
synced 2025-12-24 02:22:34 +03:00
gpu: nvgpu: doxygen for common.fb hals
Added doxygen documentation for fb hal functions. JIRA NVGPU-4141 Change-Id: I00bf0316c69856596e85314013faddb6f36e765e Signed-off-by: Seshendra Gadagottu <sgadagottu@nvidia.com> Reviewed-on: https://git-master.nvidia.com/r/2234440 Reviewed-by: Philip Elcan <pelcan@nvidia.com> Reviewed-by: Automatic_Commit_Validation_User GVS: Gerrit_Virtual_Submit Reviewed-by: Vinod Gopalakrishnakurup <vinodg@nvidia.com> Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com> Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
This commit is contained in:
committed by
Alex Waterman
parent
bac80f7e76
commit
f974bed1bc
@@ -39,9 +39,48 @@ struct gk20a;
|
||||
* @see gpu_ops
|
||||
*/
|
||||
struct gops_fb_intr {
|
||||
/**
|
||||
* @brief Enable fb hub interrupts.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function enables following fb hub interrupts.
|
||||
* MMU_ECC_UNCORRECTED_ERROR_NOTIFY: Uncorrected ECC errors.
|
||||
* MMU_NONREPLAYABLE_FAULT_NOTIFY: non-replayable fault happened.
|
||||
* MMU_NONREPLAYABLE_FAULT_OVERFLOW : non-replayable fault buffer
|
||||
* overflow occurred.
|
||||
* MMU_OTHER_FAULT_NOTIFY: All other fault notifications from MMU.
|
||||
*/
|
||||
void (*enable)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Disable fb hub interrupts.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function disables fb hub interrupts enabled in enable.
|
||||
*/
|
||||
void (*disable)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief ISR for fb hub interrupts.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This is the entry point to handle fb hub interrupts. This function
|
||||
* handled all the interrupts enabled in enable function.
|
||||
*/
|
||||
void (*isr)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Checks any mmu fault interrupt is pending
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function checks and returns information about mmu fault pending.
|
||||
*
|
||||
* @return true in case of mmu faults pending, false otherwise.
|
||||
*/
|
||||
bool (*is_mmu_fault_pending)(struct gk20a *g);
|
||||
};
|
||||
|
||||
@@ -53,22 +92,198 @@ struct gops_fb_intr {
|
||||
* @see gpu_ops
|
||||
*/
|
||||
struct gops_fb {
|
||||
|
||||
/**
|
||||
* @brief Initializes frame buffer h/w configuration.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* Frame Buffer(FB) init h/w function:
|
||||
* - configures address that is used for issuing flush reads to
|
||||
system memory.
|
||||
* - initializes mmu debugger buffer.
|
||||
* - enables fb interrupts related to mmu faults.
|
||||
*/
|
||||
void (*init_hw)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Intitilizes controls for GMMU state
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function enables platform atomic capability mode to rmw atomic
|
||||
* through following configuration:
|
||||
* NV_PFB_PRI_MMU_CTRL_ATOMIC_CAPABILITY_MODE to RMW MODE
|
||||
* NV_PFB_PRI_MMU_CTRL_ATOMIC_CAPABILITY_SYS_NCOH_MODE to L2
|
||||
* NV_PFB_HSHUB_NUM_ACTIVE_LTCS_HUB_SYS_ATOMIC_MODE to USE_RMW
|
||||
*/
|
||||
void (*init_fs_state)(struct gk20a *g);
|
||||
void (*set_mmu_page_size)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Gets master MMU register control
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function returns register that controls all MMU h/w units.
|
||||
*
|
||||
* @return u32 register for MMU control.
|
||||
*/
|
||||
u32 (*mmu_ctrl)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Gets register control for MMU debug mode
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function returns register that controls MMU debug mode.
|
||||
* In debug mode, MMU translates all faulting engine requests using
|
||||
* two dummy pages. One dummy page handles writes, the other dummy
|
||||
* page handles reads.
|
||||
*
|
||||
* @return u32 register for MMU debug mode control.
|
||||
*/
|
||||
u32 (*mmu_debug_ctrl)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Gets register address to hold dummy page writes in debug mode.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function returns register containing the address of the dummy
|
||||
* page write in debug mode on a fault.
|
||||
*
|
||||
* @return u32 register for dummy page write.
|
||||
*/
|
||||
u32 (*mmu_debug_wr)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Gets register address to hold dummy page reads in debug mode.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function returns register containing the address of the dummy
|
||||
* page read in debug mode on a fault.
|
||||
*
|
||||
* @return u32 register for dummy page read.
|
||||
*/
|
||||
u32 (*mmu_debug_rd)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Dumps VPR information.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function error logs VPR information that the MMU fetches from
|
||||
* memory controller. VPR info has following data:
|
||||
* - addr_lo displays the lower address of the VPR
|
||||
* - addr_hi displays the upper address of the VPR.
|
||||
* - cya_low and cya_hi displays CYA bits the control the
|
||||
* trust level of each client.
|
||||
*/
|
||||
void (*dump_vpr_info)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Dumps WPR information.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function error logs WPR information that the MMU fetches from
|
||||
* memory controller. WPR info has following data:
|
||||
* - allow_read displays the read access controls
|
||||
* - allow_write displays the write access controls
|
||||
* - wpr1_addr_lo displays the lower address of the WPR1
|
||||
* - wpr1_addr_hi displays the upper address of the WPR1.
|
||||
* - wpr2_addr_lo displays the lower address of the WPR2
|
||||
* - wpr2_addr_hi displays the upper address of the WPR2.
|
||||
*/
|
||||
void (*dump_wpr_info)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Trigger VPR fetch information.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
*
|
||||
* This function triggers VPR fetch and waits until VPR fetch is
|
||||
* completed.
|
||||
*
|
||||
* @return 0 in case of success, < 0 in case of failure.
|
||||
* @retval -ETIMEDOUT if CPU polling timeout during VPR fetch.
|
||||
*/
|
||||
int (*vpr_info_fetch)(struct gk20a *g);
|
||||
|
||||
/**
|
||||
* @brief Read WPR info.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
* @param wpr_base [out] WPR base address.
|
||||
* @param wpr_size [out] WPR region size.
|
||||
*
|
||||
* This function reads WPR info and returns WPR base address and
|
||||
* WPR size.
|
||||
*/
|
||||
void (*read_wpr_info)(struct gk20a *g, u64 *wpr_base, u64 *wpr_size);
|
||||
|
||||
/**
|
||||
* @brief Invalidate TLB specific to pdb given.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
* @param pdb [in] Pointer to pdb.
|
||||
*
|
||||
* This function invalidates all va addressed specified by pdb.
|
||||
* It includes following steps:
|
||||
* - Wait until pri input fifo space available for tlb invalidation.
|
||||
* - Setup pdb address space for invalidation.
|
||||
* - Trigger invalidate of all va address and wait for completion.
|
||||
*
|
||||
* @return 0 in case of success, < 0 in case of failure.
|
||||
* @retval -ETIMEDOUT if CPU polling timeout during any tlb invalidate
|
||||
* operations.
|
||||
*/
|
||||
int (*tlb_invalidate)(struct gk20a *g, struct nvgpu_mem *pdb);
|
||||
|
||||
/**
|
||||
* @brief Setup mmu fault buffer.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
* @param index [in] Fault buffer index.
|
||||
*
|
||||
* This function configures mmu fault buffer for h/w and s/w use. When
|
||||
* mmu fault occurs h/w will write fault info in the region set-up by
|
||||
* s/w for s/w consumption.
|
||||
*/
|
||||
void (*fault_buf_configure_hw)(struct gk20a *g, u32 index);
|
||||
|
||||
/**
|
||||
* @brief Check if mmu fault buffer is enabled or not
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
* @param index [in] Fault buffer index.
|
||||
*
|
||||
* This function checks and returns whether fault buffer is enabled
|
||||
* for specified index.
|
||||
*
|
||||
* @return true in case of fault buffer enabled, false otherwise.
|
||||
*/
|
||||
bool (*is_fault_buf_enabled)(struct gk20a *g, u32 index);
|
||||
|
||||
/**
|
||||
* @brief Setup mmu fault buffer state.
|
||||
*
|
||||
* @param g [in] Pointer to GPU driver struct.
|
||||
* @param index [in] Fault buffer index.
|
||||
* @param state [in] NVGPU_MMU_FAULT_BUF_ENABLED or
|
||||
* NVGPU_MMU_FAULT_BUF_DISABLED
|
||||
*
|
||||
* This function set-up mmu fault buffer state.
|
||||
* NVGPU_MMU_FAULT_BUF_ENABLED : set the actual size of fault buffer.
|
||||
* NVGPU_MMU_FAULT_BUF_DISABLED : Clears fault buffer size.
|
||||
*/
|
||||
void (*fault_buf_set_state_hw)(struct gk20a *g, u32 index, u32 state);
|
||||
|
||||
struct gops_fb_intr intr;
|
||||
|
||||
/** @cond DOXYGEN_SHOULD_SKIP_THIS */
|
||||
void (*set_mmu_page_size)(struct gk20a *g);
|
||||
|
||||
u32 (*read_mmu_fault_buffer_get)(struct gk20a *g, u32 index);
|
||||
u32 (*read_mmu_fault_buffer_put)(struct gk20a *g, u32 index);
|
||||
u32 (*read_mmu_fault_buffer_size)(struct gk20a *g, u32 index);
|
||||
@@ -86,9 +301,6 @@ struct gops_fb {
|
||||
u32 *inst_lo, u32 *inst_hi);
|
||||
void (*write_mmu_fault_status)(struct gk20a *g, u32 reg_val);
|
||||
|
||||
struct gops_fb_intr intr;
|
||||
|
||||
/** @cond DOXYGEN_SHOULD_SKIP_THIS */
|
||||
struct nvgpu_hw_err_inject_info_desc * (*get_hubmmu_err_desc)
|
||||
(struct gk20a *g);
|
||||
#ifdef CONFIG_NVGPU_COMPRESSION
|
||||
|
||||
Reference in New Issue
Block a user