Commit 0b51e7e8 authored by Anthony Koo's avatar Anthony Koo Committed by Alex Deucher

drm/amd/display: [FW Promotion] Release 0.0.65

- Implement INBOX0 messaging for HW lock
Signed-off-by: default avatarAnthony Koo <Anthony.Koo@amd.com>
Acked-by: default avatarStylon Wang <stylon.wang@amd.com>
Tested-by: default avatarDaniel Wheeler <daniel.wheeler@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 14b1f073
...@@ -47,10 +47,10 @@ ...@@ -47,10 +47,10 @@
/* Firmware versioning. */ /* Firmware versioning. */
#ifdef DMUB_EXPOSE_VERSION #ifdef DMUB_EXPOSE_VERSION
#define DMUB_FW_VERSION_GIT_HASH 0x9130ab830 #define DMUB_FW_VERSION_GIT_HASH 0x2cab49dfb
#define DMUB_FW_VERSION_MAJOR 0 #define DMUB_FW_VERSION_MAJOR 0
#define DMUB_FW_VERSION_MINOR 0 #define DMUB_FW_VERSION_MINOR 0
#define DMUB_FW_VERSION_REVISION 64 #define DMUB_FW_VERSION_REVISION 65
#define DMUB_FW_VERSION_TEST 0 #define DMUB_FW_VERSION_TEST 0
#define DMUB_FW_VERSION_VBIOS 0 #define DMUB_FW_VERSION_VBIOS 0
#define DMUB_FW_VERSION_HOTFIX 0 #define DMUB_FW_VERSION_HOTFIX 0
...@@ -164,6 +164,13 @@ extern "C" { ...@@ -164,6 +164,13 @@ extern "C" {
#define dmub_udelay(microseconds) udelay(microseconds) #define dmub_udelay(microseconds) udelay(microseconds)
#endif #endif
/**
* Number of nanoseconds per DMUB tick.
* DMCUB_TIMER_CURRENT increments in DMUB ticks, which are 10ns by default.
* If DMCUB_TIMER_WINDOW is non-zero this will no longer be true.
*/
#define NS_PER_DMUB_TICK 10
/** /**
* union dmub_addr - DMUB physical/virtual 64-bit address. * union dmub_addr - DMUB physical/virtual 64-bit address.
*/ */
...@@ -455,6 +462,61 @@ enum dmub_gpint_command { ...@@ -455,6 +462,61 @@ enum dmub_gpint_command {
DMUB_GPINT__PSR_RESIDENCY = 9, DMUB_GPINT__PSR_RESIDENCY = 9,
}; };
/**
* INBOX0 generic command definition
*/
union dmub_inbox0_cmd_common {
struct {
uint32_t command_code: 8; /**< INBOX0 command code */
uint32_t param: 24; /**< 24-bit parameter */
} bits;
uint32_t all;
};
/**
* INBOX0 hw_lock command definition
*/
union dmub_inbox0_cmd_lock_hw {
struct {
uint32_t command_code: 8;
/* NOTE: Must be have enough bits to match: enum hw_lock_client */
uint32_t hw_lock_client: 1;
/* NOTE: Below fields must match with: struct dmub_hw_lock_inst_flags */
uint32_t otg_inst: 3;
uint32_t opp_inst: 3;
uint32_t dig_inst: 3;
/* NOTE: Below fields must match with: union dmub_hw_lock_flags */
uint32_t lock_pipe: 1;
uint32_t lock_cursor: 1;
uint32_t lock_dig: 1;
uint32_t triple_buffer_lock: 1;
uint32_t lock: 1; /**< Lock */
uint32_t should_release: 1; /**< Release */
uint32_t reserved: 8; /**< Reserved for extending more clients, HW, etc. */
} bits;
uint32_t all;
};
union dmub_inbox0_data_register {
union dmub_inbox0_cmd_common inbox0_cmd_common;
union dmub_inbox0_cmd_lock_hw inbox0_cmd_lock_hw;
};
enum dmub_inbox0_command {
/**
* DESC: Invalid command, ignored.
*/
DMUB_INBOX0_CMD__INVALID_COMMAND = 0,
/**
* DESC: Notification to acquire/release HW lock
* ARGS:
*/
DMUB_INBOX0_CMD__HW_LOCK = 1,
};
//============================================================================== //==============================================================================
//</DMUB_GPINT>================================================================= //</DMUB_GPINT>=================================================================
//============================================================================== //==============================================================================
...@@ -573,7 +635,8 @@ struct dmub_cmd_header { ...@@ -573,7 +635,8 @@ struct dmub_cmd_header {
unsigned int type : 8; /**< command type */ unsigned int type : 8; /**< command type */
unsigned int sub_type : 8; /**< command sub type */ unsigned int sub_type : 8; /**< command sub type */
unsigned int ret_status : 1; /**< 1 if returned data, 0 otherwise */ unsigned int ret_status : 1; /**< 1 if returned data, 0 otherwise */
unsigned int reserved0 : 7; /**< reserved bits */ unsigned int multi_cmd_pending : 1; /**< 1 if multiple commands chained together */
unsigned int reserved0 : 6; /**< reserved bits */
unsigned int payload_bytes : 6; /* payload excluding header - up to 60 bytes */ unsigned int payload_bytes : 6; /* payload excluding header - up to 60 bytes */
unsigned int reserved1 : 2; /**< reserved bits */ unsigned int reserved1 : 2; /**< reserved bits */
}; };
...@@ -1346,6 +1409,9 @@ struct dmub_rb_cmd_psr_force_static { ...@@ -1346,6 +1409,9 @@ struct dmub_rb_cmd_psr_force_static {
/** /**
* Set of HW components that can be locked. * Set of HW components that can be locked.
*
* Note: If updating with more HW components, fields
* in dmub_inbox0_cmd_lock_hw must be updated to match.
*/ */
union dmub_hw_lock_flags { union dmub_hw_lock_flags {
/** /**
...@@ -1378,6 +1444,9 @@ union dmub_hw_lock_flags { ...@@ -1378,6 +1444,9 @@ union dmub_hw_lock_flags {
/** /**
* Instances of HW to be locked. * Instances of HW to be locked.
*
* Note: If updating with more HW components, fields
* in dmub_inbox0_cmd_lock_hw must be updated to match.
*/ */
struct dmub_hw_lock_inst_flags { struct dmub_hw_lock_inst_flags {
/** /**
...@@ -1401,16 +1470,16 @@ struct dmub_hw_lock_inst_flags { ...@@ -1401,16 +1470,16 @@ struct dmub_hw_lock_inst_flags {
/** /**
* Clients that can acquire the HW Lock Manager. * Clients that can acquire the HW Lock Manager.
*
* Note: If updating with more clients, fields in
* dmub_inbox0_cmd_lock_hw must be updated to match.
*/ */
enum hw_lock_client { enum hw_lock_client {
/** /**
* Driver is the client of HW Lock Manager. * Driver is the client of HW Lock Manager.
*/ */
HW_LOCK_CLIENT_DRIVER = 0, HW_LOCK_CLIENT_DRIVER = 0,
/** HW_LOCK_CLIENT_SUBVP = 3,
* FW is the client of HW Lock Manager.
*/
HW_LOCK_CLIENT_FW,
/** /**
* Invalid client. * Invalid client.
*/ */
...@@ -2198,6 +2267,46 @@ static inline bool dmub_rb_front(struct dmub_rb *rb, ...@@ -2198,6 +2267,46 @@ static inline bool dmub_rb_front(struct dmub_rb *rb,
return true; return true;
} }
/**
* @brief Determines the next ringbuffer offset.
*
* @param rb DMUB inbox ringbuffer
* @param num_cmds Number of commands
* @param next_rptr The next offset in the ringbuffer
*/
static inline void dmub_rb_get_rptr_with_offset(struct dmub_rb *rb,
uint32_t num_cmds,
uint32_t *next_rptr)
{
*next_rptr = rb->rptr + DMUB_RB_CMD_SIZE * num_cmds;
if (*next_rptr >= rb->capacity)
*next_rptr %= rb->capacity;
}
/**
* @brief Returns a pointer to a command in the inbox.
*
* @param rb DMUB inbox ringbuffer
* @param cmd The inbox command to return
* @param rptr The ringbuffer offset
* @return true if not empty
* @return false otherwise
*/
static inline bool dmub_rb_peek_offset(struct dmub_rb *rb,
union dmub_rb_cmd **cmd,
uint32_t rptr)
{
uint8_t *rb_cmd = (uint8_t *)(rb->base_address) + rptr;
if (dmub_rb_empty(rb))
return false;
*cmd = (union dmub_rb_cmd *)rb_cmd;
return true;
}
/** /**
* @brief Returns the next unprocessed command in the outbox. * @brief Returns the next unprocessed command in the outbox.
* *
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment